2014-02-03 19:37:31 +01:00
|
|
|
/*
|
2015-11-19 15:54:52 +01:00
|
|
|
* Copyright (C) 2013-2015 Freie Universität Berlin
|
2014-02-03 19:37:31 +01:00
|
|
|
*
|
2014-08-27 18:47:31 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2014-02-03 19:37:31 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-11-19 15:54:52 +01:00
|
|
|
* @defgroup drivers_periph Peripheral Driver Interface
|
2014-08-06 15:06:06 +02:00
|
|
|
* @ingroup drivers
|
2015-11-19 15:54:52 +01:00
|
|
|
* @brief Low-level peripheral driver interface for vendor and platform
|
|
|
|
* independent access to MCU peripherals as UART, SPI, etc
|
2014-02-03 19:37:31 +01:00
|
|
|
*
|
2015-11-19 15:54:52 +01:00
|
|
|
* The module contains the low-level peripheral driver interface. This interface
|
|
|
|
* defines a standardized interface to access MCU peripherals that is not tied
|
|
|
|
* to any specific vendor, platform or architecture.
|
|
|
|
*
|
2023-07-04 15:26:01 +02:00
|
|
|
* # Initialization and Thread Safety
|
|
|
|
*
|
|
|
|
* Peripheral drivers fall into three categories regarding to their
|
|
|
|
* initialization:
|
|
|
|
*
|
|
|
|
* 1. Drivers that do not need to be initialized
|
|
|
|
* (e.g. @ref drivers_periph_eeprom)
|
|
|
|
* 2. Drivers that are automatically initialized by the module `periph_init` at boot,
|
|
|
|
* (see @ref drivers_periph_init for details)
|
|
|
|
* 3. Drivers that require manual initialization (e.g. @ref drivers_periph_uart
|
|
|
|
* or @ref drivers_periph_adc)
|
|
|
|
*
|
|
|
|
* The initialization code of drivers initialized at boot up is *not* thread
|
|
|
|
* safe. This code is run sequentially anyway and never called by the user, so
|
|
|
|
* the overhead of thread safety would not be justified.
|
|
|
|
*
|
|
|
|
* All other peripheral APIs (including the initialization functions of drivers
|
|
|
|
* that are not initialized with `periph_init`) are fully or partially thread
|
|
|
|
* safe. Partially thread safe drivers require the user to make sure that the
|
|
|
|
* same peripheral entity (e.g. one UART device) is exclusively used by one
|
|
|
|
* thread. So two threads may concurrently use two *distinct* UART devices
|
|
|
|
* without any synchronization, but they *must* synchronize explicitly to access
|
|
|
|
* the same UART device.
|
|
|
|
*
|
|
|
|
* Fully thread safe are all bus peripherals: A call to e.g. @ref spi_acquire
|
|
|
|
* will start a period of exclusive access to the given SPI bus by the calling
|
|
|
|
* thread until that calls @ref spi_release.
|
|
|
|
*
|
|
|
|
* | Peripheral Driver | Initialized By | Thread Safety |
|
|
|
|
* |:------------------ |:----------------- |:----------------------------------------------------------------------------- |
|
|
|
|
* | `periph_adc` | user / driver | Partial (no concurrent use of the same ADC line allowed) |
|
|
|
|
* | `periph_can` | user / driver | Partial (no concurrent use of the same CAN device allowed) |
|
|
|
|
* | `periph_cpuid` | not needed | Full Thread Safety |
|
|
|
|
* | `periph_dac` | user / driver | Partial (no concurrent use of the same DAC line allowed) |
|
|
|
|
* | `periph_eeprom` | not needed | None (no concurrency whatsoever) |
|
|
|
|
* | `periph_flashpage` | not needed | None (no concurrency whatsoever) |
|
|
|
|
* | `periph_gpio` | not needed | Limited (reads are fine, concurrent writes to pins on distinct ports work) |
|
|
|
|
* | `periph_gpio_ll` | not needed | Yes, except for concurrent initialization of the GPIO pin |
|
|
|
|
* | `periph_hwrng` | `periph_init` | None (no concurrency whatsoever) |
|
|
|
|
* | `periph_i2c` | `periph_init` | Full Thread Safety (except for initialization) |
|
|
|
|
* | `periph_pio` | `periph_init` | Full Thread Safety (except for initialization) |
|
|
|
|
* | `periph_pm` | not needed | Full Thread Safety |
|
|
|
|
* | `periph_ptp` | `periph_init` | Full Thread Safety (except for initialization) |
|
|
|
|
* | `periph_pwm` | user / driver | Partial (no concurrent use of the same PWM device) |
|
|
|
|
* | `periph_qdec` | user / driver | Partial (no concurrent use of the same QDEC device) |
|
|
|
|
* | `periph_rtc` | `periph_init` | None (no concurrency whatsoever) |
|
|
|
|
* | `periph_rtt` | `periph_init` | None (no concurrency whatsoever) |
|
|
|
|
* | `periph_spi` | `periph_init` | Full Thread Safety (except for initialization) |
|
|
|
|
* | `periph_timer` | user / driver | Yes, except for concurrent initialization of the same timer |
|
|
|
|
* | `periph_uart` | user / driver | Partial (no concurrent use of the same UART device allowed) |
|
|
|
|
* | `periph_usbdev` | user / driver (*) | Full Thread Safety (except for initialization) |
|
|
|
|
* | `periph_vbat` | `periph_init` | None (no concurrency whatsoever) |
|
|
|
|
* | `periph_wdt` | `periph_init` | Only `wdt_kick()` is thread-safe |
|
|
|
|
*
|
|
|
|
* @note `periph_usbdev` requires a low level initialization
|
|
|
|
* (@ref usbdev_init_lowlevel) that is done by `periph_init`. A per
|
|
|
|
* device initialization is needed in addition by the user.
|
|
|
|
*
|
2015-11-19 15:54:52 +01:00
|
|
|
* @todo describe concept in detail
|
|
|
|
* @todo link to driver model
|
|
|
|
* @todo describe/link implementation guide
|
|
|
|
* @todo list best practices
|
2014-02-03 19:37:31 +01:00
|
|
|
*/
|