1.. _system_threads_v2:
2
3System Threads
4##############
5
6.. contents::
7    :local:
8    :depth: 2
9
10A :dfn:`system thread` is a thread that the kernel spawns automatically
11during system initialization.
12
13The kernel spawns the following system threads:
14
15**Main thread**
16    This thread performs kernel initialization, then calls the application's
17    :c:func:`main` function (if one is defined).
18
19    By default, the main thread uses the highest configured preemptible thread
20    priority (i.e. 0). If the kernel is not configured to support preemptible
21    threads, the main thread uses the lowest configured cooperative thread
22    priority (i.e. -1).
23
24    The main thread is an essential thread while it is performing kernel
25    initialization or executing the application's :c:func:`main` function;
26    this means a fatal system error is raised if the thread aborts. If
27    :c:func:`main` is not defined, or if it executes and then does a normal
28    return, the main thread terminates normally and no error is raised.
29
30**Idle thread**
31    This thread executes when there is no other work for the system to do.
32    If possible, the idle thread activates the board's power management support
33    to save power; otherwise, the idle thread simply performs a "do nothing"
34    loop. The idle thread remains in existence as long as the system is running
35    and never terminates.
36
37    The idle thread always uses the lowest configured thread priority.
38    If this makes it a cooperative thread, the idle thread repeatedly
39    yields the CPU to allow the application's other threads to run when
40    they need to.
41
42    The idle thread is an essential thread, which means a fatal system error
43    is raised if the thread aborts.
44
45Additional system threads may also be spawned, depending on the kernel
46and board configuration options specified by the application. For example,
47enabling the system workqueue spawns a system thread
48that services the work items submitted to it. (See :ref:`workqueues_v2`.)
49
50Implementation
51**************
52
53Writing a main() function
54=========================
55
56An application-supplied ``main()`` function begins executing once
57kernel initialization is complete. The kernel does not pass any arguments
58to the function, unless ``CONFIG_BOOTARGS`` is selected. In such case the
59kernel passes arguments to it and ``main(int, char **)`` can be used.
60
61The following code outlines a trivial ``main(void)`` function.
62The function used by a real application can be as complex as needed.
63
64.. code-block:: c
65
66    int main(void)
67    {
68        /* initialize a semaphore */
69	...
70
71	/* register an ISR that gives the semaphore */
72	...
73
74	/* monitor the semaphore forever */
75	while (1) {
76	    /* wait for the semaphore to be given by the ISR */
77	    ...
78	    /* do whatever processing is now needed */
79	    ...
80	}
81    }
82
83Suggested Uses
84**************
85
86Use the main thread to perform thread-based processing in an application
87that only requires a single thread, rather than defining an additional
88application-specific thread.
89