mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
19943: cpu/stm32: FMC used for low-level LCD parallel interface r=maribu a=gschorcht ### Contribution description This PR provides the implementation of the LCD low-level MCU 8080 parallel interface using the FMC peripheral. ### Testing procedure ``` BOARD=stm32f723e-disco make -C tests/drivers/st77xx flash ``` and ``` BOARD=stm32l496g-disco make -C tests/drivers/st77xx flash ``` should work on top of PR #19941. Drawing operations should be much faster. ### Issues/PRs references Depends on PR #19941 19978: treewide: fix typos to make codespell happy r=maribu a=maribu ### Contribution description - fixes typos in comments and docs (no generated firmware changes expected) - fixes a typo in a string in a GUI of a utility program - add some false positives to the ignore list ### Testing procedure - No generated binaries (except for the GUI version of the utility program to flash the MSB-A2) should change - The diff should not look too scary ### Issues/PRs references None Co-authored-by: Gunar Schorcht <gunar@schorcht.net> Co-authored-by: Marian Buschsieweke <marian.buschsieweke@posteo.net>
This commit is contained in:
commit
554efb7040
@ -257,7 +257,7 @@ Wrong:
|
|||||||
functionality.
|
functionality.
|
||||||
* Every function must be documented - including parameters and return value.
|
* Every function must be documented - including parameters and return value.
|
||||||
|
|
||||||
An examplary doxygen documentation in a header file can look like this.
|
An exemplary doxygen documentation in a header file can look like this.
|
||||||
|
|
||||||
```
|
```
|
||||||
/*
|
/*
|
||||||
|
@ -82,7 +82,7 @@ SUBSYSTEMS=="usb", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="3748", \
|
|||||||
# If you share your linux system with other users, or just don't like the
|
# If you share your linux system with other users, or just don't like the
|
||||||
# idea of write permission for everybody, you can replace MODE:="0666" with
|
# idea of write permission for everybody, you can replace MODE:="0666" with
|
||||||
# OWNER:="yourusername" to create the device owned by you, or with
|
# OWNER:="yourusername" to create the device owned by you, or with
|
||||||
# GROUP:="somegroupname" and mange access using standard unix groups.
|
# GROUP:="somegroupname" and manage access using standard unix groups.
|
||||||
|
|
||||||
> sudo cp 49-stlinkv2.rules /etc/udev/rules.d/
|
> sudo cp 49-stlinkv2.rules /etc/udev/rules.d/
|
||||||
> sudo udevadm control --reload-rules
|
> sudo udevadm control --reload-rules
|
||||||
|
@ -55,7 +55,7 @@ See also the ARMmbed
|
|||||||
[instructions](https://developer.mbed.org/platforms/FRDM-K64F/#getting-started-
|
[instructions](https://developer.mbed.org/platforms/FRDM-K64F/#getting-started-
|
||||||
with-mbed).
|
with-mbed).
|
||||||
|
|
||||||
## Updating the Booloader
|
## Updating the Bootloader
|
||||||
A update of CMSIS-DAP firmware is necessary to using the board with OpenOCD.
|
A update of CMSIS-DAP firmware is necessary to using the board with OpenOCD.
|
||||||
A good step by step guide is available
|
A good step by step guide is available
|
||||||
[here](https://developer.mbed.org/handbook/Firmware-FRDM-K64F).
|
[here](https://developer.mbed.org/handbook/Firmware-FRDM-K64F).
|
||||||
|
@ -76,7 +76,7 @@ b <breakpoint>
|
|||||||
c
|
c
|
||||||
```
|
```
|
||||||
For best debugging experience also change the `-Os` flag in
|
For best debugging experience also change the `-Os` flag in
|
||||||
`Makefile.inlcude`'s `CFLAGS` variable to `-O0`.
|
`Makefile.include`'s `CFLAGS` variable to `-O0`.
|
||||||
|
|
||||||
## Details
|
## Details
|
||||||
The M3 Open Node can reset, debug and program the STM32 on JTAG through the
|
The M3 Open Node can reset, debug and program the STM32 on JTAG through the
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
|
|
||||||
This board is a waterproof board with a LoRa SX1276 radio.
|
This board is a waterproof board with a LoRa SX1276 radio.
|
||||||
|
|
||||||
![LSN50](https://wiki.dragino.com/images/thumb/e/e9/Introdution.png/600px-Introdution.png)
|
![LSN50](https://docs.zephyrproject.org/latest/_images/dragino_lsn50.jpg)
|
||||||
|
|
||||||
Documentation of the board is available
|
Documentation of the board is available
|
||||||
[here](https://wiki.dragino.com/index.php?title=Lora_Sensor_Node-LSN50).
|
[here](https://wiki.dragino.com/index.php?title=Lora_Sensor_Node-LSN50).
|
||||||
|
@ -52,7 +52,7 @@ SUBSYSTEMS=="usb", ATTRS{idVendor}=="1d50", ATTRS{idProduct}=="607f", \
|
|||||||
# If you share your linux system with other users, or just don't like the
|
# If you share your linux system with other users, or just don't like the
|
||||||
# idea of write permission for everybody, you can replace MODE:="0666" with
|
# idea of write permission for everybody, you can replace MODE:="0666" with
|
||||||
# OWNER:="yourusername" to create the device owned by you, or with
|
# OWNER:="yourusername" to create the device owned by you, or with
|
||||||
# GROUP:="somegroupname" and mange access using standard unix groups.
|
# GROUP:="somegroupname" and manage access using standard unix groups.
|
||||||
|
|
||||||
sudo cp 50-openmoko.rules /etc/udev/rules.d/
|
sudo cp 50-openmoko.rules /etc/udev/rules.d/
|
||||||
sudo udevadm control --reload-rules
|
sudo udevadm control --reload-rules
|
||||||
|
@ -39,6 +39,7 @@ config BOARD_STM32F723E_DISCO
|
|||||||
select HAVE_FT5X06
|
select HAVE_FT5X06
|
||||||
select HAVE_ST7789
|
select HAVE_ST7789
|
||||||
select HAVE_LCD_PARALLEL_16BIT if MODULE_ST7789
|
select HAVE_LCD_PARALLEL_16BIT if MODULE_ST7789
|
||||||
|
select HAVE_LCD_PARALLEL_LL_MCU if MODULE_ST7789
|
||||||
|
|
||||||
select MODULE_PERIPH_UART_HW_FC if HAS_PERIPH_UART_HW_FC && MODULE_PERIPH_UART
|
select MODULE_PERIPH_UART_HW_FC if HAS_PERIPH_UART_HW_FC && MODULE_PERIPH_UART
|
||||||
# Workaround due to stdout only working with stdin enabled
|
# Workaround due to stdout only working with stdin enabled
|
||||||
|
@ -25,6 +25,8 @@ endif
|
|||||||
|
|
||||||
ifneq (,$(filter st7789,$(USEMODULE)))
|
ifneq (,$(filter st7789,$(USEMODULE)))
|
||||||
USEMODULE += lcd_parallel_16bit
|
USEMODULE += lcd_parallel_16bit
|
||||||
|
USEMODULE += lcd_parallel_ll_mcu
|
||||||
|
FEATURES_REQUIRED += periph_fmc_nor_sram
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# TODO: remove the stdin dependency
|
# TODO: remove the stdin dependency
|
||||||
|
@ -42,6 +42,7 @@
|
|||||||
#else
|
#else
|
||||||
#include "cfg_usb_otg_fs.h"
|
#include "cfg_usb_otg_fs.h"
|
||||||
#endif
|
#endif
|
||||||
|
#include "lcd_fmc.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@ -325,6 +326,29 @@ static const fmc_bank_conf_t fmc_bank_config[] = {
|
|||||||
.bus_turnaround = 3, }, /* 3 HCLKs a 4.63 ns */
|
.bus_turnaround = 3, }, /* 3 HCLKs a 4.63 ns */
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
/* bank 1, subbank 2 is used for LCD with asynchronuous
|
||||||
|
* access in Mode 1, i.e. write timings are not used */
|
||||||
|
{
|
||||||
|
.bank = FMC_BANK_1,
|
||||||
|
.mem_type = FMC_SRAM,
|
||||||
|
.data_width = FMC_BUS_WIDTH_16BIT,
|
||||||
|
.address = 0x64000000, /* Bank 1, subbank 2 is mapped to 0x64000000 */
|
||||||
|
.size = 4, /* 1 word for command @ 0x64000000 and
|
||||||
|
1 word for data @ 0x64000001 */
|
||||||
|
.nor_sram = {
|
||||||
|
.sub_bank = 2,
|
||||||
|
.ext_mode = false, /* Mode 1 used, no separate w_timing */
|
||||||
|
/* timing requirements for ST7789H2:
|
||||||
|
- t_AST min 0 ns (Address setup time)
|
||||||
|
- t_DST min 10 ns (Data setup time)
|
||||||
|
- t_WRL min 15 ns (WE LOW time)
|
||||||
|
- t_WRH min 15 ns (WE HIGH time)
|
||||||
|
- t_WRC min 66 ns (WE cycle time) */
|
||||||
|
.r_timing = { .addr_setup = 2, /* t_AST = 10 ns (2 HCLKs a 4.63 ns) */
|
||||||
|
.data_setup = 8, /* t_DST = 37 ns (8 HCLKs a 4.63 ns) */
|
||||||
|
.bus_turnaround = 5, }, /* t_WRH = 23 ns (5 HCLKs a 4.63 ns) */
|
||||||
|
},
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -333,6 +357,25 @@ static const fmc_bank_conf_t fmc_bank_config[] = {
|
|||||||
#define FMC_BANK_NUMOF ARRAY_SIZE(fmc_bank_config)
|
#define FMC_BANK_NUMOF ARRAY_SIZE(fmc_bank_config)
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Descriptors of FMC banks used for LCDs
|
||||||
|
*/
|
||||||
|
static const lcd_fmc_desc_t lcd_fmc_desc[] = {
|
||||||
|
{
|
||||||
|
.bank = FMC_BANK_CONFIG(1), /* second bank (fmc_bank_config[1]) is used */
|
||||||
|
.cmd_offset = 0x0, /* address 0x64000000 (offset 0x0) used for commands */
|
||||||
|
.data_offset = 0x2, /* address 0x64000002 (offset 0x2) used for commands */
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Number of LCDs using FMC banks
|
||||||
|
*
|
||||||
|
* Because it is used by the preprocessor it has to be a number.
|
||||||
|
* The @ref ARRAY_SIZE can't be used here.
|
||||||
|
*/
|
||||||
|
#define LCD_FMC_NUMOF 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -45,6 +45,7 @@ config BOARD_STM32L496G_DISCO
|
|||||||
select HAVE_FT5X06
|
select HAVE_FT5X06
|
||||||
select HAVE_ST7789
|
select HAVE_ST7789
|
||||||
select HAVE_LCD_PARALLEL_16BIT if MODULE_ST7789
|
select HAVE_LCD_PARALLEL_16BIT if MODULE_ST7789
|
||||||
|
select HAVE_LCD_PARALLEL_LL_MCU if MODULE_ST7789
|
||||||
|
|
||||||
select MODULE_PERIPH_LPUART if MODULE_PERIPH_UART
|
select MODULE_PERIPH_LPUART if MODULE_PERIPH_UART
|
||||||
select MODULE_PERIPH_UART_HW_FC if MODULE_PERIPH_UART && !MODULE_PERIPH_SPI_STMOD && HAS_PERIPH_UART_HW_FC
|
select MODULE_PERIPH_UART_HW_FC if MODULE_PERIPH_UART && !MODULE_PERIPH_SPI_STMOD && HAS_PERIPH_UART_HW_FC
|
||||||
|
@ -28,4 +28,6 @@ endif
|
|||||||
|
|
||||||
ifneq (,$(filter st7789,$(USEMODULE)))
|
ifneq (,$(filter st7789,$(USEMODULE)))
|
||||||
USEMODULE += lcd_parallel_16bit
|
USEMODULE += lcd_parallel_16bit
|
||||||
|
USEMODULE += lcd_parallel_ll_mcu
|
||||||
|
FEATURES_REQUIRED += periph_fmc_nor_sram
|
||||||
endif
|
endif
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include "clk_conf.h"
|
#include "clk_conf.h"
|
||||||
#include "cfg_rtt_default.h"
|
#include "cfg_rtt_default.h"
|
||||||
#include "cfg_usb_otg_fs.h"
|
#include "cfg_usb_otg_fs.h"
|
||||||
|
#include "lcd_fmc.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@ -253,12 +254,55 @@ static const fmc_bank_conf_t fmc_bank_config[] = {
|
|||||||
.bus_turnaround = 1, }, /* 1 HCLK a 12.5 ns */
|
.bus_turnaround = 1, }, /* 1 HCLK a 12.5 ns */
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
/* bank 1, subbank 1 is used for LCD with asynchronuous
|
||||||
|
* access in Mode 1, i.e. write timings are not used */
|
||||||
|
{
|
||||||
|
.bank = FMC_BANK_1,
|
||||||
|
.mem_type = FMC_SRAM,
|
||||||
|
.data_width = FMC_BUS_WIDTH_16BIT,
|
||||||
|
.address = 0x60000000, /* Bank 1, subbank 1 is mapped to 0x60000000 */
|
||||||
|
.size = 2, /* 1 word for command @ 0x60000000 and
|
||||||
|
1 word for data @ 0x60080000 */
|
||||||
|
.nor_sram = {
|
||||||
|
.sub_bank = 1,
|
||||||
|
.ext_mode = false, /* Mode 1 used, no separate w_timing */
|
||||||
|
/* timing requirements for ST7789H2:
|
||||||
|
- t_AST min 0 ns (Address setup time)
|
||||||
|
- t_DST min 10 ns (Data setup time)
|
||||||
|
- t_WRL min 15 ns (WE LOW time)
|
||||||
|
- t_WRH min 15 ns (WE HIGH time)
|
||||||
|
- t_WRC min 66 ns (WE cycle time) */
|
||||||
|
.r_timing = { .addr_setup = 1, /* t_AST = 12 ns (1 HCLKs a 12.5 ns) */
|
||||||
|
.data_setup = 3, /* t_DST = 37 ns (3 HCLKs a 12.5 ns) */
|
||||||
|
.bus_turnaround = 2, }, /* t_WRH = 25 ns (2 HCLKs a 12.5 ns) */
|
||||||
|
},
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Number of configured FMC banks
|
* @brief Number of configured FMC banks
|
||||||
*/
|
*/
|
||||||
#define FMC_BANK_NUMOF ARRAY_SIZE(fmc_bank_config)
|
#define FMC_BANK_NUMOF ARRAY_SIZE(fmc_bank_config)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Descriptors of FMC banks used for LCDs
|
||||||
|
*/
|
||||||
|
static const lcd_fmc_desc_t lcd_fmc_desc[] = {
|
||||||
|
{
|
||||||
|
.bank = FMC_BANK_CONFIG(1), /* second bank (fmc_bank_config[1]) is used */
|
||||||
|
.cmd_offset = 0x0, /* address 0x60000000 (offset 0x00000) used for commands */
|
||||||
|
.data_offset = 0x80000, /* address 0x60080000 (offset 0x80000) used for data */
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Number of LCDs using FMC banks
|
||||||
|
*
|
||||||
|
* Because it is used by the preprocessor it has to be a number.
|
||||||
|
* The @ref ARRAY_SIZE can't be used here.
|
||||||
|
*/
|
||||||
|
#define LCD_FMC_NUMOF 1
|
||||||
|
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -392,7 +392,7 @@ void mutex_unlock_and_sleep(mutex_t *mutex);
|
|||||||
* @ref mutex_lock_cancelable. (You can reinitialize the same memory
|
* @ref mutex_lock_cancelable. (You can reinitialize the same memory
|
||||||
* to safely reuse it.)
|
* to safely reuse it.)
|
||||||
* @warning You ***MUST NOT*** call this function once the thread referred to by
|
* @warning You ***MUST NOT*** call this function once the thread referred to by
|
||||||
* @p mc re-uses the mutex object referred to by @p mc (not counting
|
* @p mc reuses the mutex object referred to by @p mc (not counting
|
||||||
* the call to @ref mutex_lock_cancelable @p mc was used in).
|
* the call to @ref mutex_lock_cancelable @p mc was used in).
|
||||||
* @note It is safe to call this function from IRQ context, e.g. from a timer
|
* @note It is safe to call this function from IRQ context, e.g. from a timer
|
||||||
* interrupt.
|
* interrupt.
|
||||||
|
@ -216,7 +216,7 @@ static int _msg_send_oneway(msg_t *m, kernel_pid_t target_pid)
|
|||||||
|
|
||||||
sched_set_status(target, STATUS_PENDING);
|
sched_set_status(target, STATUS_PENDING);
|
||||||
|
|
||||||
/* Interrupts are disabled here, we can set / re-use
|
/* Interrupts are disabled here, we can set / reuse
|
||||||
sched_context_switch_request. */
|
sched_context_switch_request. */
|
||||||
sched_context_switch_request = 1;
|
sched_context_switch_request = 1;
|
||||||
|
|
||||||
@ -280,7 +280,7 @@ int msg_send_receive(msg_t *m, msg_t *reply, kernel_pid_t target_pid)
|
|||||||
sched_set_status(me, STATUS_REPLY_BLOCKED);
|
sched_set_status(me, STATUS_REPLY_BLOCKED);
|
||||||
me->wait_data = reply;
|
me->wait_data = reply;
|
||||||
|
|
||||||
/* we re-use (abuse) reply for sending, because wait_data might be
|
/* we reuse (abuse) reply for sending, because wait_data might be
|
||||||
* overwritten if the target is not in RECEIVE_BLOCKED */
|
* overwritten if the target is not in RECEIVE_BLOCKED */
|
||||||
*reply = *m;
|
*reply = *m;
|
||||||
/* msg_send blocks until reply received */
|
/* msg_send blocks until reply received */
|
||||||
|
@ -37,7 +37,7 @@ int adc_init(adc_t line)
|
|||||||
{
|
{
|
||||||
CHECK_PARAM_RET (line < ADC_NUMOF, -1)
|
CHECK_PARAM_RET (line < ADC_NUMOF, -1)
|
||||||
|
|
||||||
/* no special inialization needed */
|
/* no special initialization needed */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -88,7 +88,7 @@ following configuration parameters have to be defined:
|
|||||||
Parameter | Default | Description
|
Parameter | Default | Description
|
||||||
:------------------|:----------|:------------
|
:------------------|:----------|:------------
|
||||||
WIFI_SSID | "RIOT_AP" | SSID of the AP to be used.
|
WIFI_SSID | "RIOT_AP" | SSID of the AP to be used.
|
||||||
WIFI_EAP_ID | none | Optional anonymous identity used in phase 1 (outer) EAP authentication. If it is not defined, the user name defined for phase 2 (inner) EAP authentication is used as idendity in phase 1.
|
WIFI_EAP_ID | none | Optional anonymous identity used in phase 1 (outer) EAP authentication. If it is not defined, the user name defined for phase 2 (inner) EAP authentication is used as identity in phase 1.
|
||||||
WIFI_EAP_USER | none | User name used in phase 2 (inner) EAP authentication.
|
WIFI_EAP_USER | none | User name used in phase 2 (inner) EAP authentication.
|
||||||
WIFI_EAP_PASS | none | Password used in phase 2 (inner) EAP authentication.
|
WIFI_EAP_PASS | none | Password used in phase 2 (inner) EAP authentication.
|
||||||
ESP_WIFI_STACKSIZE | #THREAD_STACKSIZE_DEFAULT | Stack size used for the WiFi netdev driver thread.
|
ESP_WIFI_STACKSIZE | #THREAD_STACKSIZE_DEFAULT | Stack size used for the WiFi netdev driver thread.
|
||||||
|
@ -566,7 +566,7 @@ void isr_radio(void)
|
|||||||
case STATE_ACK:
|
case STATE_ACK:
|
||||||
_state = STATE_IDLE;
|
_state = STATE_IDLE;
|
||||||
|
|
||||||
/* We disable the radio to avoid unwanted emmissions (see ERRATA
|
/* We disable the radio to avoid unwanted emissions (see ERRATA
|
||||||
* ID 204, "Switching between TX and RX causes unwanted emissions")
|
* ID 204, "Switching between TX and RX causes unwanted emissions")
|
||||||
*/
|
*/
|
||||||
_disable();
|
_disable();
|
||||||
|
@ -310,7 +310,7 @@ unsigned int timer_read(tim_t tim)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* request syncronisation */
|
/* request synchronisation */
|
||||||
#ifdef TC_CTRLBSET_CMD_READSYNC_Val
|
#ifdef TC_CTRLBSET_CMD_READSYNC_Val
|
||||||
dev(tim)->CTRLBSET.reg = TC_CTRLBSET_CMD_READSYNC;
|
dev(tim)->CTRLBSET.reg = TC_CTRLBSET_CMD_READSYNC;
|
||||||
/* work around a possible hardware bug where it takes some
|
/* work around a possible hardware bug where it takes some
|
||||||
|
@ -1038,7 +1038,7 @@ static bool sdio_test_type(sdhc_state_t *state)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Wait card ready
|
* Wait card ready
|
||||||
* Timeout 1s = 400KHz / ((6+4)*8) cylces = 5000 retry
|
* Timeout 1s = 400KHz / ((6+4)*8) cycles = 5000 retry
|
||||||
* 6 = cmd byte size
|
* 6 = cmd byte size
|
||||||
* 4(SPI) 6(MCI) = response byte size
|
* 4(SPI) 6(MCI) = response byte size
|
||||||
*/
|
*/
|
||||||
|
@ -78,6 +78,7 @@ rsource "periph/Kconfig.fmc"
|
|||||||
|
|
||||||
if TEST_KCONFIG
|
if TEST_KCONFIG
|
||||||
|
|
||||||
|
rsource "lcd_fmc/Kconfig"
|
||||||
rsource "periph/Kconfig"
|
rsource "periph/Kconfig"
|
||||||
rsource "stmclk/Kconfig"
|
rsource "stmclk/Kconfig"
|
||||||
rsource "vectors/Kconfig"
|
rsource "vectors/Kconfig"
|
||||||
|
@ -6,4 +6,8 @@ ifneq (,$(filter bootloader_stm32,$(USEMODULE)))
|
|||||||
DIRS += bootloader
|
DIRS += bootloader
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifneq (,$(filter lcd_fmc,$(USEMODULE)))
|
||||||
|
DIRS += lcd_fmc
|
||||||
|
endif
|
||||||
|
|
||||||
include $(RIOTBASE)/Makefile.base
|
include $(RIOTBASE)/Makefile.base
|
||||||
|
@ -54,6 +54,10 @@ ifneq (,$(filter stm32_eth,$(USEMODULE)))
|
|||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifneq (,$(filter lcd_parallel_ll_mcu,$(USEMODULE)))
|
||||||
|
USEMODULE += lcd_fmc
|
||||||
|
endif
|
||||||
|
|
||||||
ifneq (,$(filter periph_can,$(FEATURES_USED)))
|
ifneq (,$(filter periph_can,$(FEATURES_USED)))
|
||||||
FEATURES_REQUIRED += periph_gpio
|
FEATURES_REQUIRED += periph_gpio
|
||||||
FEATURES_REQUIRED += periph_gpio_irq
|
FEATURES_REQUIRED += periph_gpio_irq
|
||||||
|
@ -219,7 +219,7 @@ static inline uint32_t _multi_read_reg32(volatile uint32_t *addr, bool *glitch)
|
|||||||
* Think of this as a STM32-specific version of the Rowhammer attack.
|
* Think of this as a STM32-specific version of the Rowhammer attack.
|
||||||
*
|
*
|
||||||
* RDP may not be set correctly due to manufacturing error, glitch or
|
* RDP may not be set correctly due to manufacturing error, glitch or
|
||||||
* intentional attack. It's done thrice to reduce the probablility of a
|
* intentional attack. It's done thrice to reduce the probability of a
|
||||||
* glitch attack succeeding amongst all of the multireads desgned to make it
|
* glitch attack succeeding amongst all of the multireads desgned to make it
|
||||||
* tougher.
|
* tougher.
|
||||||
*
|
*
|
||||||
|
60
cpu/stm32/include/lcd_fmc.h
Normal file
60
cpu/stm32/include/lcd_fmc.h
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2023 Gunar Schorcht
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @defgroup cpu_stm32_lcd_fmc STM32 FMC/FSMC LCD low-level parallel interface driver
|
||||||
|
* @ingroup cpu_stm32
|
||||||
|
*
|
||||||
|
* @{
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef LCD_FMC_H
|
||||||
|
#define LCD_FMC_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Number of LCDs using FMC banks
|
||||||
|
*
|
||||||
|
* It represents the number of elements in LCD FMC bank descriptor array of
|
||||||
|
* type @ref lcd_fmc_desc_t. Because it is used by the preprocessor, it has
|
||||||
|
* to be defined as a number. It is not possible to use the @ref ARRAY_SIZE
|
||||||
|
* macro here.
|
||||||
|
*
|
||||||
|
* @note `LCD_FMC_NUMOF` has to be equal to the number of elements in the
|
||||||
|
* LCD FMC bank descriptor array of type @ref lcd_fmc_desc_t.
|
||||||
|
*/
|
||||||
|
#if DOXYGEN
|
||||||
|
#define LCD_FMC_NUMOF 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Descriptor of the FMC bank used for a LCD
|
||||||
|
*
|
||||||
|
* The board definition has to specify the array @ref lcd_fmc_desc of type
|
||||||
|
* @ref lcd_fmc_desc_t which defines the FMC banks and the address offsets used
|
||||||
|
* for the LCD displays that are connected to FMC banks.
|
||||||
|
*
|
||||||
|
* @note In the case that multiple LCDs are connected to FMC banks, the FMC
|
||||||
|
* bank descriptors for LCDs of type @ref lcd_fmc_desc_t
|
||||||
|
* must be defined in same order as the LCD devices.
|
||||||
|
*/
|
||||||
|
typedef struct {
|
||||||
|
const fmc_bank_conf_t *bank; /**< FMC bank config used for the LCD */
|
||||||
|
uint32_t cmd_offset; /**< offset to the bank address used for commands */
|
||||||
|
uint32_t data_offset; /**< offset to the bank address used for data */
|
||||||
|
} lcd_fmc_desc_t;
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LCD_FMC_H */
|
||||||
|
/** @} */
|
@ -64,6 +64,17 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Gives the configuration of n-th bank
|
||||||
|
*
|
||||||
|
* This macro gives a pointer to the n-th entry of type @ref fmc_bank_conf_t of
|
||||||
|
* the banks configured by the board in the @ref fmc_bank_config array. n is in
|
||||||
|
* the range 0 ... @ref FMC_BANK_NUMOF - 1.
|
||||||
|
*/
|
||||||
|
#ifndef FMC_BANK_CONFIG
|
||||||
|
#define FMC_BANK_CONFIG(n) (&fmc_bank_config[n])
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Number of data pins used
|
* @brief Number of data pins used
|
||||||
*
|
*
|
||||||
|
13
cpu/stm32/lcd_fmc/Kconfig
Normal file
13
cpu/stm32/lcd_fmc/Kconfig
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
# Copyright (c) 2023 Gunar Schorcht
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
#
|
||||||
|
|
||||||
|
config MODULE_LCD_FMC
|
||||||
|
bool
|
||||||
|
depends on MODULE_LCD
|
||||||
|
select MODULE_PERIPH_FMC
|
||||||
|
select MODULE_PERIPH_FMC_NOR_SRAM
|
||||||
|
default y if HAVE_LCD_PARALLEL_LL_MCU
|
3
cpu/stm32/lcd_fmc/Makefile
Normal file
3
cpu/stm32/lcd_fmc/Makefile
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
MODULE = lcd_fmc
|
||||||
|
|
||||||
|
include $(RIOTBASE)/Makefile.base
|
176
cpu/stm32/lcd_fmc/lcd_fmc.c
Normal file
176
cpu/stm32/lcd_fmc/lcd_fmc.c
Normal file
@ -0,0 +1,176 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2023 Gunar Schorcht
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ingroup cpu_stm32
|
||||||
|
* @ingroup drivers_periph_fmc
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file
|
||||||
|
* @brief FMC peripheral driver implementation
|
||||||
|
*
|
||||||
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
#include "periph/gpio.h"
|
||||||
|
#include "lcd.h"
|
||||||
|
#include "lcd_internal.h"
|
||||||
|
#include "ztimer.h"
|
||||||
|
|
||||||
|
#define ENABLE_DEBUG 0
|
||||||
|
#include "debug.h"
|
||||||
|
|
||||||
|
#ifndef LCD_FMC_NUMOF
|
||||||
|
#define LCD_FMC_NUMOF 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define FMC_LCD_CMD(d) (*((__IO uint16_t *)(d->bank->address + d->cmd_offset)))
|
||||||
|
#define FMC_LCD_DATA(d) (*((__IO uint16_t *)(d->bank->address + d->data_offset)))
|
||||||
|
|
||||||
|
/* sanity check */
|
||||||
|
static_assert(LCD_FMC_NUMOF == ARRAY_SIZE(lcd_fmc_desc),
|
||||||
|
"LCD_FMC_NUMOF is not equal to the number of elements in lcd_fmc_desc");
|
||||||
|
|
||||||
|
#if LCD_FMC_NUMOF > 1
|
||||||
|
/* In the case that multiple LCDs are connected to FMC banks, an array
|
||||||
|
* for mapping the LCD device pointer to the FMC bank descriptor is used.
|
||||||
|
* This requires that the FMC bank descriptors for LCDs in `lcd_fmc_desc`
|
||||||
|
* are defined in same order as the LCD devices. */
|
||||||
|
static lcd_t *_lcd_fmc_desc_map[LCD_FMC_NUMOF];
|
||||||
|
static uint8_t _lcd_index = 0;
|
||||||
|
|
||||||
|
static inline uint8_t _dev_to_lcd_fmc_desc(lcd_t *dev)
|
||||||
|
{
|
||||||
|
for (uint8_t i = 0; i < LCD_FMC_NUMOF; i++) {
|
||||||
|
if (_lcd_fmc_desc_map[i] == dev) {
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
assert(false);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static void lcd_ll_mcu_init(lcd_t *dev)
|
||||||
|
{
|
||||||
|
#if LCD_FMC_NUMOF > 1
|
||||||
|
/* The FMC bank descriptors for LCDs in `lcd_fmc_desc` must be defined
|
||||||
|
* in same order as the LCD display devices. We suppose that the
|
||||||
|
* LCDs are initialized in that order. */
|
||||||
|
assert(_lcd_index < LCD_FMC_NUMOF);
|
||||||
|
_lcd_fmc_desc_map[_lcd_index++] = dev;
|
||||||
|
#else
|
||||||
|
(void)dev;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
static void lcd_ll_mcu_set_data_dir(lcd_t *dev, bool output)
|
||||||
|
{
|
||||||
|
/* no action needed */
|
||||||
|
(void)dev;
|
||||||
|
(void)output;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void lcd_ll_mcu_cmd_start(lcd_t *dev, uint8_t cmd, bool cont)
|
||||||
|
{
|
||||||
|
DEBUG("[lcd_ll_mcu] write cmd: %02x\n", cmd);
|
||||||
|
|
||||||
|
(void)cont;
|
||||||
|
#if LCD_FMC_NUMOF > 1
|
||||||
|
const lcd_fmc_desc_t *desc = &lcd_fmc_desc[_dev_to_lcd_fmc_desc(dev)];
|
||||||
|
#else
|
||||||
|
(void)dev;
|
||||||
|
const lcd_fmc_desc_t *desc = lcd_fmc_desc;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
FMC_LCD_CMD(desc) = cmd;
|
||||||
|
/* data synchronization barrier seems to be necessary on some STM32 MCUs. */
|
||||||
|
__DSB();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void lcd_ll_mcu_write_byte(lcd_t *dev, bool cont, uint8_t out)
|
||||||
|
{
|
||||||
|
DEBUG("[lcd_ll_mcu] write byte: %02x\n", out);
|
||||||
|
|
||||||
|
(void)cont;
|
||||||
|
#if LCD_FMC_NUMOF > 1
|
||||||
|
const lcd_fmc_desc_t *desc = &lcd_fmc_desc[_dev_to_lcd_fmc_desc(dev)];
|
||||||
|
#else
|
||||||
|
(void)dev;
|
||||||
|
const lcd_fmc_desc_t *desc = lcd_fmc_desc;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
FMC_LCD_DATA(desc) = out;
|
||||||
|
/* data synchronization barrier seems to be necessary on some STM32 MCUs. */
|
||||||
|
__DSB();
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t lcd_ll_mcu_read_byte(lcd_t *dev, bool cont)
|
||||||
|
{
|
||||||
|
(void)cont;
|
||||||
|
#if LCD_FMC_NUMOF > 1
|
||||||
|
const lcd_fmc_desc_t *desc = &lcd_fmc_desc[_dev_to_lcd_fmc_desc(dev)];
|
||||||
|
#else
|
||||||
|
(void)dev;
|
||||||
|
const lcd_fmc_desc_t *desc = lcd_fmc_desc;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
uint8_t in = FMC_LCD_DATA(desc);
|
||||||
|
DEBUG("[lcd_ll_mcu] read byte: %02x\n", in);
|
||||||
|
return in;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if IS_USED(MODULE_LCD_PARALLEL_16BIT)
|
||||||
|
|
||||||
|
static void lcd_ll_mcu_write_word(lcd_t *dev, bool cont, uint16_t out)
|
||||||
|
{
|
||||||
|
DEBUG("[lcd_ll_mcu] write word: %04x\n", out);
|
||||||
|
|
||||||
|
(void)cont;
|
||||||
|
#if LCD_FMC_NUMOF > 1
|
||||||
|
const lcd_fmc_desc_t *desc = &lcd_fmc_desc[_dev_to_lcd_fmc_desc(dev)];
|
||||||
|
#else
|
||||||
|
(void)dev;
|
||||||
|
const lcd_fmc_desc_t *desc = lcd_fmc_desc;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
FMC_LCD_DATA(desc) = out;
|
||||||
|
/* data synchronization barrier seems to be necessary on some STM32 MCUs. */
|
||||||
|
__DSB();
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint16_t lcd_ll_mcu_read_word(lcd_t *dev, bool cont)
|
||||||
|
{
|
||||||
|
(void)cont;
|
||||||
|
#if LCD_FMC_NUMOF > 1
|
||||||
|
const lcd_fmc_desc_t *desc = &lcd_fmc_desc[_dev_to_lcd_fmc_desc(dev)];
|
||||||
|
#else
|
||||||
|
(void)dev;
|
||||||
|
const lcd_fmc_desc_t *desc = lcd_fmc_desc;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
uint16_t in = FMC_LCD_DATA(desc);
|
||||||
|
DEBUG("[lcd_ll_mcu] read word: %04x\n", in);
|
||||||
|
return in;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* MODULE_LCD_PARALLEL_16BIT */
|
||||||
|
|
||||||
|
const lcd_ll_par_driver_t lcd_ll_par_driver = {
|
||||||
|
.init = lcd_ll_mcu_init,
|
||||||
|
.set_data_dir = lcd_ll_mcu_set_data_dir,
|
||||||
|
.cmd_start = lcd_ll_mcu_cmd_start,
|
||||||
|
.write_byte = lcd_ll_mcu_write_byte,
|
||||||
|
.read_byte = lcd_ll_mcu_read_byte,
|
||||||
|
#if IS_USED(MODULE_LCD_PARALLEL_16BIT)
|
||||||
|
.write_word = lcd_ll_mcu_write_word,
|
||||||
|
.read_word = lcd_ll_mcu_read_word,
|
||||||
|
#endif
|
||||||
|
};
|
@ -480,7 +480,7 @@ static int read_frame(can_t *dev, struct can_frame *frame, int mailbox)
|
|||||||
frame->data[j] = (can->sFIFOMailBox[mailbox].RDHR >> ((j - 4) * 8)) & 0xFF;
|
frame->data[j] = (can->sFIFOMailBox[mailbox].RDHR >> ((j - 4) * 8)) & 0xFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* filter number matching the reveived frame */
|
/* filter number matching the received frame */
|
||||||
/* filter = (can->sFIFOMailBox[mailbox].RDTR & CAN_RDT0R_FMI) >> CAN_RDTxR_FMI_SHIFT; */
|
/* filter = (can->sFIFOMailBox[mailbox].RDTR & CAN_RDT0R_FMI) >> CAN_RDTxR_FMI_SHIFT; */
|
||||||
|
|
||||||
/* Release input mailbox */
|
/* Release input mailbox */
|
||||||
|
6
dist/tools/codespell/ignored_words.txt
vendored
6
dist/tools/codespell/ignored_words.txt
vendored
@ -168,3 +168,9 @@ rsource
|
|||||||
|
|
||||||
# SHS (abbreviation for Secure Hash Standard) => SSH, NHS
|
# SHS (abbreviation for Secure Hash Standard) => SSH, NHS
|
||||||
shs
|
shs
|
||||||
|
|
||||||
|
# FRAM (abbreviation for ferroelectric random access memory, a non-volatile memory)
|
||||||
|
fram
|
||||||
|
|
||||||
|
# MIS (mask interrupt register)
|
||||||
|
mis
|
||||||
|
2
dist/tools/lpc2k_pgm/README.txt
vendored
2
dist/tools/lpc2k_pgm/README.txt
vendored
@ -66,7 +66,7 @@ been tested with Linux kernel 2.4.20 and 2.6.8, and should work with
|
|||||||
almost any linux system.
|
almost any linux system.
|
||||||
|
|
||||||
You must have the "xterm" program installed. Nearly all linux
|
You must have the "xterm" program installed. Nearly all linux
|
||||||
distrubtions provide this, and it is often installed by default. If
|
distributions provide this, and it is often installed by default. If
|
||||||
you do not have it, simply install from your linux distribution.
|
you do not have it, simply install from your linux distribution.
|
||||||
|
|
||||||
Your serial port device file (usually /dev/ttyS0 or /dev/ttyS1) must
|
Your serial port device file (usually /dev/ttyS0 or /dev/ttyS1) must
|
||||||
|
2
dist/tools/lpc2k_pgm/src/gui.c
vendored
2
dist/tools/lpc2k_pgm/src/gui.c
vendored
@ -395,7 +395,7 @@ void create_window(int *argc, char ***argv)
|
|||||||
gtk_widget_set_sensitive(reboot_button, TRUE);
|
gtk_widget_set_sensitive(reboot_button, TRUE);
|
||||||
gtk_widget_show(reboot_button);
|
gtk_widget_show(reboot_button);
|
||||||
|
|
||||||
bootloader_button = gtk_button_new_with_label("Booloader");
|
bootloader_button = gtk_button_new_with_label("Bootloader");
|
||||||
gtk_widget_show(bootloader_button);
|
gtk_widget_show(bootloader_button);
|
||||||
|
|
||||||
quit_button = gtk_button_new_with_label("Quit");
|
quit_button = gtk_button_new_with_label("Quit");
|
||||||
|
@ -574,7 +574,7 @@ void at86rf2xx_tx_exec(at86rf2xx_t *dev);
|
|||||||
bool at86rf2xx_cca(at86rf2xx_t *dev);
|
bool at86rf2xx_cca(at86rf2xx_t *dev);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Enable the smart receive tecnology (SRT)
|
* @brief Enable the smart receive technology (SRT)
|
||||||
*
|
*
|
||||||
* The SRT reduces the power consumption during RX listening periods.
|
* The SRT reduces the power consumption during RX listening periods.
|
||||||
*
|
*
|
||||||
@ -584,7 +584,7 @@ bool at86rf2xx_cca(at86rf2xx_t *dev);
|
|||||||
void at86rf2xx_enable_smart_idle(at86rf2xx_t *dev);
|
void at86rf2xx_enable_smart_idle(at86rf2xx_t *dev);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Disable the smart receive tecnology (SRT)
|
* @brief Disable the smart receive technology (SRT)
|
||||||
*
|
*
|
||||||
* @param[in] dev device to use
|
* @param[in] dev device to use
|
||||||
*
|
*
|
||||||
|
@ -281,7 +281,7 @@ int bme680_force_measurement(bme680_t *dev);
|
|||||||
*
|
*
|
||||||
* @param[in,out] dev device descriptor of the sensor
|
* @param[in,out] dev device descriptor of the sensor
|
||||||
*
|
*
|
||||||
* @return duration of one THPG measurement cylce in milliseconds.
|
* @return duration of one THPG measurement cycle in milliseconds.
|
||||||
* @return < 0 on error
|
* @return < 0 on error
|
||||||
*/
|
*/
|
||||||
int bme680_get_duration(bme680_t* dev);
|
int bme680_get_duration(bme680_t* dev);
|
||||||
|
@ -633,7 +633,7 @@
|
|||||||
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
*
|
*
|
||||||
* If module `l3gxxxx_fifo` is used, the corresponding interrupt sources can
|
* If module `l3gxxxx_fifo` is used, the corresponding interrupt sources can
|
||||||
* be testsed.
|
* be tested.
|
||||||
*
|
*
|
||||||
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.c}
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.c}
|
||||||
* l3gxxxx_int_src_t int_src = l3gxxxx_wait_int(&dev);
|
* l3gxxxx_int_src_t int_src = l3gxxxx_wait_int(&dev);
|
||||||
@ -1278,7 +1278,7 @@ typedef struct {
|
|||||||
for threshold comparison */
|
for threshold comparison */
|
||||||
|
|
||||||
bool and_or; /**< Combination of interrupt events (true=AND, false=OR):<br>
|
bool and_or; /**< Combination of interrupt events (true=AND, false=OR):<br>
|
||||||
AND - all enabled axes passed their tresholds<br>
|
AND - all enabled axes passed their thresholds<br>
|
||||||
OR - at least one axis passed its threshold */
|
OR - at least one axis passed its threshold */
|
||||||
bool latch; /**< Latch the interrupt when true until the interrupt
|
bool latch; /**< Latch the interrupt when true until the interrupt
|
||||||
source has been read by function l3gxxxx_wait_int. */
|
source has been read by function l3gxxxx_wait_int. */
|
||||||
|
@ -311,7 +311,7 @@ int nrf24l01p_set_address_width(const nrf24l01p_t *dev, nrf24l01p_aw_t aw);
|
|||||||
*
|
*
|
||||||
* @ note
|
* @ note
|
||||||
* This function sets the payload width for one packet. If the maximum of 32 bytes is
|
* This function sets the payload width for one packet. If the maximum of 32 bytes is
|
||||||
* exeeded, this value is set to 32.
|
* exceeded, this value is set to 32.
|
||||||
*
|
*
|
||||||
* @param[in] dev Transceiver device to use.
|
* @param[in] dev Transceiver device to use.
|
||||||
* @param[in] pipe RX pipe to set the payload width.
|
* @param[in] pipe RX pipe to set the payload width.
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
*
|
*
|
||||||
* 1. The high-level API that implements the SD Host Controller driver and
|
* 1. The high-level API that implements the SD Host Controller driver and
|
||||||
* allows
|
* allows
|
||||||
* - to inititialize and identify different types of cards,
|
* - to initialize and identify different types of cards,
|
||||||
* - to access them either blockwise or bytewise,
|
* - to access them either blockwise or bytewise,
|
||||||
* - to get information about the used card, and
|
* - to get information about the used card, and
|
||||||
* - to send single commands or application specific commands to the card.
|
* - to send single commands or application specific commands to the card.
|
||||||
@ -676,7 +676,7 @@ typedef struct __attribute__((packed)) {
|
|||||||
/**
|
/**
|
||||||
* @brief CSD register structure Version 2.0 and Version 3.0
|
* @brief CSD register structure Version 2.0 and Version 3.0
|
||||||
*
|
*
|
||||||
* A combined format is used vor CSD Version 2.0 and 3.0 to reduce the code
|
* A combined format is used for CSD Version 2.0 and 3.0 to reduce the code
|
||||||
* size. The only difference is the bit length of `C_SIZE`.
|
* size. The only difference is the bit length of `C_SIZE`.
|
||||||
*
|
*
|
||||||
* @see Physical Layer Simplified Specification Version 9.00
|
* @see Physical Layer Simplified Specification Version 9.00
|
||||||
|
@ -81,7 +81,7 @@ int8_t shtcx_init(shtcx_t* const dev, const shtcx_params_t* params);
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Reads all register values from the device.
|
* @brief Reads all register values from the device.
|
||||||
* @details The values as raw data will be saved into reveived.
|
* @details The values as raw data will be saved into received.
|
||||||
*
|
*
|
||||||
* @param[in] dev The I2C device descriptor.
|
* @param[in] dev The I2C device descriptor.
|
||||||
* @param[in] rel_humidity Humidity in centi %.
|
* @param[in] rel_humidity Humidity in centi %.
|
||||||
|
@ -455,7 +455,7 @@ int mpu9x50_set_compass_sample_rate(mpu9x50_t *dev, uint8_t rate)
|
|||||||
/**
|
/**
|
||||||
* Initialize compass
|
* Initialize compass
|
||||||
* Caution: This internal function does not acquire exclusive access to the I2C bus.
|
* Caution: This internal function does not acquire exclusive access to the I2C bus.
|
||||||
* Acquisation and release is supposed to be handled by the calling function.
|
* Acquisition and release is supposed to be handled by the calling function.
|
||||||
*/
|
*/
|
||||||
static int compass_init(mpu9x50_t *dev)
|
static int compass_init(mpu9x50_t *dev)
|
||||||
{
|
{
|
||||||
@ -524,7 +524,7 @@ static int compass_init(mpu9x50_t *dev)
|
|||||||
/**
|
/**
|
||||||
* Configure bypass mode
|
* Configure bypass mode
|
||||||
* Caution: This internal function does not acquire exclusive access to the I2C bus.
|
* Caution: This internal function does not acquire exclusive access to the I2C bus.
|
||||||
* Acquisation and release is supposed to be handled by the calling function.
|
* Acquisition and release is supposed to be handled by the calling function.
|
||||||
*/
|
*/
|
||||||
static void conf_bypass(const mpu9x50_t *dev, uint8_t bypass_enable)
|
static void conf_bypass(const mpu9x50_t *dev, uint8_t bypass_enable)
|
||||||
{
|
{
|
||||||
@ -548,7 +548,7 @@ static void conf_bypass(const mpu9x50_t *dev, uint8_t bypass_enable)
|
|||||||
/**
|
/**
|
||||||
* Configure low pass filter
|
* Configure low pass filter
|
||||||
* Caution: This internal function does not acquire exclusive access to the I2C bus.
|
* Caution: This internal function does not acquire exclusive access to the I2C bus.
|
||||||
* Acquisation and release is supposed to be handled by the calling function.
|
* Acquisition and release is supposed to be handled by the calling function.
|
||||||
*/
|
*/
|
||||||
static void conf_lpf(const mpu9x50_t *dev, uint16_t half_rate)
|
static void conf_lpf(const mpu9x50_t *dev, uint16_t half_rate)
|
||||||
{
|
{
|
||||||
|
@ -64,7 +64,7 @@ void auto_init_sdp3x(void)
|
|||||||
saul_reg_add(&saul_entries[se_ix]);
|
saul_reg_add(&saul_entries[se_ix]);
|
||||||
se_ix++;
|
se_ix++;
|
||||||
|
|
||||||
/* differential presure */
|
/* differential pressure */
|
||||||
saul_entries[se_ix].dev = &sdp3x_devs[i];
|
saul_entries[se_ix].dev = &sdp3x_devs[i];
|
||||||
saul_entries[se_ix].name = sdp3x_saul_info[i].name;
|
saul_entries[se_ix].name = sdp3x_saul_info[i].name;
|
||||||
saul_entries[se_ix].driver = &sdp3x_differential_pressure_saul_driver;
|
saul_entries[se_ix].driver = &sdp3x_differential_pressure_saul_driver;
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# This files contains dependencies for default modules. They are parsed at the
|
# This files contains dependencies for default modules. They are parsed at the
|
||||||
# end of the dependency loop. They MAY inlcude new modules, but this modules
|
# end of the dependency loop. They MAY include new modules, but this modules
|
||||||
# MUST NOT have dependencies themselfs.
|
# MUST NOT have dependencies themselves.
|
||||||
|
|
||||||
ifneq (,$(filter auto_init%,$(USEMODULE)))
|
ifneq (,$(filter auto_init%,$(USEMODULE)))
|
||||||
USEMODULE += preprocessor preprocessor_successor
|
USEMODULE += preprocessor preprocessor_successor
|
||||||
|
@ -61,11 +61,11 @@
|
|||||||
* ==================
|
* ==================
|
||||||
* To enable the Key-Value database, select the `flashdb_kvdb` module.
|
* To enable the Key-Value database, select the `flashdb_kvdb` module.
|
||||||
*
|
*
|
||||||
* For use of the FlashDB API, reffer to the [FlashDB documentation](http://armink.gitee.io/flashdb/#/sample-kvdb-basic).
|
* For use of the FlashDB API, refer to the [FlashDB documentation](http://armink.gitee.io/flashdb/#/sample-kvdb-basic).
|
||||||
*
|
*
|
||||||
* Time series database
|
* Time series database
|
||||||
* ====================
|
* ====================
|
||||||
* To enable the Key-Value database, select the `flashdb_tsdb` module.
|
* To enable the Key-Value database, select the `flashdb_tsdb` module.
|
||||||
*
|
*
|
||||||
* For use of the FlashDB API, reffer to the [FlashDB documentation](http://armink.gitee.io/flashdb/#/sample-tsdb-basic).
|
* For use of the FlashDB API, refer to the [FlashDB documentation](http://armink.gitee.io/flashdb/#/sample-tsdb-basic).
|
||||||
*/
|
*/
|
||||||
|
@ -35,7 +35,7 @@
|
|||||||
* The RIOT port of MicroPython currently resides in a fork at
|
* The RIOT port of MicroPython currently resides in a fork at
|
||||||
* https://github.com/kaspar030/micropython (in branch add_riot_port). It is
|
* https://github.com/kaspar030/micropython (in branch add_riot_port). It is
|
||||||
* based on Micropython's "ports/minimal" with some extra modules enabled.
|
* based on Micropython's "ports/minimal" with some extra modules enabled.
|
||||||
* It re-uses the gc_collect code from ports/unix, which has special support
|
* It reuses the gc_collect code from ports/unix, which has special support
|
||||||
* for i386 and Cortex-M. On other platforms, it uses setjmp() to collect
|
* for i386 and Cortex-M. On other platforms, it uses setjmp() to collect
|
||||||
* registers.
|
* registers.
|
||||||
*
|
*
|
||||||
|
@ -142,7 +142,7 @@ void nimble_riot_init(void)
|
|||||||
while (!ble_hs_synced()) {}
|
while (!ble_hs_synced()) {}
|
||||||
|
|
||||||
/* for reducing code duplication, we read our own address type once here
|
/* for reducing code duplication, we read our own address type once here
|
||||||
* so it can be re-used later on */
|
* so it can be reused later on */
|
||||||
res = ble_hs_util_ensure_addr(0);
|
res = ble_hs_util_ensure_addr(0);
|
||||||
assert(res == 0);
|
assert(res == 0);
|
||||||
res = ble_hs_id_infer_auto(0, &nimble_riot_own_addr_type);
|
res = ble_hs_id_infer_auto(0, &nimble_riot_own_addr_type);
|
||||||
|
@ -43,7 +43,7 @@ typedef enum {
|
|||||||
} nrf_clock_task_t;
|
} nrf_clock_task_t;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Status HF clock acitvation/deactivation in `dcd_nrf52.c`
|
* @brief Status HF clock activation/deactivation in `dcd_nrf52.c`
|
||||||
*
|
*
|
||||||
* The `clock_hfxo_request` and `clock_hfxo_release` functions are used in
|
* The `clock_hfxo_request` and `clock_hfxo_release` functions are used in
|
||||||
* RIOT to enable/disable the HF clock if necessary. Since `hfclk_enable`
|
* RIOT to enable/disable the HF clock if necessary. Since `hfclk_enable`
|
||||||
|
@ -1442,7 +1442,7 @@ Build System / Tooling
|
|||||||
+ .vscode: import initial RIOT-OS style (#18945)
|
+ .vscode: import initial RIOT-OS style (#18945)
|
||||||
+ build-system: add capability to execute scripts with custom executor (#18770)
|
+ build-system: add capability to execute scripts with custom executor (#18770)
|
||||||
+ dist/tools: add "RESET_PIN" value for the dwm1001 (#18815)
|
+ dist/tools: add "RESET_PIN" value for the dwm1001 (#18815)
|
||||||
+ examples/gnrc_border_router: add option to re-use existing TAP
|
+ examples/gnrc_border_router: add option to reuse existing TAP
|
||||||
interface (#18836)
|
interface (#18836)
|
||||||
+ makefiles/tools/serial.inc.mk: add support for bootterm (#18749)
|
+ makefiles/tools/serial.inc.mk: add support for bootterm (#18749)
|
||||||
+ tapsetup: add --loss & --delay option (#18885)
|
+ tapsetup: add --loss & --delay option (#18885)
|
||||||
@ -3633,7 +3633,7 @@ Packages
|
|||||||
* pkg/littlefs2: bump version to 2.4.2 (#17837)
|
* pkg/littlefs2: bump version to 2.4.2 (#17837)
|
||||||
* pkg/lv_drivers: initial commit (#17713)
|
* pkg/lv_drivers: initial commit (#17713)
|
||||||
* pkg/lvgl: bump to 8.2.0 (#17681)
|
* pkg/lvgl: bump to 8.2.0 (#17681)
|
||||||
* pkg/lvlgl: allow cusomizing LV_MEM_SIZE (#17759)
|
* pkg/lvlgl: allow customizing LV_MEM_SIZE (#17759)
|
||||||
+ pkg/mbedtls: initial pkg import to use entropy module (#15671)
|
+ pkg/mbedtls: initial pkg import to use entropy module (#15671)
|
||||||
* pkg/mynewt-core: fix semaphore (#17771)
|
* pkg/mynewt-core: fix semaphore (#17771)
|
||||||
* pkg/semtech-loramac: enable setting channels mask (#17824)
|
* pkg/semtech-loramac: enable setting channels mask (#17824)
|
||||||
@ -5848,7 +5848,7 @@ System Libraries (21)
|
|||||||
+ sys/event: add periodic timeout event (#16507)
|
+ sys/event: add periodic timeout event (#16507)
|
||||||
+ sys/ps: enable runtime_usec output for the ps command (#16470)
|
+ sys/ps: enable runtime_usec output for the ps command (#16470)
|
||||||
* gnrc_dhcpv6_client_6lbr: choose downstream if as !upstream (#16530)
|
* gnrc_dhcpv6_client_6lbr: choose downstream if as !upstream (#16530)
|
||||||
* net/emcute: Allow RETAIN flag to be set on incoming PUBLISHs (#16326)
|
* net/emcute: Allow RETAIN flag to be set on incoming PUBLISHes (#16326)
|
||||||
* net/gnrc/rpl: use ztimer_msec if available (#16339)
|
* net/gnrc/rpl: use ztimer_msec if available (#16339)
|
||||||
* net/grnc/sixlowpan/ctx: use ztimer_msec if available (#16340)
|
* net/grnc/sixlowpan/ctx: use ztimer_msec if available (#16340)
|
||||||
* sys/arduino: replace xtimer by ztimer as high-level background timer (#15317)
|
* sys/arduino: replace xtimer by ztimer as high-level background timer (#15317)
|
||||||
@ -13615,7 +13615,7 @@ Drivers
|
|||||||
Build System
|
Build System
|
||||||
------------
|
------------
|
||||||
+ Experimental distributed building using Murdock
|
+ Experimental distributed building using Murdock
|
||||||
+ most makfiles moved from root into makefiles/
|
+ most makefiles moved from root into makefiles/
|
||||||
+ added submodule support
|
+ added submodule support
|
||||||
|
|
||||||
Special Thanks
|
Special Thanks
|
||||||
|
@ -317,7 +317,7 @@ void swap(thread& lhs, thread& rhs) noexcept;
|
|||||||
/** @cond INTERNAL */
|
/** @cond INTERNAL */
|
||||||
template <class Tuple>
|
template <class Tuple>
|
||||||
void* thread_proxy(void* vp) {
|
void* thread_proxy(void* vp) {
|
||||||
{ // without this scope, the objects here are not cleaned up corrctly
|
{ // without this scope, the objects here are not cleaned up correctly
|
||||||
std::unique_ptr<Tuple> p(static_cast<Tuple*>(vp));
|
std::unique_ptr<Tuple> p(static_cast<Tuple*>(vp));
|
||||||
auto tmp = std::get<0>(*p);
|
auto tmp = std::get<0>(*p);
|
||||||
std::unique_ptr<thread_data, thread_data_deleter> data{tmp};
|
std::unique_ptr<thread_data, thread_data_deleter> data{tmp};
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
* - This implementation of the ChaCha stream cipher is very stripped down.
|
* - This implementation of the ChaCha stream cipher is very stripped down.
|
||||||
* - It assumes a little-endian system.
|
* - It assumes a little-endian system.
|
||||||
* - It is implemented for little code and data size, but will likely be
|
* - It is implemented for little code and data size, but will likely be
|
||||||
* slower than the refenrence implementation. Optimized implementation will
|
* slower than the reference implementation. Optimized implementation will
|
||||||
* out-perform the code even more.
|
* out-perform the code even more.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -616,7 +616,7 @@ static int _get_assertion(ctap_req_t *req_raw)
|
|||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* find eligble credentials */
|
/* find eligible credentials */
|
||||||
_assert_state.count = _find_matching_rks(_assert_state.rks,
|
_assert_state.count = _find_matching_rks(_assert_state.rks,
|
||||||
CTAP_MAX_EXCLUDE_LIST_SIZE,
|
CTAP_MAX_EXCLUDE_LIST_SIZE,
|
||||||
req.allow_list,
|
req.allow_list,
|
||||||
@ -693,7 +693,7 @@ static int _get_assertion(ctap_req_t *req_raw)
|
|||||||
memcpy(_assert_state.client_data_hash, req.client_data_hash,
|
memcpy(_assert_state.client_data_hash, req.client_data_hash,
|
||||||
SHA256_DIGEST_LENGTH);
|
SHA256_DIGEST_LENGTH);
|
||||||
|
|
||||||
/* most recently created eligble rk found */
|
/* most recently created eligible rk found */
|
||||||
rk = &_assert_state.rks[_assert_state.cred_counter++];
|
rk = &_assert_state.rks[_assert_state.cred_counter++];
|
||||||
|
|
||||||
/* last moment where transaction can be cancelled */
|
/* last moment where transaction can be cancelled */
|
||||||
@ -780,7 +780,7 @@ static int _get_next_assertion(void)
|
|||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* next eligble rk */
|
/* next eligible rk */
|
||||||
rk = &_assert_state.rks[_assert_state.cred_counter];
|
rk = &_assert_state.rks[_assert_state.cred_counter];
|
||||||
_assert_state.cred_counter++;
|
_assert_state.cred_counter++;
|
||||||
|
|
||||||
|
@ -1557,7 +1557,7 @@ static int _parse_options(CborValue *it, ctap_options_t *options)
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* ignore unknown options */
|
/* ignore unknown options */
|
||||||
DEBUG("Ctap parse options, unknown uption: %s \n", key);
|
DEBUG("Ctap parse options, unknown option: %s \n", key);
|
||||||
}
|
}
|
||||||
|
|
||||||
cbor_value_advance(&map);
|
cbor_value_advance(&map);
|
||||||
|
@ -395,7 +395,7 @@ static void _process_transaction(event_t *arg)
|
|||||||
_handle_init_packet(cid, bcnt, buf);
|
_handle_init_packet(cid, bcnt, buf);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* readding deleted cid */
|
/* re-adding deleted cid */
|
||||||
if (!_cid_exists(cid) && _add_cid(cid) == -1) {
|
if (!_cid_exists(cid) && _add_cid(cid) == -1) {
|
||||||
_send_error_response(cid, CTAP_HID_ERR_CHANNEL_BUSY);
|
_send_error_response(cid, CTAP_HID_ERR_CHANNEL_BUSY);
|
||||||
}
|
}
|
||||||
|
@ -142,7 +142,7 @@ static void permute(uint32_t abcd[4], const uint8_t block[64] )
|
|||||||
uint32_t keep_abcd[4];
|
uint32_t keep_abcd[4];
|
||||||
uint32_t x[16];
|
uint32_t x[16];
|
||||||
|
|
||||||
/* Store the current ABCD values for later re-use */
|
/* Store the current ABCD values for later reuse */
|
||||||
for (int i = 0; i < 4; i++) {
|
for (int i = 0; i < 4; i++) {
|
||||||
keep_abcd[i] = abcd[i];
|
keep_abcd[i] = abcd[i];
|
||||||
}
|
}
|
||||||
|
@ -144,7 +144,7 @@ int congure_test_call_setup(int argc, char **argv);
|
|||||||
* @param[in] argc Number of @p argv. Needs to be at least 2.
|
* @param[in] argc Number of @p argv. Needs to be at least 2.
|
||||||
* @param[in] argv Command line arguments. `argv[0]` needs to be the command
|
* @param[in] argv Command line arguments. `argv[0]` needs to be the command
|
||||||
* name and `argv[1]` needs to be a hexadecimal integer of
|
* name and `argv[1]` needs to be a hexadecimal integer of
|
||||||
* format 0xXXXX, represending a pointer to the object used as
|
* format 0xXXXX, representing a pointer to the object used as
|
||||||
* the `ctx` parameter for `init()`.
|
* the `ctx` parameter for `init()`.
|
||||||
*
|
*
|
||||||
* This function will generate the following JSON objects in STDOUT on error:
|
* This function will generate the following JSON objects in STDOUT on error:
|
||||||
|
@ -53,7 +53,7 @@ int cipher_encrypt_ecb(const cipher_t *cipher, const uint8_t *input,
|
|||||||
* @param input pointer to input data to decrypt
|
* @param input pointer to input data to decrypt
|
||||||
* @param length length of the input data
|
* @param length length of the input data
|
||||||
* @param output pointer to allocated memory for plaintext data. It has to
|
* @param output pointer to allocated memory for plaintext data. It has to
|
||||||
* be of size `lengh`.
|
* be of size `length`.
|
||||||
*
|
*
|
||||||
* @return Length of decrypted data on a successful decryption
|
* @return Length of decrypted data on a successful decryption
|
||||||
* @return A negative error code if something went wrong
|
* @return A negative error code if something went wrong
|
||||||
|
@ -71,7 +71,7 @@ typedef struct {
|
|||||||
*
|
*
|
||||||
* @param[out] ctx context handle to initialise
|
* @param[out] ctx context handle to initialise
|
||||||
* @param[in] rate the desired rate of the sponge
|
* @param[in] rate the desired rate of the sponge
|
||||||
* @param[in] capacity the desired capcity of the sponge
|
* @param[in] capacity the desired capacity of the sponge
|
||||||
* @param[in] delimitedSuffix suffix to be appended to the message after the absorbation phase
|
* @param[in] delimitedSuffix suffix to be appended to the message after the absorbation phase
|
||||||
*/
|
*/
|
||||||
void Keccak_init(keccak_state_t *ctx, unsigned int rate, unsigned int capacity,
|
void Keccak_init(keccak_state_t *ctx, unsigned int rate, unsigned int capacity,
|
||||||
|
@ -288,7 +288,7 @@ struct asymcute_con {
|
|||||||
*/
|
*/
|
||||||
struct asymcute_topic {
|
struct asymcute_topic {
|
||||||
asymcute_con_t *con; /**< connection used for registration */
|
asymcute_con_t *con; /**< connection used for registration */
|
||||||
char name[CONFIG_ASYMCUTE_TOPIC_MAXLEN + 1]; /**< topic string (ACSII only) */
|
char name[CONFIG_ASYMCUTE_TOPIC_MAXLEN + 1]; /**< topic string (ASCII only) */
|
||||||
uint8_t flags; /**< normal, short, or pre-defined */
|
uint8_t flags; /**< normal, short, or pre-defined */
|
||||||
uint16_t id; /**< topic id */
|
uint16_t id; /**< topic id */
|
||||||
};
|
};
|
||||||
|
@ -214,7 +214,7 @@ enum {
|
|||||||
* @brief MQTT-SN topic
|
* @brief MQTT-SN topic
|
||||||
*/
|
*/
|
||||||
typedef struct {
|
typedef struct {
|
||||||
const char *name; /**< topic string (currently ACSII only) */
|
const char *name; /**< topic string (currently ASCII only) */
|
||||||
uint16_t id; /**< topic id, as assigned by the gateway */
|
uint16_t id; /**< topic id, as assigned by the gateway */
|
||||||
} emcute_topic_t;
|
} emcute_topic_t;
|
||||||
|
|
||||||
|
@ -183,7 +183,7 @@
|
|||||||
* First, the data to be sent is added to the @ref net_gnrc_pktbuf "packet buffer".
|
* First, the data to be sent is added to the @ref net_gnrc_pktbuf "packet buffer".
|
||||||
* This ensures its intactness during the sending process. After the data to be
|
* This ensures its intactness during the sending process. After the data to be
|
||||||
* sent has been added to the packet buffer, its parent data structure can safely
|
* sent has been added to the packet buffer, its parent data structure can safely
|
||||||
* be freed or re-used.
|
* be freed or reused.
|
||||||
*
|
*
|
||||||
* Then, the @ref net_gnrc_pkt "pkt" will be sent to all threads that registered
|
* Then, the @ref net_gnrc_pkt "pkt" will be sent to all threads that registered
|
||||||
* for @ref GNRC_NETTYPE_UDP and the demux context `80`. Every registered thread
|
* for @ref GNRC_NETTYPE_UDP and the demux context `80`. Every registered thread
|
||||||
|
@ -227,7 +227,7 @@ typedef struct gnrc_netreg_entry {
|
|||||||
* There is an exclusive counterpart to the lock, which is
|
* There is an exclusive counterpart to the lock, which is
|
||||||
* internal to netreg (and used through functions such as @ref
|
* internal to netreg (and used through functions such as @ref
|
||||||
* gnrc_netreg_register and @ref gnrc_netreg_unregister). The current
|
* gnrc_netreg_register and @ref gnrc_netreg_unregister). The current
|
||||||
* implementation priorizes shared locks. This means that shared locks are
|
* implementation prioritizes shared locks. This means that shared locks are
|
||||||
* generally acquired fast (they only block if an exclusive operation has
|
* generally acquired fast (they only block if an exclusive operation has
|
||||||
* already started), but constant access through shared locks might starve
|
* already started), but constant access through shared locks might starve
|
||||||
* registration and deregistration.
|
* registration and deregistration.
|
||||||
|
@ -87,7 +87,7 @@ gnrc_sixlowpan_frag_vrb_t *gnrc_sixlowpan_frag_vrb_add(
|
|||||||
* @brief Generate reassembly buffer from a header's forwarding information.
|
* @brief Generate reassembly buffer from a header's forwarding information.
|
||||||
*
|
*
|
||||||
* @param[in] base Base data of the datagram. Must not be `NULL`.
|
* @param[in] base Base data of the datagram. Must not be `NULL`.
|
||||||
* @param[in] netif Restict route to this interface. May be `NULL` for any
|
* @param[in] netif Restrict route to this interface. May be `NULL` for any
|
||||||
* interface.
|
* interface.
|
||||||
* @param[in] hdr Header from which to take the forwarding information from
|
* @param[in] hdr Header from which to take the forwarding information from
|
||||||
* (e.g. IPv6 header implies `hdr->type == GNRC_NETTYPE_IPV6`).
|
* (e.g. IPv6 header implies `hdr->type == GNRC_NETTYPE_IPV6`).
|
||||||
|
@ -49,7 +49,7 @@ extern "C" {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SOCK_HAS_IPV6
|
#ifdef SOCK_HAS_IPV6
|
||||||
/* Re-use sock endpoint if sock is available and supporting IPv6. */
|
/* Reuse sock endpoint if sock is available and supporting IPv6. */
|
||||||
typedef struct _sock_tl_ep gnrc_tcp_ep_t;
|
typedef struct _sock_tl_ep gnrc_tcp_ep_t;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
@ -287,7 +287,7 @@ typedef ssize_t (*coap_handler_t)(coap_pkt_t *pkt, uint8_t *buf, size_t len,
|
|||||||
typedef int (*coap_blockwise_cb_t)(void *arg, size_t offset, uint8_t *buf, size_t len, int more);
|
typedef int (*coap_blockwise_cb_t)(void *arg, size_t offset, uint8_t *buf, size_t len, int more);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Coap equest callback descriptor
|
* @brief Coap request callback descriptor
|
||||||
*
|
*
|
||||||
* @param[in] arg Pointer to be passed as arguments to the callback
|
* @param[in] arg Pointer to be passed as arguments to the callback
|
||||||
* @param[in] pkt The received CoAP response.
|
* @param[in] pkt The received CoAP response.
|
||||||
|
@ -74,7 +74,7 @@
|
|||||||
* The actual code very much depends on the used `sock` type. Please refer to
|
* The actual code very much depends on the used `sock` type. Please refer to
|
||||||
* their documentation for specific examples.
|
* their documentation for specific examples.
|
||||||
*
|
*
|
||||||
* Implementor Notes
|
* Implementer Notes
|
||||||
* =================
|
* =================
|
||||||
* ### Type definition
|
* ### Type definition
|
||||||
* For simplicity and modularity this API doesn't put any restriction on the
|
* For simplicity and modularity this API doesn't put any restriction on the
|
||||||
|
@ -599,7 +599,7 @@ enum {
|
|||||||
/**
|
/**
|
||||||
* @brief Type for a DTLS sock object
|
* @brief Type for a DTLS sock object
|
||||||
*
|
*
|
||||||
* @note API implementors: `struct sock_dtls` needs to be defined by
|
* @note API implementers: `struct sock_dtls` needs to be defined by
|
||||||
* an implementation-specific `sock_dtls_types.h`.
|
* an implementation-specific `sock_dtls_types.h`.
|
||||||
*/
|
*/
|
||||||
typedef struct sock_dtls sock_dtls_t;
|
typedef struct sock_dtls sock_dtls_t;
|
||||||
|
@ -289,7 +289,7 @@ extern "C" {
|
|||||||
/**
|
/**
|
||||||
* @brief Type for a raw IPv4/IPv6 sock object
|
* @brief Type for a raw IPv4/IPv6 sock object
|
||||||
*
|
*
|
||||||
* @note API implementors: `struct sock_ip` needs to be defined by
|
* @note API implementers: `struct sock_ip` needs to be defined by
|
||||||
* implementation-specific `sock_types.h`.
|
* implementation-specific `sock_types.h`.
|
||||||
*/
|
*/
|
||||||
typedef struct sock_ip sock_ip_t;
|
typedef struct sock_ip sock_ip_t;
|
||||||
|
@ -322,7 +322,7 @@ typedef struct _sock_tl_ep sock_tcp_ep_t; /**< An end point for a TCP sock obj
|
|||||||
/**
|
/**
|
||||||
* @brief Type for a TCP sock object
|
* @brief Type for a TCP sock object
|
||||||
*
|
*
|
||||||
* @note API implementors: `struct sock_tcp` needs to be defined by
|
* @note API implementers: `struct sock_tcp` needs to be defined by
|
||||||
* implementation-specific `sock_types.h`.
|
* implementation-specific `sock_types.h`.
|
||||||
*/
|
*/
|
||||||
typedef struct sock_tcp sock_tcp_t;
|
typedef struct sock_tcp sock_tcp_t;
|
||||||
@ -330,7 +330,7 @@ typedef struct sock_tcp sock_tcp_t;
|
|||||||
/**
|
/**
|
||||||
* @brief Type for a TCP listening queue
|
* @brief Type for a TCP listening queue
|
||||||
*
|
*
|
||||||
* @note API implementors: `struct sock_tcp_queue` needs to be defined by
|
* @note API implementers: `struct sock_tcp_queue` needs to be defined by
|
||||||
* implementation-specific `sock_types.h`.
|
* implementation-specific `sock_types.h`.
|
||||||
*/
|
*/
|
||||||
typedef struct sock_tcp_queue sock_tcp_queue_t;
|
typedef struct sock_tcp_queue sock_tcp_queue_t;
|
||||||
|
@ -295,7 +295,7 @@ typedef struct _sock_tl_ep sock_udp_ep_t; /**< An end point for a UDP sock obj
|
|||||||
/**
|
/**
|
||||||
* @brief Type for a UDP sock object
|
* @brief Type for a UDP sock object
|
||||||
*
|
*
|
||||||
* @note API implementors: `struct sock_udp` needs to be defined by
|
* @note API implementers: `struct sock_udp` needs to be defined by
|
||||||
* implementation-specific `sock_types.h`.
|
* implementation-specific `sock_types.h`.
|
||||||
*/
|
*/
|
||||||
typedef struct sock_udp sock_udp_t;
|
typedef struct sock_udp sock_udp_t;
|
||||||
|
@ -68,7 +68,7 @@ extern "C" {
|
|||||||
/**
|
/**
|
||||||
* @brief Type for a TURO object
|
* @brief Type for a TURO object
|
||||||
*
|
*
|
||||||
* @note API implementors: `struct turo` needs to be defined by
|
* @note API implementers: `struct turo` needs to be defined by
|
||||||
* implementation-specific `result_output_types.h`.
|
* implementation-specific `result_output_types.h`.
|
||||||
*/
|
*/
|
||||||
typedef struct turo turo_t;
|
typedef struct turo turo_t;
|
||||||
|
@ -50,7 +50,7 @@ extern "C" {
|
|||||||
#define USB_DFU_CAN_DOWNLOAD 0x01 /**< DFU Download attribute */
|
#define USB_DFU_CAN_DOWNLOAD 0x01 /**< DFU Download attribute */
|
||||||
#define USB_DFU_CAN_UPLOAD 0x02 /**< DFU Upload attribute */
|
#define USB_DFU_CAN_UPLOAD 0x02 /**< DFU Upload attribute */
|
||||||
#define USB_DFU_MANIFEST_TOLERANT 0x04 /**< DFU Manifest tolerant attribute */
|
#define USB_DFU_MANIFEST_TOLERANT 0x04 /**< DFU Manifest tolerant attribute */
|
||||||
#define USB_DFU_WILL_DETACH 0x08 /**< DFU Detach capabability attribute */
|
#define USB_DFU_WILL_DETACH 0x08 /**< DFU Detach capability attribute */
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -85,7 +85,7 @@ static bool entry_is_dir(char *path, const char *name)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* re-use path buffer, it is already COAPFILESERVER_PATH_MAX bytes long */
|
/* reuse path buffer, it is already COAPFILESERVER_PATH_MAX bytes long */
|
||||||
path[path_len] = '/';
|
path[path_len] = '/';
|
||||||
path[path_len + 1] = 0;
|
path[path_len + 1] = 0;
|
||||||
strncat(path, name, COAPFILESERVER_PATH_MAX - 1);
|
strncat(path, name, COAPFILESERVER_PATH_MAX - 1);
|
||||||
|
@ -39,8 +39,8 @@
|
|||||||
/**
|
/**
|
||||||
* @brief Calculates the maximum of two unsigned numbers.
|
* @brief Calculates the maximum of two unsigned numbers.
|
||||||
*
|
*
|
||||||
* @param[in] x First comparrison value.
|
* @param[in] x First comparison value.
|
||||||
* @param[in] y Second comparrison value.
|
* @param[in] y Second comparison value.
|
||||||
*
|
*
|
||||||
* @returns X if x is larger than y, if not y is returned.
|
* @returns X if x is larger than y, if not y is returned.
|
||||||
*/
|
*/
|
||||||
|
@ -745,7 +745,7 @@
|
|||||||
*
|
*
|
||||||
* **cpu/myCPU/Makefile.features:**
|
* **cpu/myCPU/Makefile.features:**
|
||||||
* @code
|
* @code
|
||||||
* FEATURES_PROVIDED += periph_speedycrypt // General feature for the acclerator
|
* FEATURES_PROVIDED += periph_speedycrypt // General feature for the accelerator
|
||||||
* FEATURES_PROVIDED += periph_hash_sha_256
|
* FEATURES_PROVIDED += periph_hash_sha_256
|
||||||
* FEATURES_PROVIDED += periph_ecc_p256r1
|
* FEATURES_PROVIDED += periph_ecc_p256r1
|
||||||
* @endcode
|
* @endcode
|
||||||
|
@ -756,7 +756,7 @@ typedef psa_status_t (*psa_drv_se_aead_encrypt_t)(psa_drv_se_context_t *drv_cont
|
|||||||
size_t *p_ciphertext_length);
|
size_t *p_ciphertext_length);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief A function that peforms a secure element authenticated decryption operation
|
* @brief A function that performs a secure element authenticated decryption operation
|
||||||
*
|
*
|
||||||
* @param drv_context The driver context structure.
|
* @param drv_context The driver context structure.
|
||||||
* @param key_slot Slot containing the key to use
|
* @param key_slot Slot containing the key to use
|
||||||
|
@ -134,7 +134,7 @@ CFLAGS=-DCAN_DLL_NUMOF=2 BOARD=native PERIPH_CAN_FLAGS="--can 0:vcan1 --can 1:vc
|
|||||||
|
|
||||||
To send or receive bytes from the interface `can-utils` can be used:
|
To send or receive bytes from the interface `can-utils` can be used:
|
||||||
|
|
||||||
- send raw CAN frames: by using `cansend` or altenatively `cangen` to send random can messages:
|
- send raw CAN frames: by using `cansend` or alternatively `cangen` to send random can messages:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
$ cansend <interface> <can_id>:<hexbytes>
|
$ cansend <interface> <can_id>:<hexbytes>
|
||||||
|
@ -23,6 +23,7 @@ endif
|
|||||||
DRIVER ?= st7735
|
DRIVER ?= st7735
|
||||||
|
|
||||||
USEMODULE += $(DRIVER)
|
USEMODULE += $(DRIVER)
|
||||||
|
USEMODULE += benchmark
|
||||||
USEMODULE += ztimer
|
USEMODULE += ztimer
|
||||||
USEMODULE += ztimer_msec
|
USEMODULE += ztimer_msec
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
BOARD_INSUFFICIENT_MEMORY := \
|
BOARD_INSUFFICIENT_MEMORY := \
|
||||||
atmega8 \
|
atmega8 \
|
||||||
nucleo-l011k4 \
|
nucleo-l011k4 \
|
||||||
|
nucleo-l031k6 \
|
||||||
samd10-xmini \
|
samd10-xmini \
|
||||||
stk3200 \
|
stk3200 \
|
||||||
stm32f030f4-demo \
|
stm32f030f4-demo \
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
# this file enables modules defined in Kconfig. Do not use this file for
|
# this file enables modules defined in Kconfig. Do not use this file for
|
||||||
# application configuration. This is only needed during migration.
|
# application configuration. This is only needed during migration.
|
||||||
|
CONFIG_MODULE_BENCHMARK=y
|
||||||
CONFIG_MODULE_ST77XX=y
|
CONFIG_MODULE_ST77XX=y
|
||||||
CONFIG_MODULE_ZTIMER=y
|
CONFIG_MODULE_ZTIMER=y
|
||||||
CONFIG_MODULE_ZTIMER_MSEC=y
|
CONFIG_MODULE_ZTIMER_MSEC=y
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "timex.h"
|
#include "timex.h"
|
||||||
#include "ztimer.h"
|
#include "ztimer.h"
|
||||||
|
#include "benchmark.h"
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
#include "lcd.h"
|
#include "lcd.h"
|
||||||
#include "lcd_internal.h"
|
#include "lcd_internal.h"
|
||||||
@ -92,14 +93,21 @@ int main(void)
|
|||||||
lcd_invert_off(&dev);
|
lcd_invert_off(&dev);
|
||||||
puts("lcd TFT display normal");
|
puts("lcd TFT display normal");
|
||||||
|
|
||||||
puts("lcd TFT display clear screen");
|
puts("lcd TFT display clear screen with benchmarking");
|
||||||
lcd_fill(&dev, 0, dev.params->lines, 0, dev.params->rgb_channels, 0x0000);
|
BENCHMARK_FUNC("fill", 1,
|
||||||
|
lcd_fill(&dev, 0, dev.params->lines, 0, dev.params->rgb_channels, 0x0000));
|
||||||
|
|
||||||
#ifndef CONFIG_NO_RIOT_IMAGE
|
#ifndef CONFIG_NO_RIOT_IMAGE
|
||||||
|
printf("Write pixmap of size %u x %u with benchmarking\n",
|
||||||
|
RIOT_LOGO_WIDTH, RIOT_LOGO_HEIGHT);
|
||||||
/* Approximate middle of the display */
|
/* Approximate middle of the display */
|
||||||
uint8_t x1 = (dev.params->lines / 2) - (RIOT_LOGO_WIDTH / 2);
|
uint8_t x1 = (dev.params->lines / 2) - (RIOT_LOGO_WIDTH / 2);
|
||||||
uint8_t y1 = (dev.params->rgb_channels / 2) - (RIOT_LOGO_HEIGHT / 2);
|
uint8_t y1 = (dev.params->rgb_channels / 2) - (RIOT_LOGO_HEIGHT / 2);
|
||||||
lcd_pixmap(&dev, x1, x1 + RIOT_LOGO_WIDTH - 1, y1, y1 + RIOT_LOGO_HEIGHT - 1,
|
BENCHMARK_FUNC("fill", 1,
|
||||||
(const uint16_t *)picture);
|
lcd_pixmap(&dev,
|
||||||
|
x1, x1 + RIOT_LOGO_WIDTH - 1,
|
||||||
|
y1, y1 + RIOT_LOGO_HEIGHT - 1,
|
||||||
|
(const uint16_t *)picture));
|
||||||
#endif
|
#endif
|
||||||
while (1) {}
|
while (1) {}
|
||||||
|
|
||||||
|
@ -75,7 +75,7 @@ class StatelessDHCPv6Test(Automaton):
|
|||||||
"""
|
"""
|
||||||
The initial state.
|
The initial state.
|
||||||
|
|
||||||
The Automaton waits for an NDP Router Solication.
|
The Automaton waits for an NDP Router Solicitation.
|
||||||
"""
|
"""
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@ ESP32x WiFi interface simultaneously.
|
|||||||
|
|
||||||
# Usage
|
# Usage
|
||||||
|
|
||||||
Comile and flash the application with command
|
Compile and flash the application with command
|
||||||
```
|
```
|
||||||
CFLAGS='-DWIFI_SSID=\"myssid\" -DWIFI_PASS=\"mypass\"'
|
CFLAGS='-DWIFI_SSID=\"myssid\" -DWIFI_PASS=\"mypass\"'
|
||||||
BOARD=esp32-wroom-32 make -C tests/nimble_esp_wifi_coexist flash term
|
BOARD=esp32-wroom-32 make -C tests/nimble_esp_wifi_coexist flash term
|
||||||
|
@ -71,7 +71,7 @@ static void test_tinyvcdiff_mtd(void)
|
|||||||
rc = vcdiff_finish(&vcdiff);
|
rc = vcdiff_finish(&vcdiff);
|
||||||
TEST_ASSERT_EQUAL_INT(0, rc);
|
TEST_ASSERT_EQUAL_INT(0, rc);
|
||||||
|
|
||||||
/* check reconsturcted target */
|
/* check reconstructed target */
|
||||||
mtd_read(target_mtd, target_buf, 0, sizeof(target_buf));
|
mtd_read(target_mtd, target_buf, 0, sizeof(target_buf));
|
||||||
TEST_ASSERT_EQUAL_INT(0, memcmp(target_bin, target_buf, sizeof(target_buf)));
|
TEST_ASSERT_EQUAL_INT(0, memcmp(target_bin, target_buf, sizeof(target_buf)));
|
||||||
}
|
}
|
||||||
@ -109,7 +109,7 @@ static void test_tinyvcdiff_vfs(void)
|
|||||||
vfs_close(source_fd);
|
vfs_close(source_fd);
|
||||||
vfs_close(target_fd);
|
vfs_close(target_fd);
|
||||||
|
|
||||||
/* check reconsturcted target */
|
/* check reconstructed target */
|
||||||
memset(target_buf, 0, sizeof(target_buf));
|
memset(target_buf, 0, sizeof(target_buf));
|
||||||
target_fd = vfs_open("/mnt/target", O_RDONLY, 0);
|
target_fd = vfs_open("/mnt/target", O_RDONLY, 0);
|
||||||
vfs_read(target_fd, target_buf, sizeof(target_buf));
|
vfs_read(target_fd, target_buf, sizeof(target_buf));
|
||||||
|
@ -109,7 +109,7 @@ void test_fips(void);
|
|||||||
void test_entropy(uint32_t samples);
|
void test_entropy(uint32_t samples);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Run the speed test for a given duration. It utillizes xtimer for
|
* @brief Run the speed test for a given duration. It utilizes xtimer for
|
||||||
* setting an alarm.
|
* setting an alarm.
|
||||||
*
|
*
|
||||||
* @param[in] duration Test duration (in seconds)
|
* @param[in] duration Test duration (in seconds)
|
||||||
@ -118,7 +118,7 @@ void test_speed(uint32_t duration);
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Run the speed test for random numbers r with a <= r < b and a given duration.
|
* @brief Run the speed test for random numbers r with a <= r < b and a given duration.
|
||||||
* It utillizes xtimer for setting an alarm.
|
* It utilizes xtimer for setting an alarm.
|
||||||
*
|
*
|
||||||
* @param[in] duration Test duration (in seconds)
|
* @param[in] duration Test duration (in seconds)
|
||||||
* @param[in] a Minimum for random number
|
* @param[in] a Minimum for random number
|
||||||
|
@ -85,7 +85,7 @@ static void test_counter_mode(void)
|
|||||||
sema_inv_wait(&sync);
|
sema_inv_wait(&sync);
|
||||||
puts("thread synced");
|
puts("thread synced");
|
||||||
|
|
||||||
/* wait for all threads to terminate, we are going to re-use the stack */
|
/* wait for all threads to terminate, we are going to reuse the stack */
|
||||||
ztimer_sleep(ZTIMER_MSEC, 50);
|
ztimer_sleep(ZTIMER_MSEC, 50);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -112,7 +112,7 @@ static void test_mask_mode(void)
|
|||||||
sema_inv_wait(&sync);
|
sema_inv_wait(&sync);
|
||||||
puts("thread synced");
|
puts("thread synced");
|
||||||
|
|
||||||
/* wait for all threads to terminate, we are going to re-use the stack */
|
/* wait for all threads to terminate, we are going to reuse the stack */
|
||||||
ztimer_sleep(ZTIMER_MSEC, 50);
|
ztimer_sleep(ZTIMER_MSEC, 50);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user