revert between 56095 -> 55830 in arch
[AROS.git] / arch / .unmaintained / dummy / forbid.c
blob8f51578108176fe4bb25a19e71f3520ed2a6c96a
1 /*
2 Copyright © 1995-2001, The AROS Development Team. All rights reserved.
3 $Id$
4 */
6 #include <exec/execbase.h>
8 /******************************************************************************
10 NAME */
11 #include <proto/exec.h>
13 AROS_LH0(void, Forbid,
15 /* LOCATION */
16 struct ExecBase *, SysBase, 22, Exec)
18 /* FUNCTION
19 Forbid any further taskswitches until a matching call to Permit().
20 Naturally disabling taskswitches means:
22 THIS CALL IS DANGEROUS
24 Do not use it without thinking very well about it or better do not
25 use it at all. Most of the time you can live without it by using
26 semaphores or similar.
28 Calls to Forbid() nest, i.e. for each call to Forbid() you need one
29 call to Enable().
31 INPUTS
32 None.
34 RESULT
35 None.
37 NOTES
38 To prevent deadlocks calling Wait() in forbidden state breaks the
39 forbid - thus taskswitches may happen again.
41 This function preserves all registers.
43 EXAMPLE
45 BUGS
47 SEE ALSO
48 Permit(), Disable(), Enable(), Wait()
50 INTERNALS
52 HISTORY
54 ******************************************************************************/
56 ++SysBase->TDNestCnt;
57 } /* Forbid */