Skip to content

Latest commit

 

History

History
216 lines (186 loc) · 11.9 KB

toc.md

File metadata and controls

216 lines (186 loc) · 11.9 KB
layout lang permalink title author date
page
en
/user-manual/
User's manual
Liviu Ionescu
2016-06-28 19:39:00 +0300

Note: The User's Manual is currently work in progress.

RTOS

[Getting started with µOS++]({{ site.baseurl }}/user-manual/getting-started/)

  • [Overview]({{ site.baseurl }}/user-manual/getting-started/#overview)
    • [Multiple APIs]({{ site.baseurl }}/user-manual/getting-started/#multiple-apis)
  • [The os_main() and the main thread]({{ site.baseurl }}/user-manual/getting-started/#the-os_main-and-the-main-thread)
  • [Multiple thread applications]({{ site.baseurl }}/user-manual/getting-started/#multiple-thread-applications)

[Basic concepts]({{ site.baseurl }}/user-manual/basic-concepts/)

  • [Soft vs hard real-time systems]({{ site.baseurl }}/user-manual/basic-concepts/#soft-vs-hard-real-time-systems)
  • [Superloop (foreground/background) applications]({{ site.baseurl }}/user-manual/basic-concepts/#superloop-foregroundbackground-applications)
  • [Multi-tasking]({{ site.baseurl }}/user-manual/basic-concepts/#multi-tasking)
    • [Tasks]({{ site.baseurl }}/user-manual/basic-concepts/#tasks)
    • [Why multiple threads?]({{ site.baseurl }}/user-manual/basic-concepts/#why-multiple-threads)
    • [Threads & processes]({{ site.baseurl }}/user-manual/basic-concepts/#threads-vs-processes)
    • [Blocking I/O]({{ site.baseurl }}/user-manual/basic-concepts/#blocking-io)
    • [The idle thread]({{ site.baseurl }}/user-manual/basic-concepts/#the-idle-thread)
    • [Sleep modes and power savings]({{ site.baseurl }}/user-manual/basic-concepts/#sleep-modes-and-power-savings)
    • [Context switching]({{ site.baseurl }}/user-manual/basic-concepts/#context-switching)
    • [Thread stacks]({{ site.baseurl }}/user-manual/basic-concepts/#thread-stacks)
    • [Cooperative vs preemptive multi-tasking]({{ site.baseurl }}/user-manual/basic-concepts/#cooperative-vs-preemptive-multi-tasking)
    • [Thread interruption/cancellation]({{ site.baseurl }}/user-manual/basic-concepts/#thread-interruptioncancellation)
  • [Scheduling]({{ site.baseurl }}/user-manual/basic-concepts/#scheduling)
    • [Thread states]({{ site.baseurl }}/user-manual/basic-concepts/#thread-states)
    • [The READY list]({{ site.baseurl }}/user-manual/basic-concepts/#the-ready-list)
    • [Scheduling algorithms]({{ site.baseurl }}/user-manual/basic-concepts/#scheduling-algorithms)
    • [Round-robin vs priority scheduling]({{ site.baseurl }}/user-manual/basic-concepts/#round-robin-vs-priority-scheduling)
    • [Selecting thread priorities]({{ site.baseurl }}/user-manual/basic-concepts/#selecting-thread-priorities)
    • [Priority inversion / priority inheritance]({{ site.baseurl }}/user-manual/basic-concepts/#priority-inversion--priority-inheritance)
  • [Communicating between threads and/or ISRs]({{ site.baseurl }}/user-manual/basic-concepts/#communicating-between-threads-andor-isrs)
    • [Periodic polling vs event waiting]({{ site.baseurl }}/user-manual/basic-concepts/#periodic-polling-vs-event-waiting)
    • [Passing messages]({{ site.baseurl }}/user-manual/basic-concepts/#passing-messages)
    • [Event flags]({{ site.baseurl }}/user-manual/basic-concepts/#event-flags)
    • [Semaphores]({{ site.baseurl }}/user-manual/basic-concepts/#semaphores)
  • [Managing common resources]({{ site.baseurl }}/user-manual/basic-concepts/#managing-common-resources)
    • [Disable/enable interrupts]({{ site.baseurl }}/user-manual/basic-concepts/#disableenable-interrupts)
    • [Lock/unlock the scheduler]({{ site.baseurl }}/user-manual/basic-concepts/#lockunlock-the-scheduler)
    • [Counting semaphores]({{ site.baseurl }}/user-manual/basic-concepts/#counting-semaphores)
    • [Mutual exclusion (mutex)]({{ site.baseurl }}/user-manual/basic-concepts/#mutual-exclusion-mutex)
    • [Should a semaphore or a mutex be used?]({{ site.baseurl }}/user-manual/basic-concepts/#should-a-semaphore-or-a-mutex-be-used)
    • [Deadlock (or deadly embrace)]({{ site.baseurl }}/user-manual/basic-concepts/#deadlock-or-deadly-embrace)
  • [Statically vs. dynamically allocated objects]({{ site.baseurl }}/user-manual/basic-concepts/#statically-vs-dynamically-allocated-objects)
    • [The system allocator]({{ site.baseurl }}/user-manual/basic-concepts/#the-system-allocator)
    • [Fragmentation]({{ site.baseurl }}/user-manual/basic-concepts/#fragmentation)
  • [Real-time clock]({{ site.baseurl }}/user-manual/basic-concepts/#real-time-clock)
  • [Terms to use with caution]({{ site.baseurl }}/user-manual/basic-concepts/#terms-to-use-with-caution)
    • [Kernel]({{ site.baseurl }}/user-manual/basic-concepts/#kernel)
    • [Tasks vs threads]({{ site.baseurl }}/user-manual/basic-concepts/#tasks-vs-threads)

[Features]({{ site.baseurl }}/user-manual/features/)

[Threads]({{ site.baseurl }}/user-manual/threads/)

  • [Overview]({{ site.baseurl }}/user-manual/threads/#overview)
  • [Thread functions]({{ site.baseurl }}/user-manual/threads/#thread-functions)
  • [Thread priorities]({{ site.baseurl }}/user-manual/threads/#thread-priorities)
  • [Creating threads]({{ site.baseurl }}/user-manual/threads/#creating-threads)
  • [Changing thread priorities]({{ site.baseurl }}/user-manual/threads/#changing-thread-priorities)
  • [Other thread functions]({{ site.baseurl }}/user-manual/threads/#other-thread-functions)
  • [Destroying threads]({{ site.baseurl }}/user-manual/threads/#destroying-threads)
  • [The current thread]({{ site.baseurl }}/user-manual/threads/#the-current-thread)
  • [Thread states]({{ site.baseurl }}/user-manual/threads/#thread-states)
  • [The thread stack]({{ site.baseurl }}/user-manual/threads/#the-thread-stack)
  • [The idle thread]({{ site.baseurl }}/user-manual/threads/#the-idle-thread)
  • [The main thread]({{ site.baseurl }}/user-manual/threads/#the-main-thread)

[Thread event flags]({{ site.baseurl }}/user-manual/thread-event-flags/)

  • [Overview]({{ site.baseurl }}/user-manual/thread-event-flags/#overview)
  • [Raising thread event flags]({{ site.baseurl }}/user-manual/thread-event-flags/#raising-thread-event-flags)
  • [Waiting for thread event flags]({{ site.baseurl }}/user-manual/thread-event-flags/#waiting-for-thread-event-flags)
  • [Other thread event flags functions]({{ site.baseurl }}/user-manual/thread-event-flags/#other-thread-event-flags-functions)

[Semaphores]({{ site.baseurl }}/user-manual/semaphores/)

  • [Overview]({{ site.baseurl }}/user-manual/semaphores/#overview)
  • [Semaphore types]({{ site.baseurl }}/user-manual/semaphores/#semaphore-types)
    • [Binary semaphores]({{ site.baseurl }}/user-manual/semaphores/#binary-semaphores)
    • [Counting semaphores]({{ site.baseurl }}/user-manual/semaphores/#counting-semaphores)
  • [Creating semaphores]({{ site.baseurl }}/user-manual/semaphores/#creating-semaphores)
  • [Posting to semaphores]({{ site.baseurl }}/user-manual/semaphores/#posting-to-semaphores)
    • [Posting to semaphores from ISRs]({{ site.baseurl }}/user-manual/semaphores/#posting-to-semaphores-from-isrs)
  • [Waiting on semaphores]({{ site.baseurl }}/user-manual/semaphores/#waiting-on-semaphores)
  • [Multiple threads waiting on a semaphore]({{ site.baseurl }}/user-manual/semaphores/#multiple-threads-waiting-on-a-semaphore)
  • [Other semaphore functions]({{ site.baseurl }}/user-manual/semaphores/#other-semaphore-functions)
    • [Getting the semaphore name]({{ site.baseurl }}/user-manual/semaphores/#getting-the-semaphore-name)
    • [Getting the semaphore value]({{ site.baseurl }}/user-manual/semaphores/#getting-the-semaphore-value)
    • [Getting the semaphore maximum value]({{ site.baseurl }}/user-manual/semaphores/#getting-the-semaphore-maximum-value)
    • [Getting the semaphore initial value]({{ site.baseurl }}/user-manual/semaphores/#getting-the-semaphore-initial-value)
  • [Destroying semaphores]({{ site.baseurl }}/user-manual/semaphores/#destroying-semaphores)
  • [Using semaphores for resource management]({{ site.baseurl }}/user-manual/semaphores/#using-semaphores-for-resource-management)
  • [Unilateral rendezvous]({{ site.baseurl }}/user-manual/semaphores/#unilateral-rendezvous)
  • [Semaphore pitfalls]({{ site.baseurl }}/user-manual/semaphores/#semaphore-pitfalls)
    • [Unbalanced wait()/post()]({{ site.baseurl }}/user-manual/semaphores/#unbalanced-waitpost)
    • [Recursive deadlock]({{ site.baseurl }}/user-manual/semaphores/#recursive-deadlock)
    • [Thread-termination deadlock]({{ site.baseurl }}/user-manual/semaphores/#thread-termination-deadlock)
    • [Priority inversion]({{ site.baseurl }}/user-manual/semaphores/#priority-inversion)
    • [Wrong initialisation]({{ site.baseurl }}/user-manual/semaphores/#wrong-initialisation)

[Event flags]({{ site.baseurl }}/user-manual/event-flags/)

  • [Overview]({{ site.baseurl }}/user-manual/event-flags/#overview)
  • [Creating event flags]({{ site.baseurl }}/user-manual/event-flags/#creating-event-flags)
  • [Raising event flags]({{ site.baseurl }}/user-manual/event-flags/#raising-event-flags)
    • [Raising event flags from ISRs]({{ site.baseurl }}/user-manual/event-flags/#raising-event-flags-from-isrs)
  • [Waiting for event flags]({{ site.baseurl }}/user-manual/event-flags/#waiting-for-event-flags)
  • [Multiple threads waiting on event flags]({{ site.baseurl }}/user-manual/event-flags/#multiple-threads-waiting-on-event-flags)
  • [Other event flags functions]({{ site.baseurl }}/user-manual/event-flags/#other-event-flags-functions)
    • [Getting the event flags name]({{ site.baseurl }}/user-manual/event-flags/#getting-the-event-flags-name)
    • [Getting individual flags]({{ site.baseurl }}/user-manual/event-flags/#getting-individual-flags)
    • [Clearing individual flags]({{ site.baseurl }}/user-manual/event-flags/#clearing-individual-flags)
  • [Destroying event flags]({{ site.baseurl }}/user-manual/event-flags/#destroying-event-flags)

[Mutexes]({{ site.baseurl }}/user-manual/mutexes/)

  • [Overview]({{ site.baseurl }}/user-manual/mutexes/#overview)
    • Normal mutexes
    • Recursive mutexes
  • Creating mutexes
  • Acquiring a mutex
  • Releasing a mutex
  • Multiple threads waiting on a mutex
  • Other mutex functions
  • Destroying mutexes
  • Priority inversion
  • Priority inheritance
  • Deadlock (or deadly embrace)

Condition variables

  • Overview
  • TODO

Message queues

  • Overview
  • Queue storage
  • Message priorities
  • Creating queues
  • Sending messages to queues
    • Sending messages from ISRs
  • Receiving messages from queues
  • Other message queue functions
  • Multiple threads waiting on message queues
  • Destroying queues

Fixed size memory pools

  • Overview
  • Pool storage
  • Creating memory pools
  • Getting a memory block
    • Getting a memory block from ISRs
  • Returning a memory block
  • Other memory pools functions
  • Multiple threads waiting on memory pools
  • Destroying memory pools

Software timers

  • Overview
  • Timer functions
  • Creating timers
  • Start a timer
  • Stop a timer
  • Other timer functions
  • Destroying timers

Clocks

  • Overview
  • The system clock
  • The real time clock
  • The high resolution clock

Interrupts & critical sections

  • Overview
  • High/low priority interrupts
  • Interrupt nesting
  • Critical sections
  • Uncritical sections

Memory allocators

  • TODO

The scheduler

  • Scheduling points
  • The ready list
  • The scheduling algorithm
  • Waiting lists
  • The idle thread

Run-time statistics

  • Per-thread number of context switches
  • Per-thread number of CPU clocks used

Iterating threads

Credits

As the saying goes, "Books are written from books, and software from software". As such, this manual too did not appear from nothing, but was influenced by the following manuals:

  • "Using the FreeRTOS Real Time Kernel", by Richard Barry
  • "µC/OC-III The Real-Time Kernel - User's Manual", by Micriµm
  • "embOS & embOS-MPU - Real-Time Operating System - CPU-independent - User & Reference Guide", by SEGGER

Other links:

Many thanks for their impressive work and for providing the inspiration.