OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [rtems-20020807/] [doc/] [itron3.0/] [task.t] - Blame information for rev 1771

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1026 ivang
@c
2
@c  COPYRIGHT (c) 1988-2002.
3
@c  On-Line Applications Research Corporation (OAR).
4
@c  All rights reserved.
5
@c
6
@c  This is the chapter from the RTEMS ITRON User's Guide that
7
@c  documents the services provided by the task
8
@c  manager.
9
@c
10
@c  task.t,v 1.12 2002/01/17 21:47:45 joel Exp
11
@c
12
 
13
@chapter Task Manager
14
 
15
@section Introduction
16
 
17
The task manager is used to directly control and access the state of tasks.  Included among these are functions for creating, deleting, starting and terminating tasks, for releasing the WAIT state of tasks, for enabling/disabling task dispatching, for changing task priority levels, for rotatingtasks on the ready queue, and for accessing task state.
18
 
19
The services provided by the task manager are:
20
 
21
@itemize @bullet
22
@item @code{cre_tsk} - Create Task
23
@item @code{del_tsk} - Delete Task
24
@item @code{sta_tsk} - Start Task
25
@item @code{ext_tsk} - Exit Issuing Task
26
@item @code{exd_tsk} - Exit and Delete Issuing Task
27
@item @code{ter_tsk} - Terminate Other Task
28
@item @code{dis_dsp} - Disable Dispatch
29
@item @code{ena_dsp} - Enable Dispatch
30
@item @code{chg_pri} - Change Task Priority
31
@item @code{rot_rdq} - Rotate Tasks on the Ready Queue
32
@item @code{rel_wai} - Release Wait of Other Task
33
@item @code{get_tid} - Get Task Identifier
34
@item @code{ref_tsk} - Reference Task Status
35
@end itemize
36
 
37
@section Background
38
 
39
@subsection Task Definition
40
Many definitions of a task have been proposed in computer literature. Unfortunately, none of these definitions encompasses all facets of the concept in a manner which is operating system independent. Several of the more common definitions are provided to enable each user to select a definition which best matches their own experience and understanding of the task concept:
41
 
42
@itemize @bullet
43
@item a "dispatchable" unit.
44
@item an entity to which the processor is allocated.
45
@item an atomic unit of a real-time, multiprocessor system.
46
@item single threads of execution which concurrently compete for resources.
47
@item a sequence of closely related computations which can execute concurrently with other computational sequences.
48
@item From our implementation perspective, a task is the smallest thread of execution which can compete on its own for system resources. A task is manifested by the existence of a task control block (TCB).
49
@end itemize
50
 
51
@subsection Task Manager Task Control Block
52
 The Task Control Block (TCB) is a defined data structure which contains all the information that is pertinent to the execution of a task. During system initialization, implementation reserves a TCB for each task configured. A TCB is allocated upon creation of the task and is returned to the TCB free list upon deletion of the task.
53
 
54
The TCB's elements are modified as a result of system calls made by the application in response to external and internal stimuli. The TCB contains a task's name, ID, current priority, current and starting states, TCB user extension pointer, scheduling control structures, as well as data required by a blocked task.
55
 
56
A task's context is stored in the TCB when a task switch occurs. When the task regains control of the processor, its context is restored from the TCB. When a task is restarted, the initial state of the task is restored from the starting context area in the task's TCB.
57
 
58
@subsection T_CTSK Structure
59
The T_CTSK structure contains detailed information necessary to create the task. Such task attributes, start address, priority and stack size.
60
 
61
@example
62
typedef struct t_ctsk @{
63
  VP    exinf;     /* extended information */
64
  ATR   tskatr;    /* task attributes */
65
  FP    task;      /* task start address */
66
  PRI   itskpri;   /* initial task priority */
67
  INT   stksz;     /* stack size */
68
  /* additional implementation dependent information may be included */
69
@} T_CTSK;
70
 
71
@end example
72
 
73
@subsection Task Manager Task States
74
A task may exist in one of the following five states:
75
 
76
@itemize @bullet
77
@item RUN - Currently scheduled to the CPU
78
@item READY - May be scheduled to the CPU
79
@item Wait - Unable to be scheduled to the CPU
80
@itemize @bullet
81
@item (Specific) WAIT - The task is issued a command to wait on a condition
82
@item SUSPEND - Another task suspended execution of the task
83
@item WAIT-SUSPEND - Both the WAIT and SUSPEND states apply
84
@end itemize
85
@item DORMANT - Created task that is not started
86
@item NON-EXISTENT - Uncreated or deleted task
87
@end itemize
88
 
89
An active task may occupy the RUN, READY, Wait or DORMANT state, otherwise the task is considered NON-EXISTENT. One or more tasks may be active in the system simultaneously. Multiple tasks communicate, synchronize, and compete for system resources with each other via system calls. The multiple tasks appear to execute in parallel, but actually each is dispatched to the CPU for periods of time determined by the scheduling algorithm. The scheduling of a task is based on its current state and priority.
90
 
