Link Search Menu Expand Document

What are threads?

A thread is an isolated instance that is responsible for the execution of some task. While a microcontroller usually only has 1 CPU, the RTOS is able to have multiple tasks execute (seemingly) simultaneously by exchanging the thread that gets run on the CPU as dictated by the scheduler.

Some key concepts:

  • Stack area: a region of memory used for the thread’s stack. The size can be adjusted as required by the thread’s processing.

thread-stack-size

  • Thread control block: for internal bookkeeping of the thread’s metadata. An instance of the type k_thread.

thread-control-block

  • Entry point function: invoked when the thread is started. Up to 3 argument values can be passed to this function.

thread-entry-point

ARG_UNUSED is needed to indicate that the 3 arguments are not used in our thread function.

  • Scheduling policy: intstructs the kernel’s scheduler how to allocate CPU time to the thread. (This will be covered in Scheduling)
  • Execution mode: can be supervisor or user mode. By default, threads run in supervisor mode and allow access to privileged CPU instructions, the entire memory address space, and peripherals. User mode threads have a reduced set of privileges.

The specifics of how to define a thread will be discussed in the next section

How does Zephyr choose which thread to run?

“Thread is ready” = eligible to be selected as the next running thread.

Following factors can make a thread unready:

  • Thread has not been started
  • Waiting for a kernel object to complete an operation (for example, the thread is taking semaphore that is unavailable)
  • Waiting for a timeout to occur
  • Thread has been suspended
  • Thread has terminated or aborted

The following diagram shows all the possible states a thread can find itself:

thread_states