From 5c4a9043d19cc457feaec3ce7b4f279dfac530e8 Mon Sep 17 00:00:00 2001 From: Ulf Lilleengen Date: Thu, 9 Dec 2021 10:40:26 +0100 Subject: [PATCH] Update docs --- docs/modules/ROOT/nav.adoc | 8 ++++---- docs/modules/ROOT/pages/examples.adoc | 3 +++ docs/modules/ROOT/pages/hal.adoc | 9 +++++++++ docs/modules/ROOT/pages/index.adoc | 21 ++++++--------------- docs/modules/ROOT/pages/runtime.adoc | 10 +++++++++- docs/modules/ROOT/pages/stm32.adoc | 3 --- docs/modules/ROOT/pages/traits.adoc | 7 ++++++- 7 files changed, 37 insertions(+), 24 deletions(-) create mode 100644 docs/modules/ROOT/pages/examples.adoc create mode 100644 docs/modules/ROOT/pages/hal.adoc delete mode 100644 docs/modules/ROOT/pages/stm32.adoc diff --git a/docs/modules/ROOT/nav.adoc b/docs/modules/ROOT/nav.adoc index 228ead788..dbf9b0bae 100644 --- a/docs/modules/ROOT/nav.adoc +++ b/docs/modules/ROOT/nav.adoc @@ -1,4 +1,4 @@ -* xref:runtime.adoc[Runtime] -* xref:traits.adoc[Traits] -* xref:nrf.adoc[Nordic nRF HAL] -* xref:stm32.adoc[STM32 HAL] +* xref:runtime.adoc[Executor] +* xref:traits.adoc[Async traits] +* xref:hal.adoc[Hardware Interface] +* xref:examples.adoc[Examples] diff --git a/docs/modules/ROOT/pages/examples.adoc b/docs/modules/ROOT/pages/examples.adoc new file mode 100644 index 000000000..198633c77 --- /dev/null +++ b/docs/modules/ROOT/pages/examples.adoc @@ -0,0 +1,3 @@ += Examples + +Embassy provides examples for all HALs supported. You can find them in the `examples/` folder. diff --git a/docs/modules/ROOT/pages/hal.adoc b/docs/modules/ROOT/pages/hal.adoc new file mode 100644 index 000000000..75dd496c9 --- /dev/null +++ b/docs/modules/ROOT/pages/hal.adoc @@ -0,0 +1,9 @@ += Hardware Abstraction Layer (HAL) + +Embassy provides HAL's for several microcontroller families: + +* embassy-nrf for the nRF family of devices from Nordic Semiconductor +* embassy-stm32 for STM32 family of devices from ST Microelectronics +* embassy-rp for Raspberry Pi Pico + +These HALs provide async/await access to most peripherals while also implementing the async traits in Embassy. diff --git a/docs/modules/ROOT/pages/index.adoc b/docs/modules/ROOT/pages/index.adoc index 5bc35ef43..b795a7238 100644 --- a/docs/modules/ROOT/pages/index.adoc +++ b/docs/modules/ROOT/pages/index.adoc @@ -2,23 +2,14 @@ Embassy is a project to make async/await a first-class option for embedded development. -== Traits and types +== What is async? -`embassy` provides a set of traits and types specifically designed for `async` usage. +Software written without async blocks on I/O operations. In a std environment, such as a PC, software handles this problem with threads. When one thread blocks on an I/O operation, another is able to take its place. However, even on a PC, threads are relatively heavy, and therefore some programming languages, such as Go, have implemented a concept called coroutines or 'goroutines' that are much lighter and less-intensive than threads. -* `embassy::io`: `AsyncBufRead`, `AsyncWrite`. Traits for byte-stream IO, essentially `no_std` compatible versions of `futures::io`. -* `embassy::traits::flash`: Flash device trait. -* `embassy::time`: `Clock` and `Alarm` traits. Std-like `Duration` and `Instant`. -* More traits for SPI, I2C, UART async HAL coming soon. +In rust, this concept is implemented as async. async works by transforming each async function into an object called a future. When a future blocks on I/O the future yields, and the scheduler, called an executor, can select a different future to execute. Compared to alternatives such as an RTOS, async can yield better performance and lower power consumption because the executor doesn't have to guess when a future is ready to execute. However, program size may be higher than other alternatives, which may be a problem for certain space-constrained devices with very low memory. On the devices Embassy supports, such as stm32 and nrf, memory is generally large enough to accommodate the modestly-increased program size. -== Executor +== What is Embassy? -The `embassy::executor` module provides an async/await executor designed for embedded usage. +Embassy is an executor and a Hardware Access Layer (HAL). The executor is a scheduler that generally executes a fixed number of tasks, allocated at startup, though more can be added later. The HAL is an API that you can use to access certain blocking functionality, such as USART, UART, I2C, SPI, CAN, and USB. Embassy doesn't provide access to non-blocking functionality, such as GPIO, because non-blocking functionality doesn't require special treatment to work with Embassy. For such functionality, existing HALs are recommended. -* No `alloc`, no heap needed. Task futures are statically allocated. -* No "fixed capacity" data structures, executor works with 1 or 1000 tasks without needing config/tuning. -* Integrated timer queue: sleeping is easy, just do `Timer::after(Duration::from_secs(1)).await;`. -* No busy-loop polling: CPU sleeps when there's no work to do, using interrupts or `WFE/SEV`. -* Efficient polling: a wake will only poll the woken task, not all of them. -* Fair: a task can't monopolize CPU time even if it's constantly being woken. All other tasks get a chance to run before a given task gets polled for the second time. -* Creating multiple executor instances is supported, to run tasks with multiple priority levels. This allows higher-priority tasks to preempt lower-priority tasks. +Embassy also provides a delay trait that can be used to delay a task by a fixed number of microseconds or milliseconds. For less than one microsecond, blocking delays should be used because the cost of context-switching is too high and the executor will be unable to provide accurate timing. diff --git a/docs/modules/ROOT/pages/runtime.adoc b/docs/modules/ROOT/pages/runtime.adoc index 2704f298b..8351fd0d1 100644 --- a/docs/modules/ROOT/pages/runtime.adoc +++ b/docs/modules/ROOT/pages/runtime.adoc @@ -1,3 +1,11 @@ = Embassy runtime -TODO +The Embassy excecutor is an async/await executor designed for embedded usage. + +* No `alloc`, no heap needed. Task futures are statically allocated. +* No "fixed capacity" data structures, executor works with 1 or 1000 tasks without needing config/tuning. +* Integrated timer queue: sleeping is easy, just do `Timer::after(Duration::from_secs(1)).await;`. +* No busy-loop polling: CPU sleeps when there's no work to do, using interrupts or `WFE/SEV`. +* Efficient polling: a wake will only poll the woken task, not all of them. +* Fair: a task can't monopolize CPU time even if it's constantly being woken. All other tasks get a chance to run before a given task gets polled for the second time. +* Creating multiple executor instances is supported, to run tasks with multiple priority levels. This allows higher-priority tasks to preempt lower-priority tasks. diff --git a/docs/modules/ROOT/pages/stm32.adoc b/docs/modules/ROOT/pages/stm32.adoc deleted file mode 100644 index 328f69e2a..000000000 --- a/docs/modules/ROOT/pages/stm32.adoc +++ /dev/null @@ -1,3 +0,0 @@ -= Embassy STM32 HAL - -TODO diff --git a/docs/modules/ROOT/pages/traits.adoc b/docs/modules/ROOT/pages/traits.adoc index 843cc293e..39e714127 100644 --- a/docs/modules/ROOT/pages/traits.adoc +++ b/docs/modules/ROOT/pages/traits.adoc @@ -1,3 +1,8 @@ = Embassy Traits -TODO +Embassy provides a set of traits and types specifically designed for `async` usage. + +* `embassy::io`: `AsyncBufRead`, `AsyncWrite`. Traits for byte-stream IO, essentially `no_std` compatible versions of `futures::io`. +* `embassy::traits::flash`: Flash device trait. +* `embassy::time`: `Clock` and `Alarm` traits. Std-like `Duration` and `Instant`. +* More traits for SPI, I2C, UART async HAL coming soon.