91
@subsection Task Manager Task Priority
92
A task's priority determines its importance in relation to the other tasks executing on the same processor. Our implementation supports 255 levels of priority ranging from 1 to 255. Tasks of numerically smaller priority values are more important tasks than tasks of numerically larger priority values. For example, a task at priority level 5 is of higher privilege than a task at priority level 10. There is no limit to the number of tasks assigned to the same priority.
93
 
94
Each task has a priority associated with it at all times. The initial value of this priority is assigned at task creation time. The priority of a task may be changed at any subsequent time.
95
 
96
Priorities are used by the scheduler to determine which ready task will be allowed to execute. In general, the higher the logical priority of a task, the more likely it is to receive processor execution time.
97
 
98
@section Operations
99
 
100
@subsection Task Manager Creating Tasks
101
The cre_tsk directive creates a task specified by tskid. Specifically, a TCB (Task Control Block) is allocated for the task to be created, and initialized according to accompanying parameter values of itskpri, task, stksz, etc.  A stack area is also allocated for the task based on the parameter stksz.
102
 
103
@subsection Task Manager Starting and Restarting Tasks
104
The sta_tsk directive starts the task specified by tskid.  Specifically, it changes the state of the task specified by tskid from DORMANT into RUN/READY.  This enables the task to compete, based on its current priority, for the processor and other system resources. Any actions, such as suspension or change of priority, performed on a task prior to starting it are nullified when the task is started.
105
 
106
Stacd can be used to specify parameters to be passed to the task when it is started.  This parameter can be read by the task being started, and may be used for transmitting simple messages.
107
 
108
The task priority on starting the task is given by the initial task priority parameter (itskpri) specified when the task was created.
109
 
110
Start request is not queued in this this system call.  In other words, if this system call is issued when the target task is not in DORMANT state, the system call will be ignored, and an E_OBJ error returned to the issuing task.
111
 
112
If cre_tsk [level EN] is not implemented on a system, tasks are created statically when the system is started.  Parameters required for creating a task, such as task starting address (task) and initial task priority (itskpri) are also specified statically at system startup.
113
 
114
@subsection Task Manager Suspending and Resuming Tasks
115
The sus_tsk directive suspends the execution of the task specified by tskid by putting it into SUSPEND state. SUSPEND state is released by issuing the rsm_tsk or frsm_tsk system call.
116
 
117
If the task specified to sus_tsk is already in WAIT state, it will be put in the combined WAIT-SUSPEND state by the execution of sus_tsk.  If wait conditions for the task are later fulfilled, it will enter SUSPEND state. If rsm_tsk is issued on the task, it will return to the WAIT state before the suspension.
118
 
119
Both rsm_tsk and fsm_tsk system calls release SUSPEND state of the task specified by tskid.  Specifically, they cause SUSPEND state to be released and the execution of the specified task to resume when the task has been suspended by the prior execution of sus_tsk.
120
 
121
If the specified task is in WAIT-SUSPEND state, the execution of rsm_tsk only releases the SUSPEND state, and the task will become WAIT state.
122
 
123
@subsection Task Manager Changing Task Priority
124
The chg_pri system call changes the current priority of the task specified by tskid to the value specified by tskpri.
125
 
126
A task may specify itself by specifying tskid = TSK_SELF = 0.  Note, however, that an E_ID error will result if tskid = TSK_SELF = 0 is specified to a system call issued from a task-independent portion.
127
 
128
The priority set by this system call remains in effect until the task exits.  Once a task enters DORMANT state, its priority prior to exiting is lost.  When a task which enters DORMANT state restarts, the initial task priority (itskpri) specified at task creation or at system startup will be used.
129
 
130
@subsection Task Manager Task Deletion
131
The del_tsk system call deletes the task specified by tskid.  Specifically, it changes the state of the task specified by tskid from DORMANT into NON-EXISTENT (a virtual state not existing on the system), and then clears the TCB and releases stack. An E_OBJ error results if this system call is used on a task which is not DORMANT.
132
 
133
After deletion, another task having the same ID number can be created.
134
 
135
The exd_tsk system call causes the issuing task to exit and then delete itself.
136
 
137
When a task exits, that task does not automatically release all the resources (memory blocks, semaphores, etc.) which it had secured prior to the call.  It is the user's responsibility to see to it that all resources are released beforehand.
138
 
139
@section System Calls
140
 
141
This section details the task manager's services.
142
A subsection is dedicated to each of this manager's services and describes the calling sequence, related constants, usage, and status codes.
143
 
144
 
145
@c
146
@c  cre_tsk
147
@c
148
 
149
@page
150
@subsection cre_tsk - Create Task
151
 
152
@subheading CALLING SEQUENCE:
153
 
154
@ifset is-C
155
@example
156
ER cre_tsk(
157
  ID tskid,
158
  T_CTSK *pk_ctsk
159
);
160
@end example
161
@end ifset
162
 
163
@ifset is-Ada
164
@end ifset
165
 
166
@subheading STATUS CODES:
167
 
168
@code{E_OK} - Normal Completion
169
 
170
@code{E_NOMEM} - Insufficient memory (Memory for control block and/or user stack cannot be allocated)
171
 
172
@code{E_ID} - Invalid ID Number (tskid was invalid or could not be used)
173
 
174
@code{E_RSATR} - Reserved attribute (tskatr was invalid or could not be used)
175
 
176
@code{E_OBJ} - Invalid object state (a task of the same ID already exists)
177
 
178
@code{E_OACV} - Object access violation (A tskid less than -4 was specified from a user task.  This is implementation dependent.)
179
 
180
@code{E_PAR} -  Parameter error (pk_ctsk, task, itskpri and/or stksz is invalid)
181
 
182
@code{EN_OBJNO} - An object number which could not be accessed on the target node is specified.
183
 
184
@code{EN_CTXID} - Specified an object on another node when the system call was issued from a task in dispatch disabled state or from a task-independent portion
185
 
186
@code{EN_PAR} -  A value outside the range supported by the target node and/or transmission packet format was specified as a parameter (a value outside supported range was specified for exinf, tskatr, task, itskpri and/or stksz)
187
 
188
@subheading DESCRIPTION:
189
This system call creates the task specified by tskid.  Specifically, a TCB (Task Control Block) is allocated for the task to be created, and initialized according to accompanying parameter values of itskpri, task, tksz, etc.  A stack area is also allocated for the task based on the parameter stksz.
190
 
191
@subheading NOTES:
192
User tasks have positive ID numbers, while system tasks have negative ID numbers.  User tasks cannot access system objects (objects having negative ID numbers).
193
 
194
The new task created by this system call will be put in DORMANT state.
195
 
196
Extended information (exinf) has been added.  This allows the user to include additional information about task attributes.  If a larger region is desired for including user information, the user should allocate memory area and set the address of the memory packet to exinf.
197
 
198
Multiprocessing is not supported. Thus none of the "EN_" status codes will be returned.
199
 
200
 
201
@c
202
@c  del_tsk
203
@c
204
 
205
@page
206
@subsection del_tsk - Delete Task
207
 
208
@subheading CALLING SEQUENCE:
209
 
210
@ifset is-C
211
@example
212
ER del_tsk(
213
  ID tskid
214
);
215
@end example
216
@end ifset
217
 
218
@ifset is-Ada
219
@end ifset
220
 
221
@subheading STATUS CODES:
222
 
223
@code{E_OK} - Normal Completion
224
 
225
@code{E_ID} - Invalid ID Number (tskid was invalid or could not be used)
226
 
227
@code{E_NOEXS} - Object does not exist (the task specified by tskid does not exist)
228
 
229
@code{E_OACV} - Object access violation (A tskid less than -4 was specified from a user task.  This is implementation dependent.)
230
 
231
@code{E_OBJ} -  Invalid object state (the target task is not in DORMANT state)
232
 
233
@code{EN_OBJNO} - An object number which could not be accessed on the target node is specified.
234
 
235
@code{EN_CTXID} - Specified an object on another node when the system call was issued from a task in dispatch disabled state or from a task-independent portion
236
 
237
@subheading DESCRIPTION:
238
This system call deletes the task specified by tskid.  Specifically, it changes the state of the task specified by tskid from DORMANT into NON-EXISTENT (a virtual state not existing on the system), and then clears the TCB and releases stack. An E_OBJ error results if this system call is used on a task which is not DORMANT.
239
 
240
After deletion, another task having the same ID number can be created.
241
 
242
@subheading NOTES:
243
A task cannot delete itself by this system call.  An E_OBJ error will result if a task specifies itself, since such a task cannot be DORMANT. Use the exd_tsk system call rather than this one when a task needs to delete itself.
244
 
245
 
246
@c
247
@c  sta_tsk
248
@c
249
 
250
@page
251
@subsection sta_tsk - Start Task
252
 
253
@subheading CALLING SEQUENCE:
254
 
255
@ifset is-C
256
@example
257
ER sta_tsk(
258
  ID tskid,
259
  INT stacd
260
);
261
@end example
262
@end ifset
263
 
264
@ifset is-Ada
265
@end ifset
266
 
267
@subheading STATUS CODES:
268
 
269
@code{E_OK} - Normal Completion
270
 
271
@code{E_ID} - Invalid ID Number (tskid was invalid or could not be used)
272
 
273
@code{E_NOEXS} - Object does not exist (the task specified by tskid does not exist)
274
 
275
@code{E_OACV} - Object access violation (A tskid less than -4 was specified from a user task.  This is implementation dependent.)
276
 
277
@code{E_OBJ} - Invalid object state (the target task is not in DORMANT state)
278
 
279
@code{EN_OBJNO} - An object number which could not be accessed on the target node is specified.
280
 
281
@code{EN_CTXID} - Specified an object on another node when the system call was issued from a task in dispatch disabled state or from a task-independent portion
282
 
283
@code{EN_PAR} - A value outside the range supported by the target node and/or transmission packet format was specified as a parameter (a value outside supported range was specified for stacd)
284
 
285
@subheading DESCRIPTION:
286
This system call starts the task specified by tskid.  Specifically, it changes the state of the task specified by tskid from DORMANT into RUN/READY.
287
 
288
Stacd can be used to specify parameters to be passed to the task when it is started.  This parameter can be read by the task being started, and may be used for transmitting simple messages.
289
 
290
The task priority on starting the task is given by the initial task priority parameter (itskpri) specified when the task was created.
291
 
292
Start request is not queued in this this system call.  In other words, if this system call is issued when the target task is not in DORMANT state, the system call will be ignored, and an E_OBJ error returned to the issuing task.
293
 
294
If cre_tsk [level EN] is not implemented on a system, tasks are created statically when the system is started.  Parameters required for creating a task, such as task starting address (task) and initial task priority (itskpri) are also specified statically at system startup.
295
 
296
@subheading NOTES:
297
 
298
 
299
@c
300
@c  ext_tsk
301
@c
302
 
303
@page
304
@subsection ext_tsk - Exit Issuing Task
305
 
306
@subheading CALLING SEQUENCE:
307
 
308
@ifset is-C
309
@example
310
void ext_tsk(void);
311
@end example
312
@end ifset
313
 
314
@ifset is-Ada
315
@end ifset
316
 
317
@subheading STATUS CODES:
318
 
319
@code{E_CTX} - Context error (issued from task-independent portions or a task in dispatch disabled state)
320
 
321
 * System call may detect this error.  The error is not returned to the context issuing the system call.  Error codes therefore cannot be returned directly as a return parameter of the system call.  The behavior on error detection is implementation dependent.
322
 
323
 
324
@subheading DESCRIPTION:
325
This system call causes the issuing task to exit, changing the state of the task into the DORMANT state.
326
 
327
@subheading NOTES:
328
When a task exits due to ext_tsk, that task does not automatically release all the resources (memory blocks, semaphores, etc.) which it had obtained prior to the system call.  It is the user's responsibility that all resources are released beforehand.
329
 
330
Ext_tsk is a system call which does not return to the issuing context. Accordingly, even if an error code is returned on detection of some error, it is normal for tasks making this system call not to perform any error checking, and it is in fact possible that a program could run out of control.  For this reason, even if an error is detected upon issuing this system call, the error is not returned to the task which issued the system call.  If information on detected errors is required it should be left in a messagebuffer used as an error log.
331
 
332
In principle, information concerning a task recorded in the TCB, such as task priority, is reset whenever a task is placed in DORMANT state.  For example, its task priority after being restarted would be reset to the initial task priority (itskpri) specified by cre_tsk when it was first created, even if a task's priority was changed using chg_pri, then that task exits using ext_tsk, but later started by sta_tsk.  Task priority does not return to what it was when ext_tsk was executed.
333
 
334
 
335
@c
336
@c  exd_tsk
337
@c
338
 
339
@page
340
@subsection exd_tsk - Exit and Delete Issuing Task
341
 
342
@subheading CALLING SEQUENCE:
343
 
344
@ifset is-C
345
@example
346
void exd_tsk(void);
347
@end example
348
@end ifset
349
 
350
@ifset is-Ada
351
@end ifset
352
 
353
@subheading STATUS CODES:
354
 
355
@code{E_CTX} - Context error (issued from task-independent portions or a task in dispatch disabled state)
356
 
357
 * System call may detect the following error.  The error is not returned to the context issuing the system call even.  Error codes therefore cannot be returned directly as a return parameter of the system call.  The behavior on error detection is implementation dependent.
358
 
359
@subheading DESCRIPTION:
360
This system call causes the issuing task to exit and then delete itself.  In other words the state of the issuing task changes into the NON-EXISTENT (a virtual state not existing on the system).
361
 
362
@subheading NOTES:
363
When a task exits with exd_tsk, that task does not automatically release all the resources (memory blocks, semaphores, etc.) which it had secured prior to the call.  It is the user's responsibility to see to it that all resources are released beforehand.
364
 
365
Exd_tsk is a system call which does not return any parameters to the original issuing context.  Accordingly, even if an error code is returned on detection of some error, it is normal for tasks making this system call not to perform any error checking, and it is in fact possible that a program could run out of control.  For this reason, even if an error is detected upon making this system call, it is supposed that the error is not returned to the task which issued the system call.  If information on detected errors is required it should be left in a messagebuffer used as an error log.
366
 
367
 
368
@c
369
@c  ter_tsk
370
@c
371
 
372
@page
373
@subsection ter_tsk - Terminate Other Task
374
 
375
@subheading CALLING SEQUENCE:
376
 
377
@ifset is-C
378
@example
379
ER ter_tsk(
380
  ID tskid
381
);
382
@end example
383
@end ifset
384
 
385
@ifset is-Ada
386
@end ifset
387
 
388
@subheading STATUS CODES:
389
 
390
@code{E_OK} - Normal Completion
391
 
392
@code{E_ID} - Invalid ID Number (tskid was invalid or could not be used)
393
 
394
@code{E_NOEXS} - Object does not exist (the task specified by tskid does not exist)
395
 
396
@code{E_OACV} - Object access violation (A tskid less than -4 was specified from a user task.  This is implementation dependent.)
397
 
398
@code{E_OBJ} - Invalid object state (the target task is already in DORMANT state or a task invalidly specified itself)
399
 
400
@code{EN_OBJNO} - An object number which could not be accessed on the target node is specified.
401
 
402
@code{EN_CTXID} - Specified an object on another node when the system call was issued from a task in dispatch disabled state or from a task-independent portion
403
 
404
@subheading DESCRIPTION:
405
This system call forcibly terminates the task specified by tskid.  That is, it changes the state of the task specified by tskid into DORMANT.
406
 
407
Even if the target task is in wait state (including SUSPEND state), its wait state will be released and then it will be terminated.  If the target task is on a queue of some sort (such as waiting for a semaphore), it will be removed from that queue by ter_tsk.
408
 
409
A task cannot specify the issuing task in this system call.  An E_OBJ error will result if a task specifies itself.
410
 
411
There is an intermediate state waiting for the response (TR packet or TA packet) from the target node after executing the system call to access the other node and making a request (sending a TP packet) to the node. This state is called the "connection function response wait (TTW_NOD)" state. The ter_tsk system call may specify tasks which are in the connection function response wait state.  Tasks which are waiting for objects (such as a semaphore) on another node may also be specified to this system call. In such cases, ter_tsk will halt any system calls accessing other nodes which have been issued by the task to be terminated.
412
 
413
@subheading NOTES:
414
When a task is terminated by ter_tsk, that task does not automatically release all the resources (memory blocks, semaphores, etc.) which it had obtained prior to the call.  It is the user's responsibility to see to it that all resources are released beforehand.
415
 
416
In principle, information concerning a task recorded in the TCB, such as task priority, is reset whenever a task is placed in DORMANT state.  For example, its task priority after being restarted would be reset to the initial task priority (itskpri) specified by cre_tsk when it was first created, even if a task's priority was changed using chg_pri, then that task is terminated by ter_tsk, but later started by sta_tsk.  Task priority does not return to what it was when ter_tsk was executed.
417
 
418
 
419
@c
420
@c  dis_dsp
421
@c
422
 
423
@page
424
@subsection dis_dsp - Disable Dispatch
425
 
426
@subheading CALLING SEQUENCE:
427
 
428
@ifset is-C
429
@example
430
ER dis_dsp(void);
431
@end example
432
@end ifset
433
 
434
@ifset is-Ada
435
@end ifset
436
 
437
@subheading STATUS CODES:
438
 
439
@code{E_OK} - Normal Completion
440
 
441
@code{E_CTX} - Context error (issued from task-independent portions or issued after execution of loc_cpu)
442
 
443
@subheading DESCRIPTION:
444
This system call disables task dispatching.  Dispatching will remain disabled after this call is issued until a subsequent call to ena_dsp is issued. The status of the issuing task will not be allowed to be changed to READY from the RUN.  It cannot be changed into WAIT, either.  However, since external interrupt is not disabled, interrupt handlers are allowed to run even when dispatching has been disabled.  While an executing task may be preempted by an interrupt handler with dispatching disabled, there is no possibility that it will be preempted by another task.
445
 
446
The following operations occur during the time dispatching is disabled.
447
@itemize @bullet
448
@item Even in a situation where normally a task issuing dis_dsp should be preempted by a system call issued by an interrupt handler or by the task issuing dis_dsp, the task that should normally be executed is not dispatched.  Instead, dispatching of this task is delayed until dispatch disabled state is cleared by ena_dsp.
449
 
450
@item If an interrupt handler invoked during dispatch disabled state issues sus_tsk for a running task (one that executed dis_dsp) to put it in SUSPEND state, or ter_tsk to put it in DORMANT state, the task transition is delayed until dispatch disabled state is cleared.
451
 
452
@item An E_CTX error will result if the task which has executed dis_dsp issues any system calls (such as slp_tsk or wai_sem) capable of putting an issuing task into WAIT state.
453
 
454
@item An EN_CTXID error will result if a task which has executed dis_dsp attempts to operate on objects on another node (that is, if the ID parameter of the system call issued refers to an object on another node).
455
 
456
@item TSS_DDSP will be returned as sysstat if system status is referenced using ref_sys.
457
@end itemize
458
No error will result if a task already in dispatch disable state issues dis_dsp.  It only keeps dispatch disabled state.  No matter how many times dis_dsp has been issued, a single ena_dsp enables dispatching again.  It is therefore for the user to determine what to do with nested pairs of dis_dsp and ena_dsp.
459
 
460
An E_CTX error will result if dis_dsp is issued when both interrupt and dispatching are disabled with loc_cpu.  (For details, see the description of loc_cpu.)
461
 
462
@subheading NOTES:
463
A running task cannot enter DORMANT or NON-EXISTENT state while dispatching is disabled.  An E_CTX error will result if an running task issues either ext_tsk or exd_tsk while interrupt and dispatching are disabled.  Note however that since both ext_tsk and exd_tsk are system calls which do not return to their original contexts, error notification using return parameters of these system calls is not possible.  If information on detected errors is required it should be left in a messagebuffer used as an error log.
464
 
465
Only if the system is not a multiprocessor configuration, system can take advantage of the dispatch disabled state for exclusive inter-task control.
466
 
467
 
468
@c
469
@c  ena_dsp
470
@c
471
 
472
@page
473
@subsection ena_dsp - Enable Dispatch
474
 
475
@subheading CALLING SEQUENCE:
476
 
477
@ifset is-C
478
@example
479
ER ena_dsp(void);
480
@end example
481
@end ifset
482
 
483
@ifset is-Ada
484
@end ifset
485
 
486
@subheading STATUS CODES:
487
 
488
@code{E_OK} - Normal Completion
489
 
490
@code{E_CTX} - Context error (issued from task-independent portions or issued after execution of loc_cpu)
491
 
492
@subheading DESCRIPTION:
493
This system call enables task dispatching, that is, it finishes dispatch disabled state caused by the execution of dis_dsp.
494
 
495
No error will result if a task which is not in dispatch disabled state issues ena_dsp.  In this case, dispatching will just remain enabled.
496
 
497
An E_CTX error will result if ena_dsp is issued when both interrupt and dispatching are disabled with loc_cpu.  (For details, see the description of loc_cpu.)
498
 
499
@subheading NOTES:
500
 
501
 
502
@c
503
@c  chg_pri
504
@c
505
 
506
@page
507
@subsection chg_pri - Change Task Priority
508
 
509
@subheading CALLING SEQUENCE:
510
 
511
@ifset is-C
512
@example
513
ER chg_pri(
514
  ID tskid,
515
  PRI tskpri
516
);
517
@end example
518
@end ifset
519
 
520
@ifset is-Ada
521
@end ifset
522
 
523
@subheading STATUS CODES:
524
 
525
@code{E_OK} - Normal Completion
526
 
527
@code{E_ID} - Invalid ID Number (tskid was invalid or could not be used)
528
 
529
@code{E_NOEXS} - Object does not exist (the task specified by tskid does not exist)
530
 
531
@code{E_OACV} - Object access violation (A tskid less than -4 was specified from a user task.  This is implementation dependent.)
532
 
533
@code{E_PAR} - Parameter error (the value of tskpri is invalid or may not be used)
534
 
535
@code{E_OBJ} - Invalid object state (the target task is in DORMANT state)
536
 
537
@code{EN_OBJNO} - An object number which could not be accessed on the target node is specified.
538
 
539
@code{EN_CTXID} = Specified an object on another node when the system call was issued from a task in dispatch disabled state or from a task-independent portion
540
 
541
@code{EN_PAR} - A value outside the range supported by the target node and/or transmission packet format was specified as a parameter (a value outside supported range was specified for tskpri)
542
 
543
@subheading DESCRIPTION:
544
This system call changes the current priority of the task specified by tskid to the value specified by tskpri.
545
 
546
Under uITRON 3.0 specification, at least any value of 1 through 8 can be specified as task priority.  The smaller the value, the higher the priority.  Priority levels -4 through 0 are reserved, and they may not be used.  Priority levels outside this range (including negative values) may also be specified depending on the implementation; this is considered an extended function [level X] for which compatibility and connectivity are not guaranteed.  In general, negative priority levels are reserved for use by the system.
547
 
548
A task may specify itself by specifying tskid = TSK_SELF = 0.  Note, however, that an E_ID error will result if tskid = TSK_SELF = 0 is specified to a system call issued from a task-independent portion.  The priority set by this system call remains in effect until the task exits.  Once a task enters DORMANT state, its priority prior to exiting is lost.  When a task which enters DORMANT state restarts, the initial task priority (itskpri) specified at task creation or at system startup will be used.
549
 
550
If the target task is linked to ready queue or any other queue, this system call may result in the re-ordering of the queues.  If chg_pri is executed on a task waiting on the ready queue (including tasks in RUN state) or other priority-based queue, the target task will be moved to the end of the part of the queue for the associated priority.  If the priority specified is the same as the current priority, the task will still be moved behind other tasks of the same priority.  It is therefore possible for a task to relinquish its execution privileges using chg_pri on itself by specifying its current priority.
551
 
552
@subheading NOTES:
553
Depending on the implementation, specifying tskpri = TPRI_INI = 0 may cause a task's priority to be reset to the initial task priority (itskpri) which was defined when it was first created or when the system started.  This feature is used in some implementations in order to reset the task priority to its original value after setting it to a higher value for indivisible processing.  This feature is an extended function [level X] for which compatibility and connectivity are not guaranteed.
554
 
555
 
556
@c
557
@c  rot_rdq
558
@c
559
 
560
@page
561
@subsection rot_rdq - Rotate Tasks on the Ready Queue
562
 
563
@subheading CALLING SEQUENCE:
564
 
565
@ifset is-C
566
@example
567
ER rot_rdq(
568
  PRI tskpri
569
);
570
@end example
571
@end ifset
572
 
573
@ifset is-Ada
574
@end ifset
575
 
576
@subheading STATUS CODES:
577
 
578
@code{E_OK} - Normal Completion
579
 
580
@code{E_PAR} - Parameter error (the value of tskpri is invalid)
581
 
582
@subheading DESCRIPTION:
583
This system call rotates tasks on the ready queue associated with the priority level specified by tskpri.  Specifically, the task at the head of the ready queue of the priority level in question is moved to the end of the ready queue, thus switching the execution of tasks having the same priority.  Round robin scheduling may be implemented by periodically issuing this system call in a given period of time.
584
 
585
When rot_rdq is issued by task portions with tskpri = TPRI_RUN = 0, the ready queue with the priority level of the issuing task is rotated.
586
 
587
When TPRI_RUN or a task's own priority level are specified for tskpri to rot_rdq, the task issuing the system call will be placed on the end of its ready queue.  In other words, task can issue rot_rdq to relinquishing its execution privileges.  The concept of "ready queue" envisioned in the description of this system call is one which includes the task in RUN state.
588
 
589
This system call does nothing if there are no tasks on the ready queue of the specified priority.  No error will result.
590
 
591
This system call cannot rotate ready queues on other nodes.
592
 
593
@subheading NOTES:
594
Depending on the implementation, it may be possible to issue rot_rdq(tskpri = TPRI_RUN) from task-independent portions, such as a cyclic handler.  In this case the ready queue including the running task, or the ready queue including the highest priority task, is rotated.  Normally these two are the same, but not always, as when task dispatching is delayed.  In that case it is implementation dependent whether to rotate the ready queue including the running task or the ready queue including the highest priority task.  Note that this is an extended function [Level X] for which compatibility and connectivity are not guaranteed.
595
 
596
 
597
@c
598
@c  rel_wai
599
@c
600
 
601
@page
602
@subsection rel_wai - Release Wait of Other Task
603
 
604
@subheading CALLING SEQUENCE:
605
 
606
@ifset is-C
607
@example
608
ER rel_wai(
609
  ID tskid
610
);
611
@end example
612
@end ifset
613
 
614
@ifset is-Ada
615
@end ifset
616
 
617
@subheading STATUS CODES:
618
 
619
@code{E_OK} - Normal Completion
620
 
621
@code{E_ID} - Invalid ID Number (tskid was invalid or could not be used)
622
 
623
@code{E_NOEXS} - Object does not exist (the task specified by tskid does not exist)
624
 
625
@code{E_OACV} - Object access violation (A tskid less than -4 was specified from a user task.  This is implementation dependent.)
626
 
627
@code{E_OBJ} - Invalid object state (the target task is not in WAIT state (including when it is in DORMANT state or when the issuing task specifies itself))
628
 
629
@code{EN_OBJNO} - An object number which could not be accessed on the target node is specified.
630
 
631
@code{EN_CTXID} - Specified an object on another node when the system call was issued from a task in dispatch disabled state or from a task-independent portion
632
 
633
@subheading DESCRIPTION:
634
This system call forcibly releases WAIT state (not including SUSPEND state)
635
of the task specified by tskid.
636
 
637
An E_RLWAI error is returned to the task whose WAIT state has been released using rel_wai.
638
 
639
Wait release requests by rel_wai are not queued.  In other words, if the task specified by tskid is already in WAIT state, the WAIT state is released, otherwise an E_OBJ error will be returned to the issuer.  An E_OBJ error will also result when a task specifies itself to this system call.
640
 
641
Rel_wai does not release SUSPEND state.  If rel_wai is issued on a task in WAIT-SUSPEND state, WAIT will be released but SUSPEND will continue for that task. When SUSPEND should also be released, the frsm_tsk system call must be issued separately.
642
 
643
@subheading NOTES:
644
A function similar to timeout can be implemented using an alarm handler which issues this system call on tasks specified time after they have entered WAIT state.
645
 
646
Rel_wai and wup_tsk differ in the following points.
647
@itemize @bullet
648
@item Wup_tsk can only release the WAIT state by slp_tsk or tslp_tsk, while rel_wai can release WAIT states caused by these and other calls (including wai_flg, wai_sem, rcv_msg, get_blk, etc.).
649
@item As seen from the target task, releasing WAIT state with wup_tsk results in a normal completion (E_OK), whereas releasing WAIT state with rel_wai results in an error (E_RLWAI).
650
@item When wup_tsk is used, a request is queued even if neither slp_tsk nor tslp_tsk have been executed on the target task yet.  When rel_wai is used to the task which is not in WAIT state, an E_OBJ error will result.
651
@end itemize
652
 
653
 
654
@c
655
@c  get_tid
656
@c
657
 
658
@page
659
@subsection get_tid - Get Task Identifier
660
 
661
@subheading CALLING SEQUENCE:
662
 
663
@ifset is-C
664
@example
665
ER get_tid(
666
  ID *p_tskid
667
);
668
@end example
669
@end ifset
670
 
671
@ifset is-Ada
672
@end ifset
673
 
674
@subheading STATUS CODES:
675
 
676
@code{E_OK} - Normal Completion
677
 
678
@subheading DESCRIPTION:
679
This system call gets the ID of the issuing task.
680
 
681
If this system call is issued from a task-independent portion, tskid will be FALSE=0.
682
 
683
@subheading NOTES:
684
 
685
 
686
@c
687
@c  ref_tsk
688
@c
689
 
690
@page
691
@subsection ref_tsk - Reference Task Status
692
 
693
@subheading CALLING SEQUENCE:
694
 
695
@ifset is-C
696
@example
697
ER ref_tsk(
698
  T_RTSK *pk_rtsk,
699
  ID tskid
700
);
701
@end example
702
@end ifset
703
 
704
@ifset is-Ada
705
@end ifset
706
 
707
@subheading STATUS CODES:
708
 
709
@code{E_OK} - Normal Completion
710
 
711
@code{E_ID} - Invalid ID Number (tskid was invalid or could not be used)
712
 
713
@code{E_NOEXS} - Object does not exist (the task specified by tskid does not exist)
714
 
715
@code{E_OACV} - Object access violation (A tskid less than -4 was specified from a user task.  This is implementation dependent.)
716
 
717
@code{E_PAR} - Parameter error (the packet address for return parameters cannot be used)
718
 
719
@code{EN_OBJNO} -  An object number which could not be accessed on the target node is specified.
720
 
721
@code{EN_CTXID} - Specified an object on another node when the system call was issued from a task in dispatch disabled state or from a task-independent portion
722
 
723
@code{EN_RPAR} - A value outside the range supported by the requesting node and/or transmission packet format was returned as a return parameter (a value outside supported range was returned for exinf, tskpri and/or tskstat)
724
 
725
@subheading DESCRIPTION:
726
This system call refers to the state of the task specified by tskid, and returns its current priority (tskpri), its task state (tskstat), and its extended information (exinf).
727
 
728
Tskstat may take the following values.
729
 
730
    tskstat:
731
@itemize @bullet
732
@item   TTS_RUN H'0...01        RUN state (currently running)
733
@item   TTS_RDY H'0...02        READY state (ready to run)
734
@item   TTS_WAI H'0...04        WAIT state (waiting for something)
735
@item   TTS_SUS H'0...08        SUSPEND state (forcibly made to wait)
736
@item   TTS_WAS H'0...0c        WAIT-SUSPEND state
737
@item   TTS_DMT H'0...10        DORMANT state
738
@end itemize
739
 
740
Since these task states are expressed by bit correspondences they are convenient when looking for OR conditions (such as whether a task is in RUN or READY state).  TTS_WAS is a combination of both TTS_SUS and TTS_WAI, TTS_SUS does not combine with any of the other states (TTS_RUN, TTS_RDY or TTS_DMT).
741
 
742
A task may specify itself by specifying tskid = TSK_SELF = 0.  Note, however, that an E_ID error will result if tskid = TSK_SELF = 0 is specified when this system call is issued from a task-independent portion.
743
 
744
An E_NOEXS error will result if the task specified to ref_tsk does not exist.
745
 
746
Tskstat will be TTS_RUN if ref_tsk is executed specifying a task which has been interrupted by an interrupt handler.
747
 
748
@subheading NOTES:
749
The values of TTS_RUN, TTS_RDY, TTS_WAI, etc. as return values for tskstat are not necessarily the same value to be entered in the TCB.  The way in which task state is represented in the TCB is implementation dependent.  When ref_tsk is executed, the internal representation of task state may simply be converted to the standard values TTS_RUN, TTS_RDY, TTS_WAI, etc.
750
 
751
Depending on the implementation, the following additional information can also be referenced in addition to exinf, tskpri and tskstat.
752
 
753
@itemize @bullet
754
@item tskwait Reason for wait
755
@item wid     Wait object ID
756
@item wupcnt  Number of queued wakeup requests
757
@item suscnt  Number of nested SUSPEND requests
758
@item tskatr  Task attributes
759
@item task    Task starting address
760
@item itskpri Initial task priority
761
@item stksz   Stack size
762
@end itemize
763
 
764
 
765
 
766
 
767
 

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.