gdma: support IRAM interrupt

This commit is contained in:
morris
2021-11-08 10:26:52 +08:00
parent f8f49de735
commit 83d16aa00c
26 changed files with 320 additions and 336 deletions

View File

@@ -184,4 +184,22 @@ menu "Driver configurations"
endmenu # GPIO Configuration endmenu # GPIO Configuration
menu "GDMA Configuration"
config GDMA_CTRL_FUNC_IN_IRAM
bool "Place GDMA control functions into IRAM"
default n
help
Place GDMA control functions (like start/stop/append/reset) into IRAM,
so that these functions can be IRAM-safe and able to be called in the other IRAM interrupt context.
Enabling this option can improve driver performance as well.
config GDMA_ISR_IRAM_SAFE
bool "GDMA ISR IRAM-Safe"
default n
help
This will ensure the GDMA interrupt handler is IRAM-Safe, allow to avoid flash
cache misses, and also be able to run whilst the cache is disabled.
(e.g. SPI Flash write).
endmenu # GDMA Configuration
endmenu # Driver configurations endmenu # Driver configurations

View File

@@ -8,6 +8,7 @@
#include <stdlib.h> #include <stdlib.h>
#include <sys/cdefs.h> #include <sys/cdefs.h>
#include "sdkconfig.h"
#include "freertos/FreeRTOS.h" #include "freertos/FreeRTOS.h"
#include "freertos/task.h" #include "freertos/task.h"
#include "soc/soc_caps.h" #include "soc/soc_caps.h"
@@ -15,14 +16,30 @@
#include "esp_intr_alloc.h" #include "esp_intr_alloc.h"
#include "esp_log.h" #include "esp_log.h"
#include "esp_check.h" #include "esp_check.h"
#include "esp_private/periph_ctrl.h" #include "esp_heap_caps.h"
#include "esp_private/gdma.h"
#include "hal/gdma_hal.h" #include "hal/gdma_hal.h"
#include "hal/gdma_ll.h" #include "hal/gdma_ll.h"
#include "soc/gdma_periph.h" #include "soc/gdma_periph.h"
#include "soc/soc_memory_types.h"
#include "esp_private/periph_ctrl.h"
#include "esp_private/gdma.h"
static const char *TAG = "gdma"; static const char *TAG = "gdma";
#if CONFIG_GDMA_ISR_IRAM_SAFE
#define GDMA_INTR_ALLOC_FLAGS (ESP_INTR_FLAG_IRAM | ESP_INTR_FLAG_INTRDISABLED)
#define GDMA_MEM_ALLOC_CAPS (MALLOC_CAP_INTERNAL | MALLOC_CAP_8BIT)
#else
#define GDMA_INTR_ALLOC_FLAGS ESP_INTR_FLAG_INTRDISABLED
#define GDMA_MEM_ALLOC_CAPS MALLOC_CAP_DEFAULT
#endif // CONFIG_GDMA_ISR_IRAM_SAFE
#if CONFIG_GDMA_CTRL_FUNC_IN_IRAM
#define GDMA_CTRL_FUNC_ATTR IRAM_ATTR
#else
#define GDMA_CTRL_FUNC_ATTR
#endif // CONFIG_GDMA_CTRL_FUNC_IN_IRAM
#define GDMA_INVALID_PERIPH_TRIG (0x3F) #define GDMA_INVALID_PERIPH_TRIG (0x3F)
#define SEARCH_REQUEST_RX_CHANNEL (1 << 0) #define SEARCH_REQUEST_RX_CHANNEL (1 << 0)
#define SEARCH_REQUEST_TX_CHANNEL (1 << 1) #define SEARCH_REQUEST_TX_CHANNEL (1 << 1)
@@ -123,11 +140,11 @@ esp_err_t gdma_new_channel(const gdma_channel_alloc_config_t *config, gdma_chann
} }
if (config->direction == GDMA_CHANNEL_DIRECTION_TX) { if (config->direction == GDMA_CHANNEL_DIRECTION_TX) {
search_code |= SEARCH_REQUEST_TX_CHANNEL; // search TX only search_code |= SEARCH_REQUEST_TX_CHANNEL; // search TX only
alloc_tx_channel = calloc(1, sizeof(gdma_tx_channel_t)); alloc_tx_channel = heap_caps_calloc(1, sizeof(gdma_tx_channel_t), GDMA_MEM_ALLOC_CAPS);
ESP_GOTO_ON_FALSE(alloc_tx_channel, ESP_ERR_NO_MEM, err, TAG, "no mem for gdma tx channel"); ESP_GOTO_ON_FALSE(alloc_tx_channel, ESP_ERR_NO_MEM, err, TAG, "no mem for gdma tx channel");
} else if (config->direction == GDMA_CHANNEL_DIRECTION_RX) { } else if (config->direction == GDMA_CHANNEL_DIRECTION_RX) {
search_code |= SEARCH_REQUEST_RX_CHANNEL; // search RX only search_code |= SEARCH_REQUEST_RX_CHANNEL; // search RX only
alloc_rx_channel = calloc(1, sizeof(gdma_rx_channel_t)); alloc_rx_channel = heap_caps_calloc(1, sizeof(gdma_rx_channel_t), GDMA_MEM_ALLOC_CAPS);
ESP_GOTO_ON_FALSE(alloc_rx_channel, ESP_ERR_NO_MEM, err, TAG, "no mem for gdma rx channel"); ESP_GOTO_ON_FALSE(alloc_rx_channel, ESP_ERR_NO_MEM, err, TAG, "no mem for gdma rx channel");
} }
@@ -364,6 +381,17 @@ esp_err_t gdma_register_tx_event_callbacks(gdma_channel_handle_t dma_chan, gdma_
group = pair->group; group = pair->group;
gdma_tx_channel_t *tx_chan = __containerof(dma_chan, gdma_tx_channel_t, base); gdma_tx_channel_t *tx_chan = __containerof(dma_chan, gdma_tx_channel_t, base);
#if CONFIG_GDMA_ISR_IRAM_SAFE
if (cbs->on_trans_eof) {
ESP_GOTO_ON_FALSE(esp_ptr_in_iram(cbs->on_trans_eof), ESP_ERR_INVALID_ARG, err, TAG, "on_trans_eof not in IRAM");
}
if (user_data) {
ESP_GOTO_ON_FALSE(esp_ptr_in_dram(user_data) ||
esp_ptr_in_diram_dram(user_data) ||
esp_ptr_in_rtc_dram_fast(user_data), ESP_ERR_INVALID_ARG, err, TAG, "user context not in DRAM");
}
#endif // CONFIG_GDMA_ISR_IRAM_SAFE
// lazy install interrupt service // lazy install interrupt service
ESP_GOTO_ON_ERROR(gdma_install_tx_interrupt(tx_chan), err, TAG, "install interrupt service failed"); ESP_GOTO_ON_ERROR(gdma_install_tx_interrupt(tx_chan), err, TAG, "install interrupt service failed");
@@ -391,6 +419,17 @@ esp_err_t gdma_register_rx_event_callbacks(gdma_channel_handle_t dma_chan, gdma_
group = pair->group; group = pair->group;
gdma_rx_channel_t *rx_chan = __containerof(dma_chan, gdma_rx_channel_t, base); gdma_rx_channel_t *rx_chan = __containerof(dma_chan, gdma_rx_channel_t, base);
#if CONFIG_GDMA_ISR_IRAM_SAFE
if (cbs->on_recv_eof) {
ESP_GOTO_ON_FALSE(esp_ptr_in_iram(cbs->on_recv_eof), ESP_ERR_INVALID_ARG, err, TAG, "on_recv_eof not in IRAM");
}
if (user_data) {
ESP_GOTO_ON_FALSE(esp_ptr_in_dram(user_data) ||
esp_ptr_in_diram_dram(user_data) ||
esp_ptr_in_rtc_dram_fast(user_data), ESP_ERR_INVALID_ARG, err, TAG, "user context not in DRAM");
}
#endif // CONFIG_GDMA_ISR_IRAM_SAFE
// lazy install interrupt service // lazy install interrupt service
ESP_GOTO_ON_ERROR(gdma_install_rx_interrupt(rx_chan), err, TAG, "install interrupt service failed"); ESP_GOTO_ON_ERROR(gdma_install_rx_interrupt(rx_chan), err, TAG, "install interrupt service failed");
@@ -408,7 +447,7 @@ err:
return ret; return ret;
} }
esp_err_t gdma_start(gdma_channel_handle_t dma_chan, intptr_t desc_base_addr) GDMA_CTRL_FUNC_ATTR esp_err_t gdma_start(gdma_channel_handle_t dma_chan, intptr_t desc_base_addr)
{ {
esp_err_t ret = ESP_OK; esp_err_t ret = ESP_OK;
gdma_pair_t *pair = NULL; gdma_pair_t *pair = NULL;
@@ -429,7 +468,7 @@ err:
return ret; return ret;
} }
esp_err_t gdma_stop(gdma_channel_handle_t dma_chan) GDMA_CTRL_FUNC_ATTR esp_err_t gdma_stop(gdma_channel_handle_t dma_chan)
{ {
esp_err_t ret = ESP_OK; esp_err_t ret = ESP_OK;
gdma_pair_t *pair = NULL; gdma_pair_t *pair = NULL;
@@ -448,7 +487,7 @@ err:
return ret; return ret;
} }
esp_err_t gdma_append(gdma_channel_handle_t dma_chan) GDMA_CTRL_FUNC_ATTR esp_err_t gdma_append(gdma_channel_handle_t dma_chan)
{ {
esp_err_t ret = ESP_OK; esp_err_t ret = ESP_OK;
gdma_pair_t *pair = NULL; gdma_pair_t *pair = NULL;
@@ -467,7 +506,7 @@ err:
return ret; return ret;
} }
esp_err_t gdma_reset(gdma_channel_handle_t dma_chan) GDMA_CTRL_FUNC_ATTR esp_err_t gdma_reset(gdma_channel_handle_t dma_chan)
{ {
esp_err_t ret = ESP_OK; esp_err_t ret = ESP_OK;
gdma_pair_t *pair = NULL; gdma_pair_t *pair = NULL;
@@ -512,7 +551,7 @@ static gdma_group_t *gdma_acquire_group_handle(int group_id)
{ {
bool new_group = false; bool new_group = false;
gdma_group_t *group = NULL; gdma_group_t *group = NULL;
gdma_group_t *pre_alloc_group = calloc(1, sizeof(gdma_group_t)); gdma_group_t *pre_alloc_group = heap_caps_calloc(1, sizeof(gdma_group_t), GDMA_MEM_ALLOC_CAPS);
if (!pre_alloc_group) { if (!pre_alloc_group) {
goto out; goto out;
} }
@@ -576,7 +615,7 @@ static gdma_pair_t *gdma_acquire_pair_handle(gdma_group_t *group, int pair_id)
{ {
bool new_pair = false; bool new_pair = false;
gdma_pair_t *pair = NULL; gdma_pair_t *pair = NULL;
gdma_pair_t *pre_alloc_pair = calloc(1, sizeof(gdma_pair_t)); gdma_pair_t *pre_alloc_pair = heap_caps_calloc(1, sizeof(gdma_pair_t), GDMA_MEM_ALLOC_CAPS);
if (!pre_alloc_pair) { if (!pre_alloc_pair) {
goto out; goto out;
} }
@@ -724,7 +763,7 @@ static esp_err_t gdma_install_rx_interrupt(gdma_rx_channel_t *rx_chan)
gdma_pair_t *pair = rx_chan->base.pair; gdma_pair_t *pair = rx_chan->base.pair;
gdma_group_t *group = pair->group; gdma_group_t *group = pair->group;
// pre-alloc a interrupt handle, with handler disabled // pre-alloc a interrupt handle, with handler disabled
int isr_flags = ESP_INTR_FLAG_INTRDISABLED; int isr_flags = GDMA_INTR_ALLOC_FLAGS;
#if SOC_GDMA_TX_RX_SHARE_INTERRUPT #if SOC_GDMA_TX_RX_SHARE_INTERRUPT
isr_flags |= ESP_INTR_FLAG_SHARED; isr_flags |= ESP_INTR_FLAG_SHARED;
#endif #endif
@@ -751,7 +790,7 @@ static esp_err_t gdma_install_tx_interrupt(gdma_tx_channel_t *tx_chan)
gdma_pair_t *pair = tx_chan->base.pair; gdma_pair_t *pair = tx_chan->base.pair;
gdma_group_t *group = pair->group; gdma_group_t *group = pair->group;
// pre-alloc a interrupt handle, with handler disabled // pre-alloc a interrupt handle, with handler disabled
int isr_flags = ESP_INTR_FLAG_INTRDISABLED; int isr_flags = GDMA_INTR_ALLOC_FLAGS;
#if SOC_GDMA_TX_RX_SHARE_INTERRUPT #if SOC_GDMA_TX_RX_SHARE_INTERRUPT
isr_flags |= ESP_INTR_FLAG_SHARED; isr_flags |= ESP_INTR_FLAG_SHARED;
#endif #endif

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once #pragma once
#include <stdint.h> #include <stdint.h>
@@ -67,6 +59,7 @@ static inline void gdma_ll_enable_clock(gdma_dev_t *dev, bool enable)
/** /**
* @brief Get DMA RX channel interrupt status word * @brief Get DMA RX channel interrupt status word
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->intr[channel].st.val & GDMA_LL_RX_EVENT_MASK; return dev->intr[channel].st.val & GDMA_LL_RX_EVENT_MASK;
@@ -87,6 +80,7 @@ static inline void gdma_ll_rx_enable_interrupt(gdma_dev_t *dev, uint32_t channel
/** /**
* @brief Clear DMA RX channel interrupt * @brief Clear DMA RX channel interrupt
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask) static inline void gdma_ll_rx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask)
{ {
dev->intr[channel].clr.val = (mask & GDMA_LL_RX_EVENT_MASK); dev->intr[channel].clr.val = (mask & GDMA_LL_RX_EVENT_MASK);
@@ -127,6 +121,7 @@ static inline void gdma_ll_rx_enable_descriptor_burst(gdma_dev_t *dev, uint32_t
/** /**
* @brief Reset DMA RX channel FSM and FIFO pointer * @brief Reset DMA RX channel FSM and FIFO pointer
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_reset_channel(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_reset_channel(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.in_conf0.in_rst = 1; dev->channel[channel].in.in_conf0.in_rst = 1;
@@ -172,6 +167,7 @@ static inline uint32_t gdma_ll_rx_pop_data(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Set the descriptor link base address for RX channel * @brief Set the descriptor link base address for RX channel
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr) static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr)
{ {
dev->channel[channel].in.in_link.addr = addr; dev->channel[channel].in.in_link.addr = addr;
@@ -180,6 +176,7 @@ static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, u
/** /**
* @brief Start dealing with RX descriptors * @brief Start dealing with RX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.in_link.start = 1; dev->channel[channel].in.in_link.start = 1;
@@ -188,6 +185,7 @@ static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Stop dealing with RX descriptors * @brief Stop dealing with RX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.in_link.stop = 1; dev->channel[channel].in.in_link.stop = 1;
@@ -196,6 +194,7 @@ static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Restart a new inlink right after the last descriptor * @brief Restart a new inlink right after the last descriptor
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_restart(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_restart(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.in_link.restart = 1; dev->channel[channel].in.in_link.restart = 1;
@@ -220,6 +219,7 @@ static inline bool gdma_ll_rx_is_fsm_idle(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Get RX success EOF descriptor's address * @brief Get RX success EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].in.in_suc_eof_des_addr; return dev->channel[channel].in.in_suc_eof_des_addr;
@@ -228,6 +228,7 @@ static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uin
/** /**
* @brief Get RX error EOF descriptor's address * @brief Get RX error EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].in.in_err_eof_des_addr; return dev->channel[channel].in.in_err_eof_des_addr;
@@ -236,6 +237,7 @@ static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint3
/** /**
* @brief Get current RX descriptor's address * @brief Get current RX descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].in.in_dscr; return dev->channel[channel].in.in_dscr;
@@ -261,6 +263,7 @@ static inline void gdma_ll_rx_connect_to_periph(gdma_dev_t *dev, uint32_t channe
/** /**
* @brief Get DMA TX channel interrupt status word * @brief Get DMA TX channel interrupt status word
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->intr[channel].st.val & GDMA_LL_TX_EVENT_MASK; return dev->intr[channel].st.val & GDMA_LL_TX_EVENT_MASK;
@@ -281,6 +284,7 @@ static inline void gdma_ll_tx_enable_interrupt(gdma_dev_t *dev, uint32_t channel
/** /**
* @brief Clear DMA TX channel interrupt * @brief Clear DMA TX channel interrupt
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask) static inline void gdma_ll_tx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask)
{ {
dev->intr[channel].clr.val = (mask & GDMA_LL_TX_EVENT_MASK); dev->intr[channel].clr.val = (mask & GDMA_LL_TX_EVENT_MASK);
@@ -337,6 +341,7 @@ static inline void gdma_ll_tx_enable_auto_write_back(gdma_dev_t *dev, uint32_t c
/** /**
* @brief Reset DMA TX channel FSM and FIFO pointer * @brief Reset DMA TX channel FSM and FIFO pointer
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_reset_channel(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_reset_channel(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.out_conf0.out_rst = 1; dev->channel[channel].out.out_conf0.out_rst = 1;
@@ -382,6 +387,7 @@ static inline void gdma_ll_tx_push_data(gdma_dev_t *dev, uint32_t channel, uint3
/** /**
* @brief Set the descriptor link base address for TX channel * @brief Set the descriptor link base address for TX channel
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr) static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr)
{ {
dev->channel[channel].out.out_link.addr = addr; dev->channel[channel].out.out_link.addr = addr;
@@ -390,6 +396,7 @@ static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, u
/** /**
* @brief Start dealing with TX descriptors * @brief Start dealing with TX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.out_link.start = 1; dev->channel[channel].out.out_link.start = 1;
@@ -398,6 +405,7 @@ static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Stop dealing with TX descriptors * @brief Stop dealing with TX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.out_link.stop = 1; dev->channel[channel].out.out_link.stop = 1;
@@ -406,6 +414,7 @@ static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Restart a new outlink right after the last descriptor * @brief Restart a new outlink right after the last descriptor
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_restart(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_restart(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.out_link.restart = 1; dev->channel[channel].out.out_link.restart = 1;
@@ -422,6 +431,7 @@ static inline bool gdma_ll_tx_is_fsm_idle(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Get TX EOF descriptor's address * @brief Get TX EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].out.out_eof_des_addr; return dev->channel[channel].out.out_eof_des_addr;
@@ -430,6 +440,7 @@ static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t ch
/** /**
* @brief Get current TX descriptor's address * @brief Get current TX descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].out.out_dscr; return dev->channel[channel].out.out_dscr;

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once #pragma once
#include <stdint.h> #include <stdint.h>
@@ -67,6 +59,7 @@ static inline void gdma_ll_enable_clock(gdma_dev_t *dev, bool enable)
/** /**
* @brief Get DMA RX channel interrupt status word * @brief Get DMA RX channel interrupt status word
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->intr[channel].st.val & GDMA_LL_RX_EVENT_MASK; return dev->intr[channel].st.val & GDMA_LL_RX_EVENT_MASK;
@@ -87,6 +80,7 @@ static inline void gdma_ll_rx_enable_interrupt(gdma_dev_t *dev, uint32_t channel
/** /**
* @brief Clear DMA RX channel interrupt * @brief Clear DMA RX channel interrupt
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask) static inline void gdma_ll_rx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask)
{ {
dev->intr[channel].clr.val = (mask & GDMA_LL_RX_EVENT_MASK); dev->intr[channel].clr.val = (mask & GDMA_LL_RX_EVENT_MASK);
@@ -127,6 +121,7 @@ static inline void gdma_ll_rx_enable_descriptor_burst(gdma_dev_t *dev, uint32_t
/** /**
* @brief Reset DMA RX channel FSM and FIFO pointer * @brief Reset DMA RX channel FSM and FIFO pointer
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_reset_channel(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_reset_channel(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.in_conf0.in_rst = 1; dev->channel[channel].in.in_conf0.in_rst = 1;
@@ -172,6 +167,7 @@ static inline uint32_t gdma_ll_rx_pop_data(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Set the descriptor link base address for RX channel * @brief Set the descriptor link base address for RX channel
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr) static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr)
{ {
dev->channel[channel].in.in_link.addr = addr; dev->channel[channel].in.in_link.addr = addr;
@@ -180,6 +176,7 @@ static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, u
/** /**
* @brief Start dealing with RX descriptors * @brief Start dealing with RX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.in_link.start = 1; dev->channel[channel].in.in_link.start = 1;
@@ -188,6 +185,7 @@ static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Stop dealing with RX descriptors * @brief Stop dealing with RX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.in_link.stop = 1; dev->channel[channel].in.in_link.stop = 1;
@@ -196,6 +194,7 @@ static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Restart a new inlink right after the last descriptor * @brief Restart a new inlink right after the last descriptor
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_restart(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_restart(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.in_link.restart = 1; dev->channel[channel].in.in_link.restart = 1;
@@ -220,6 +219,7 @@ static inline bool gdma_ll_rx_is_fsm_idle(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Get RX success EOF descriptor's address * @brief Get RX success EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].in.in_suc_eof_des_addr; return dev->channel[channel].in.in_suc_eof_des_addr;
@@ -228,6 +228,7 @@ static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uin
/** /**
* @brief Get RX error EOF descriptor's address * @brief Get RX error EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].in.in_err_eof_des_addr; return dev->channel[channel].in.in_err_eof_des_addr;
@@ -236,6 +237,7 @@ static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint3
/** /**
* @brief Get current RX descriptor's address * @brief Get current RX descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].in.in_dscr; return dev->channel[channel].in.in_dscr;
@@ -261,6 +263,7 @@ static inline void gdma_ll_rx_connect_to_periph(gdma_dev_t *dev, uint32_t channe
/** /**
* @brief Get DMA TX channel interrupt status word * @brief Get DMA TX channel interrupt status word
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->intr[channel].st.val & GDMA_LL_TX_EVENT_MASK; return dev->intr[channel].st.val & GDMA_LL_TX_EVENT_MASK;
@@ -281,6 +284,7 @@ static inline void gdma_ll_tx_enable_interrupt(gdma_dev_t *dev, uint32_t channel
/** /**
* @brief Clear DMA TX channel interrupt * @brief Clear DMA TX channel interrupt
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask) static inline void gdma_ll_tx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask)
{ {
dev->intr[channel].clr.val = (mask & GDMA_LL_TX_EVENT_MASK); dev->intr[channel].clr.val = (mask & GDMA_LL_TX_EVENT_MASK);
@@ -337,6 +341,7 @@ static inline void gdma_ll_tx_enable_auto_write_back(gdma_dev_t *dev, uint32_t c
/** /**
* @brief Reset DMA TX channel FSM and FIFO pointer * @brief Reset DMA TX channel FSM and FIFO pointer
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_reset_channel(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_reset_channel(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.out_conf0.out_rst = 1; dev->channel[channel].out.out_conf0.out_rst = 1;
@@ -382,6 +387,7 @@ static inline void gdma_ll_tx_push_data(gdma_dev_t *dev, uint32_t channel, uint3
/** /**
* @brief Set the descriptor link base address for TX channel * @brief Set the descriptor link base address for TX channel
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr) static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr)
{ {
dev->channel[channel].out.out_link.addr = addr; dev->channel[channel].out.out_link.addr = addr;
@@ -390,6 +396,7 @@ static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, u
/** /**
* @brief Start dealing with TX descriptors * @brief Start dealing with TX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.out_link.start = 1; dev->channel[channel].out.out_link.start = 1;
@@ -398,6 +405,7 @@ static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Stop dealing with TX descriptors * @brief Stop dealing with TX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.out_link.stop = 1; dev->channel[channel].out.out_link.stop = 1;
@@ -406,6 +414,7 @@ static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Restart a new outlink right after the last descriptor * @brief Restart a new outlink right after the last descriptor
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_restart(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_restart(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.out_link.restart = 1; dev->channel[channel].out.out_link.restart = 1;
@@ -422,6 +431,7 @@ static inline bool gdma_ll_tx_is_fsm_idle(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Get TX EOF descriptor's address * @brief Get TX EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].out.out_eof_des_addr; return dev->channel[channel].out.out_eof_des_addr;
@@ -430,6 +440,7 @@ static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t ch
/** /**
* @brief Get current TX descriptor's address * @brief Get current TX descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].out.out_dscr; return dev->channel[channel].out.out_dscr;

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once #pragma once
#include <stdint.h> #include <stdint.h>
@@ -81,6 +73,7 @@ static inline void gdma_ll_enable_clock(gdma_dev_t *dev, bool enable)
/** /**
* @brief Get DMA RX channel interrupt status word * @brief Get DMA RX channel interrupt status word
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].in.int_st.val; return dev->channel[channel].in.int_st.val;
@@ -101,6 +94,7 @@ static inline void gdma_ll_rx_enable_interrupt(gdma_dev_t *dev, uint32_t channel
/** /**
* @brief Clear DMA RX channel interrupt * @brief Clear DMA RX channel interrupt
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask) static inline void gdma_ll_rx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask)
{ {
dev->channel[channel].in.int_clr.val = mask; dev->channel[channel].in.int_clr.val = mask;
@@ -141,6 +135,7 @@ static inline void gdma_ll_rx_enable_descriptor_burst(gdma_dev_t *dev, uint32_t
/** /**
* @brief Reset DMA RX channel FSM and FIFO pointer * @brief Reset DMA RX channel FSM and FIFO pointer
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_reset_channel(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_reset_channel(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.conf0.in_rst = 1; dev->channel[channel].in.conf0.in_rst = 1;
@@ -210,6 +205,7 @@ static inline uint32_t gdma_ll_rx_pop_data(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Set the descriptor link base address for RX channel * @brief Set the descriptor link base address for RX channel
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr) static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr)
{ {
dev->channel[channel].in.link.addr = addr; dev->channel[channel].in.link.addr = addr;
@@ -218,6 +214,7 @@ static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, u
/** /**
* @brief Start dealing with RX descriptors * @brief Start dealing with RX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.link.start = 1; dev->channel[channel].in.link.start = 1;
@@ -226,6 +223,7 @@ static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Stop dealing with RX descriptors * @brief Stop dealing with RX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.link.stop = 1; dev->channel[channel].in.link.stop = 1;
@@ -234,6 +232,7 @@ static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Restart a new inlink right after the last descriptor * @brief Restart a new inlink right after the last descriptor
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_restart(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_restart(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].in.link.restart = 1; dev->channel[channel].in.link.restart = 1;
@@ -258,6 +257,7 @@ static inline bool gdma_ll_rx_is_fsm_idle(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Get RX success EOF descriptor's address * @brief Get RX success EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].in.suc_eof_des_addr; return dev->channel[channel].in.suc_eof_des_addr;
@@ -266,6 +266,7 @@ static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uin
/** /**
* @brief Get RX error EOF descriptor's address * @brief Get RX error EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].in.err_eof_des_addr; return dev->channel[channel].in.err_eof_des_addr;
@@ -274,6 +275,7 @@ static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint3
/** /**
* @brief Get current RX descriptor's address * @brief Get current RX descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].in.dscr; return dev->channel[channel].in.dscr;
@@ -307,6 +309,7 @@ static inline void gdma_ll_rx_connect_to_periph(gdma_dev_t *dev, uint32_t channe
/** /**
* @brief Get DMA TX channel interrupt status word * @brief Get DMA TX channel interrupt status word
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].out.int_st.val; return dev->channel[channel].out.int_st.val;
@@ -327,6 +330,7 @@ static inline void gdma_ll_tx_enable_interrupt(gdma_dev_t *dev, uint32_t channel
/** /**
* @brief Clear DMA TX channel interrupt * @brief Clear DMA TX channel interrupt
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask) static inline void gdma_ll_tx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask)
{ {
dev->channel[channel].out.int_clr.val = mask; dev->channel[channel].out.int_clr.val = mask;
@@ -383,6 +387,7 @@ static inline void gdma_ll_tx_enable_auto_write_back(gdma_dev_t *dev, uint32_t c
/** /**
* @brief Reset DMA TX channel FSM and FIFO pointer * @brief Reset DMA TX channel FSM and FIFO pointer
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_reset_channel(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_reset_channel(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.conf0.out_rst = 1; dev->channel[channel].out.conf0.out_rst = 1;
@@ -444,6 +449,7 @@ static inline void gdma_ll_tx_push_data(gdma_dev_t *dev, uint32_t channel, uint3
/** /**
* @brief Set the descriptor link base address for TX channel * @brief Set the descriptor link base address for TX channel
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr) static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr)
{ {
dev->channel[channel].out.link.addr = addr; dev->channel[channel].out.link.addr = addr;
@@ -452,6 +458,7 @@ static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, u
/** /**
* @brief Start dealing with TX descriptors * @brief Start dealing with TX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.link.start = 1; dev->channel[channel].out.link.start = 1;
@@ -460,6 +467,7 @@ static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Stop dealing with TX descriptors * @brief Stop dealing with TX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.link.stop = 1; dev->channel[channel].out.link.stop = 1;
@@ -468,6 +476,7 @@ static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Restart a new outlink right after the last descriptor * @brief Restart a new outlink right after the last descriptor
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_restart(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_restart(gdma_dev_t *dev, uint32_t channel)
{ {
dev->channel[channel].out.link.restart = 1; dev->channel[channel].out.link.restart = 1;
@@ -484,6 +493,7 @@ static inline bool gdma_ll_tx_is_fsm_idle(gdma_dev_t *dev, uint32_t channel)
/** /**
* @brief Get TX EOF descriptor's address * @brief Get TX EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].out.eof_des_addr; return dev->channel[channel].out.eof_des_addr;
@@ -492,6 +502,7 @@ static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t ch
/** /**
* @brief Get current TX descriptor's address * @brief Get current TX descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
return dev->channel[channel].out.dscr; return dev->channel[channel].out.dscr;

View File

@@ -39,7 +39,12 @@ extern "C" {
*/ */
static inline void gdma_ll_enable_m2m_mode(gdma_dev_t *dev, uint32_t channel, bool enable) static inline void gdma_ll_enable_m2m_mode(gdma_dev_t *dev, uint32_t channel, bool enable)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_conf0.mem_trans_en = enable;
if (enable) {
// to enable m2m mode, the tx chan has to be the same to rx chan, and set to a valid value
dev->channel[channel].in.in_peri_sel.sel = 0;
dev->channel[channel].out.out_peri_sel.sel = 0;
}
} }
/** /**
@@ -47,16 +52,17 @@ static inline void gdma_ll_enable_m2m_mode(gdma_dev_t *dev, uint32_t channel, bo
*/ */
static inline void gdma_ll_enable_clock(gdma_dev_t *dev, bool enable) static inline void gdma_ll_enable_clock(gdma_dev_t *dev, bool enable)
{ {
abort(); //TODO IDF-3817 dev->misc_conf.clk_en = enable;
} }
///////////////////////////////////// RX ///////////////////////////////////////// ///////////////////////////////////// RX /////////////////////////////////////////
/** /**
* @brief Get DMA RX channel interrupt status word * @brief Get DMA RX channel interrupt status word
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return dev->intr[channel].st.val & GDMA_LL_RX_EVENT_MASK;
} }
/** /**
@@ -64,15 +70,20 @@ static inline uint32_t gdma_ll_rx_get_interrupt_status(gdma_dev_t *dev, uint32_t
*/ */
static inline void gdma_ll_rx_enable_interrupt(gdma_dev_t *dev, uint32_t channel, uint32_t mask, bool enable) static inline void gdma_ll_rx_enable_interrupt(gdma_dev_t *dev, uint32_t channel, uint32_t mask, bool enable)
{ {
abort(); //TODO IDF-3817 if (enable) {
dev->intr[channel].ena.val |= (mask & GDMA_LL_RX_EVENT_MASK);
} else {
dev->intr[channel].ena.val &= ~(mask & GDMA_LL_RX_EVENT_MASK);
}
} }
/** /**
* @brief Clear DMA RX channel interrupt * @brief Clear DMA RX channel interrupt
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask) static inline void gdma_ll_rx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask)
{ {
abort(); //TODO IDF-3817 dev->intr[channel].clr.val = (mask & GDMA_LL_RX_EVENT_MASK);
} }
/** /**
@@ -80,7 +91,7 @@ static inline void gdma_ll_rx_clear_interrupt_status(gdma_dev_t *dev, uint32_t c
*/ */
static inline volatile void *gdma_ll_rx_get_interrupt_status_reg(gdma_dev_t *dev, uint32_t channel) static inline volatile void *gdma_ll_rx_get_interrupt_status_reg(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return (volatile void *)(&dev->intr[channel].st);
} }
/** /**
@@ -88,7 +99,7 @@ static inline volatile void *gdma_ll_rx_get_interrupt_status_reg(gdma_dev_t *dev
*/ */
static inline void gdma_ll_rx_enable_owner_check(gdma_dev_t *dev, uint32_t channel, bool enable) static inline void gdma_ll_rx_enable_owner_check(gdma_dev_t *dev, uint32_t channel, bool enable)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_conf1.in_check_owner = enable;
} }
/** /**
@@ -96,7 +107,7 @@ static inline void gdma_ll_rx_enable_owner_check(gdma_dev_t *dev, uint32_t chann
*/ */
static inline void gdma_ll_rx_enable_data_burst(gdma_dev_t *dev, uint32_t channel, bool enable) static inline void gdma_ll_rx_enable_data_burst(gdma_dev_t *dev, uint32_t channel, bool enable)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_conf0.in_data_burst_en = enable;
} }
/** /**
@@ -104,15 +115,17 @@ static inline void gdma_ll_rx_enable_data_burst(gdma_dev_t *dev, uint32_t channe
*/ */
static inline void gdma_ll_rx_enable_descriptor_burst(gdma_dev_t *dev, uint32_t channel, bool enable) static inline void gdma_ll_rx_enable_descriptor_burst(gdma_dev_t *dev, uint32_t channel, bool enable)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_conf0.indscr_burst_en = enable;
} }
/** /**
* @brief Reset DMA RX channel FSM and FIFO pointer * @brief Reset DMA RX channel FSM and FIFO pointer
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_reset_channel(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_reset_channel(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_conf0.in_rst = 1;
dev->channel[channel].in.in_conf0.in_rst = 0;
} }
/** /**
@@ -121,7 +134,7 @@ static inline void gdma_ll_rx_reset_channel(gdma_dev_t *dev, uint32_t channel)
*/ */
static inline bool gdma_ll_rx_is_fifo_full(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level) static inline bool gdma_ll_rx_is_fifo_full(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].in.infifo_status.val & 0x01;
} }
/** /**
@@ -130,7 +143,7 @@ static inline bool gdma_ll_rx_is_fifo_full(gdma_dev_t *dev, uint32_t channel, ui
*/ */
static inline bool gdma_ll_rx_is_fifo_empty(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level) static inline bool gdma_ll_rx_is_fifo_empty(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].in.infifo_status.val & 0x02;
} }
/** /**
@@ -139,7 +152,7 @@ static inline bool gdma_ll_rx_is_fifo_empty(gdma_dev_t *dev, uint32_t channel, u
*/ */
static inline uint32_t gdma_ll_rx_get_fifo_bytes(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level) static inline uint32_t gdma_ll_rx_get_fifo_bytes(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].in.infifo_status.infifo_cnt;
} }
/** /**
@@ -147,39 +160,44 @@ static inline uint32_t gdma_ll_rx_get_fifo_bytes(gdma_dev_t *dev, uint32_t chann
*/ */
static inline uint32_t gdma_ll_rx_pop_data(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_pop_data(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_pop.infifo_pop = 1;
return dev->channel[channel].in.in_pop.infifo_rdata;
} }
/** /**
* @brief Set the descriptor link base address for RX channel * @brief Set the descriptor link base address for RX channel
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr) static inline void gdma_ll_rx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_link.addr = addr;
} }
/** /**
* @brief Start dealing with RX descriptors * @brief Start dealing with RX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_start(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_link.start = 1;
} }
/** /**
* @brief Stop dealing with RX descriptors * @brief Stop dealing with RX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_stop(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_link.stop = 1;
} }
/** /**
* @brief Restart a new inlink right after the last descriptor * @brief Restart a new inlink right after the last descriptor
*/ */
__attribute__((always_inline))
static inline void gdma_ll_rx_restart(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_rx_restart(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_link.restart = 1;
} }
/** /**
@@ -187,7 +205,7 @@ static inline void gdma_ll_rx_restart(gdma_dev_t *dev, uint32_t channel)
*/ */
static inline void gdma_ll_rx_enable_auto_return(gdma_dev_t *dev, uint32_t channel, bool enable) static inline void gdma_ll_rx_enable_auto_return(gdma_dev_t *dev, uint32_t channel, bool enable)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_link.auto_ret = enable;
} }
/** /**
@@ -195,31 +213,34 @@ static inline void gdma_ll_rx_enable_auto_return(gdma_dev_t *dev, uint32_t chann
*/ */
static inline bool gdma_ll_rx_is_fsm_idle(gdma_dev_t *dev, uint32_t channel) static inline bool gdma_ll_rx_is_fsm_idle(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].in.in_link.park;
} }
/** /**
* @brief Get RX success EOF descriptor's address * @brief Get RX success EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_success_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].in.in_suc_eof_des_addr;
} }
/** /**
* @brief Get RX error EOF descriptor's address * @brief Get RX error EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_error_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].in.in_err_eof_des_addr;
} }
/** /**
* @brief Get current RX descriptor's address * @brief Get current RX descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_rx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_rx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].in.in_dscr;
} }
/** /**
@@ -227,7 +248,7 @@ static inline uint32_t gdma_ll_rx_get_current_desc_addr(gdma_dev_t *dev, uint32_
*/ */
static inline void gdma_ll_rx_set_priority(gdma_dev_t *dev, uint32_t channel, uint32_t prio) static inline void gdma_ll_rx_set_priority(gdma_dev_t *dev, uint32_t channel, uint32_t prio)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_pri.rx_pri = prio;
} }
/** /**
@@ -235,16 +256,17 @@ static inline void gdma_ll_rx_set_priority(gdma_dev_t *dev, uint32_t channel, ui
*/ */
static inline void gdma_ll_rx_connect_to_periph(gdma_dev_t *dev, uint32_t channel, int periph_id) static inline void gdma_ll_rx_connect_to_periph(gdma_dev_t *dev, uint32_t channel, int periph_id)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].in.in_peri_sel.sel = periph_id;
} }
///////////////////////////////////// TX ///////////////////////////////////////// ///////////////////////////////////// TX /////////////////////////////////////////
/** /**
* @brief Get DMA TX channel interrupt status word * @brief Get DMA TX channel interrupt status word
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_interrupt_status(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return dev->intr[channel].st.val & GDMA_LL_TX_EVENT_MASK;
} }
/** /**
@@ -252,15 +274,20 @@ static inline uint32_t gdma_ll_tx_get_interrupt_status(gdma_dev_t *dev, uint32_t
*/ */
static inline void gdma_ll_tx_enable_interrupt(gdma_dev_t *dev, uint32_t channel, uint32_t mask, bool enable) static inline void gdma_ll_tx_enable_interrupt(gdma_dev_t *dev, uint32_t channel, uint32_t mask, bool enable)
{ {
abort(); //TODO IDF-3817 if (enable) {
dev->intr[channel].ena.val |= (mask & GDMA_LL_TX_EVENT_MASK);
} else {
dev->intr[channel].ena.val &= ~(mask & GDMA_LL_TX_EVENT_MASK);
}
} }
/** /**
* @brief Clear DMA TX channel interrupt * @brief Clear DMA TX channel interrupt
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask) static inline void gdma_ll_tx_clear_interrupt_status(gdma_dev_t *dev, uint32_t channel, uint32_t mask)
{ {
abort(); //TODO IDF-3817 dev->intr[channel].clr.val = (mask & GDMA_LL_TX_EVENT_MASK);
} }
/** /**
@@ -268,7 +295,7 @@ static inline void gdma_ll_tx_clear_interrupt_status(gdma_dev_t *dev, uint32_t c
*/ */
static inline volatile void *gdma_ll_tx_get_interrupt_status_reg(gdma_dev_t *dev, uint32_t channel) static inline volatile void *gdma_ll_tx_get_interrupt_status_reg(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return (volatile void *)(&dev->intr[channel].st);
} }
/** /**
@@ -276,7 +303,7 @@ static inline volatile void *gdma_ll_tx_get_interrupt_status_reg(gdma_dev_t *dev
*/ */
static inline void gdma_ll_tx_enable_owner_check(gdma_dev_t *dev, uint32_t channel, bool enable) static inline void gdma_ll_tx_enable_owner_check(gdma_dev_t *dev, uint32_t channel, bool enable)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_conf1.out_check_owner = enable;
} }
/** /**
@@ -284,7 +311,7 @@ static inline void gdma_ll_tx_enable_owner_check(gdma_dev_t *dev, uint32_t chann
*/ */
static inline void gdma_ll_tx_enable_data_burst(gdma_dev_t *dev, uint32_t channel, bool enable) static inline void gdma_ll_tx_enable_data_burst(gdma_dev_t *dev, uint32_t channel, bool enable)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_conf0.out_data_burst_en = enable;
} }
/** /**
@@ -292,7 +319,7 @@ static inline void gdma_ll_tx_enable_data_burst(gdma_dev_t *dev, uint32_t channe
*/ */
static inline void gdma_ll_tx_enable_descriptor_burst(gdma_dev_t *dev, uint32_t channel, bool enable) static inline void gdma_ll_tx_enable_descriptor_burst(gdma_dev_t *dev, uint32_t channel, bool enable)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_conf0.outdscr_burst_en = enable;
} }
/** /**
@@ -300,7 +327,7 @@ static inline void gdma_ll_tx_enable_descriptor_burst(gdma_dev_t *dev, uint32_t
*/ */
static inline void gdma_ll_tx_set_eof_mode(gdma_dev_t *dev, uint32_t channel, uint32_t mode) static inline void gdma_ll_tx_set_eof_mode(gdma_dev_t *dev, uint32_t channel, uint32_t mode)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_conf0.out_eof_mode = mode;
} }
/** /**
@@ -308,15 +335,17 @@ static inline void gdma_ll_tx_set_eof_mode(gdma_dev_t *dev, uint32_t channel, ui
*/ */
static inline void gdma_ll_tx_enable_auto_write_back(gdma_dev_t *dev, uint32_t channel, bool enable) static inline void gdma_ll_tx_enable_auto_write_back(gdma_dev_t *dev, uint32_t channel, bool enable)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_conf0.out_auto_wrback = enable;
} }
/** /**
* @brief Reset DMA TX channel FSM and FIFO pointer * @brief Reset DMA TX channel FSM and FIFO pointer
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_reset_channel(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_reset_channel(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_conf0.out_rst = 1;
dev->channel[channel].out.out_conf0.out_rst = 0;
} }
/** /**
@@ -325,7 +354,7 @@ static inline void gdma_ll_tx_reset_channel(gdma_dev_t *dev, uint32_t channel)
*/ */
static inline bool gdma_ll_tx_is_fifo_full(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level) static inline bool gdma_ll_tx_is_fifo_full(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].out.outfifo_status.val & 0x01;
} }
/** /**
@@ -334,7 +363,7 @@ static inline bool gdma_ll_tx_is_fifo_full(gdma_dev_t *dev, uint32_t channel, ui
*/ */
static inline bool gdma_ll_tx_is_fifo_empty(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level) static inline bool gdma_ll_tx_is_fifo_empty(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].out.outfifo_status.val & 0x02;
} }
/** /**
@@ -343,7 +372,7 @@ static inline bool gdma_ll_tx_is_fifo_empty(gdma_dev_t *dev, uint32_t channel, u
*/ */
static inline uint32_t gdma_ll_tx_get_fifo_bytes(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level) static inline uint32_t gdma_ll_tx_get_fifo_bytes(gdma_dev_t *dev, uint32_t channel, uint32_t fifo_level)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].out.outfifo_status.outfifo_cnt;
} }
/** /**
@@ -351,39 +380,44 @@ static inline uint32_t gdma_ll_tx_get_fifo_bytes(gdma_dev_t *dev, uint32_t chann
*/ */
static inline void gdma_ll_tx_push_data(gdma_dev_t *dev, uint32_t channel, uint32_t data) static inline void gdma_ll_tx_push_data(gdma_dev_t *dev, uint32_t channel, uint32_t data)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_push.outfifo_wdata = data;
dev->channel[channel].out.out_push.outfifo_push = 1;
} }
/** /**
* @brief Set the descriptor link base address for TX channel * @brief Set the descriptor link base address for TX channel
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr) static inline void gdma_ll_tx_set_desc_addr(gdma_dev_t *dev, uint32_t channel, uint32_t addr)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_link.addr = addr;
} }
/** /**
* @brief Start dealing with TX descriptors * @brief Start dealing with TX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_start(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_link.start = 1;
} }
/** /**
* @brief Stop dealing with TX descriptors * @brief Stop dealing with TX descriptors
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_stop(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_link.stop = 1;
} }
/** /**
* @brief Restart a new outlink right after the last descriptor * @brief Restart a new outlink right after the last descriptor
*/ */
__attribute__((always_inline))
static inline void gdma_ll_tx_restart(gdma_dev_t *dev, uint32_t channel) static inline void gdma_ll_tx_restart(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_link.restart = 1;
} }
/** /**
@@ -391,23 +425,25 @@ static inline void gdma_ll_tx_restart(gdma_dev_t *dev, uint32_t channel)
*/ */
static inline bool gdma_ll_tx_is_fsm_idle(gdma_dev_t *dev, uint32_t channel) static inline bool gdma_ll_tx_is_fsm_idle(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].out.out_link.park;
} }
/** /**
* @brief Get TX EOF descriptor's address * @brief Get TX EOF descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_eof_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].out.out_eof_des_addr;
} }
/** /**
* @brief Get current TX descriptor's address * @brief Get current TX descriptor's address
*/ */
__attribute__((always_inline))
static inline uint32_t gdma_ll_tx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel) static inline uint32_t gdma_ll_tx_get_current_desc_addr(gdma_dev_t *dev, uint32_t channel)
{ {
abort(); //TODO IDF-3817 return dev->channel[channel].out.out_dscr;
} }
/** /**
@@ -415,7 +451,7 @@ static inline uint32_t gdma_ll_tx_get_current_desc_addr(gdma_dev_t *dev, uint32_
*/ */
static inline void gdma_ll_tx_set_priority(gdma_dev_t *dev, uint32_t channel, uint32_t prio) static inline void gdma_ll_tx_set_priority(gdma_dev_t *dev, uint32_t channel, uint32_t prio)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_pri.tx_pri = prio;
} }
/** /**
@@ -423,7 +459,7 @@ static inline void gdma_ll_tx_set_priority(gdma_dev_t *dev, uint32_t channel, ui
*/ */
static inline void gdma_ll_tx_connect_to_periph(gdma_dev_t *dev, uint32_t channel, int periph_id) static inline void gdma_ll_tx_connect_to_periph(gdma_dev_t *dev, uint32_t channel, int periph_id)
{ {
abort(); //TODO IDF-3817 dev->channel[channel].out.out_peri_sel.sel = periph_id;
} }
#ifdef __cplusplus #ifdef __cplusplus

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "hal/gdma_hal.h" #include "hal/gdma_hal.h"
#include "hal/gdma_ll.h" #include "hal/gdma_ll.h"

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once #pragma once

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
/******************************************************************************* /*******************************************************************************
* NOTICE * NOTICE

View File

@@ -1,2 +1,7 @@
/*
* SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD
*
* SPDX-License-Identifier: Apache-2.0
*/
// ESP32 doesn't feature General DMA peripheral. // ESP32 doesn't feature General DMA peripheral.
// We keep this file here only for consistency's sake. // We keep this file here only for consistency's sake.

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "soc/gdma_periph.h" #include "soc/gdma_periph.h"

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once #pragma once

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef _SOC_DMA_REG_H_ #ifndef _SOC_DMA_REG_H_
#define _SOC_DMA_REG_H_ #define _SOC_DMA_REG_H_

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once #pragma once
#include <stdint.h> #include <stdint.h>

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "soc/gdma_periph.h" #include "soc/gdma_periph.h"

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once #pragma once

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef _SOC_DMA_REG_H_ #ifndef _SOC_DMA_REG_H_
#define _SOC_DMA_REG_H_ #define _SOC_DMA_REG_H_

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once #pragma once
#include <stdint.h> #include <stdint.h>

View File

@@ -1,2 +1,7 @@
/*
* SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD
*
* SPDX-License-Identifier: Apache-2.0
*/
// ESP32-S2 doesn't feature General DMA peripheral. // ESP32-S2 doesn't feature General DMA peripheral.
// We keep this file here only for consistency's sake. // We keep this file here only for consistency's sake.

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include "soc/gdma_periph.h" #include "soc/gdma_periph.h"

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once #pragma once

View File

@@ -1,16 +1,8 @@
// Copyright 2017-2021 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2017-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef _SOC_GDMA_REG_H_ #ifndef _SOC_GDMA_REG_H_
#define _SOC_GDMA_REG_H_ #define _SOC_GDMA_REG_H_

View File

@@ -1,16 +1,8 @@
// Copyright 2017-2021 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2017-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef _SOC_GDMA_STRUCT_H_ #ifndef _SOC_GDMA_STRUCT_H_
#define _SOC_GDMA_STRUCT_H_ #define _SOC_GDMA_STRUCT_H_

View File

@@ -1,16 +1,15 @@
/* /*
* SPDX-FileCopyrightText: 2017-2021 Espressif Systems (Shanghai) CO LTD * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
* *
* SPDX-License-Identifier: Apache-2.0 * SPDX-License-Identifier: Apache-2.0
*/ */
#ifndef _SOC_GDMA_STRUCT_H_ #pragma once
#define _SOC_GDMA_STRUCT_H_
#include <stdint.h>
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif
#include "soc.h"
typedef volatile struct gdma_dev_s { typedef volatile struct gdma_dev_s {
struct { struct {
@@ -313,11 +312,9 @@ typedef volatile struct gdma_dev_s {
} out; } out;
} channel[1]; } channel[1];
} gdma_dev_t; } gdma_dev_t;
extern gdma_dev_t GDMA; extern gdma_dev_t GDMA;
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif
#endif /*_SOC_DMA_STRUCT_H_ */

View File

@@ -1,16 +1,8 @@
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD /*
// * SPDX-FileCopyrightText: 2020-2021 Espressif Systems (Shanghai) CO LTD
// Licensed under the Apache License, Version 2.0 (the "License"); *
// you may not use this file except in compliance with the License. * SPDX-License-Identifier: Apache-2.0
// You may obtain a copy of the License at */
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#pragma once #pragma once

View File

@@ -1184,7 +1184,6 @@ components/hal/esp32c3/include/hal/adc_ll.h
components/hal/esp32c3/include/hal/aes_ll.h components/hal/esp32c3/include/hal/aes_ll.h
components/hal/esp32c3/include/hal/clk_gate_ll.h components/hal/esp32c3/include/hal/clk_gate_ll.h
components/hal/esp32c3/include/hal/ds_ll.h components/hal/esp32c3/include/hal/ds_ll.h
components/hal/esp32c3/include/hal/gdma_ll.h
components/hal/esp32c3/include/hal/gpspi_flash_ll.h components/hal/esp32c3/include/hal/gpspi_flash_ll.h
components/hal/esp32c3/include/hal/hmac_hal.h components/hal/esp32c3/include/hal/hmac_hal.h
components/hal/esp32c3/include/hal/hmac_ll.h components/hal/esp32c3/include/hal/hmac_ll.h
@@ -1217,7 +1216,6 @@ components/hal/esp32h2/include/hal/adc_ll.h
components/hal/esp32h2/include/hal/aes_ll.h components/hal/esp32h2/include/hal/aes_ll.h
components/hal/esp32h2/include/hal/clk_gate_ll.h components/hal/esp32h2/include/hal/clk_gate_ll.h
components/hal/esp32h2/include/hal/ds_ll.h components/hal/esp32h2/include/hal/ds_ll.h
components/hal/esp32h2/include/hal/gdma_ll.h
components/hal/esp32h2/include/hal/gpspi_flash_ll.h components/hal/esp32h2/include/hal/gpspi_flash_ll.h
components/hal/esp32h2/include/hal/hmac_hal.h components/hal/esp32h2/include/hal/hmac_hal.h
components/hal/esp32h2/include/hal/hmac_ll.h components/hal/esp32h2/include/hal/hmac_ll.h
@@ -1291,7 +1289,6 @@ components/hal/esp32s3/include/hal/adc_hal_conf.h
components/hal/esp32s3/include/hal/adc_ll.h components/hal/esp32s3/include/hal/adc_ll.h
components/hal/esp32s3/include/hal/aes_ll.h components/hal/esp32s3/include/hal/aes_ll.h
components/hal/esp32s3/include/hal/cpu_ll.h components/hal/esp32s3/include/hal/cpu_ll.h
components/hal/esp32s3/include/hal/gdma_ll.h
components/hal/esp32s3/include/hal/gpspi_flash_ll.h components/hal/esp32s3/include/hal/gpspi_flash_ll.h
components/hal/esp32s3/include/hal/i2c_ll.h components/hal/esp32s3/include/hal/i2c_ll.h
components/hal/esp32s3/include/hal/interrupt_controller_ll.h components/hal/esp32s3/include/hal/interrupt_controller_ll.h
@@ -1316,7 +1313,6 @@ components/hal/esp32s3/include/hal/uhci_ll.h
components/hal/esp32s3/include/hal/usb_ll.h components/hal/esp32s3/include/hal/usb_ll.h
components/hal/esp32s3/include/hal/usb_serial_jtag_ll.h components/hal/esp32s3/include/hal/usb_serial_jtag_ll.h
components/hal/esp32s3/interrupt_descriptor_table.c components/hal/esp32s3/interrupt_descriptor_table.c
components/hal/gdma_hal.c
components/hal/gpio_hal.c components/hal/gpio_hal.c
components/hal/i2c_hal.c components/hal/i2c_hal.c
components/hal/i2c_hal_iram.c components/hal/i2c_hal_iram.c
@@ -1327,12 +1323,10 @@ components/hal/include/hal/brownout_hal.h
components/hal/include/hal/cpu_types.h components/hal/include/hal/cpu_types.h
components/hal/include/hal/dac_hal.h components/hal/include/hal/dac_hal.h
components/hal/include/hal/dac_types.h components/hal/include/hal/dac_types.h
components/hal/include/hal/dma_types.h
components/hal/include/hal/ds_hal.h components/hal/include/hal/ds_hal.h
components/hal/include/hal/emac_hal.h components/hal/include/hal/emac_hal.h
components/hal/include/hal/esp_flash_err.h components/hal/include/hal/esp_flash_err.h
components/hal/include/hal/eth_types.h components/hal/include/hal/eth_types.h
components/hal/include/hal/gdma_hal.h
components/hal/include/hal/gpio_hal.h components/hal/include/hal/gpio_hal.h
components/hal/include/hal/i2c_hal.h components/hal/include/hal/i2c_hal.h
components/hal/include/hal/i2c_types.h components/hal/include/hal/i2c_types.h
@@ -1830,7 +1824,6 @@ components/soc/esp32/include/soc/emac_mac_struct.h
components/soc/esp32/include/soc/fe_reg.h components/soc/esp32/include/soc/fe_reg.h
components/soc/esp32/include/soc/flash_encryption_reg.h components/soc/esp32/include/soc/flash_encryption_reg.h
components/soc/esp32/include/soc/frc_timer_reg.h components/soc/esp32/include/soc/frc_timer_reg.h
components/soc/esp32/include/soc/gdma_channel.h
components/soc/esp32/include/soc/gpio_pins.h components/soc/esp32/include/soc/gpio_pins.h
components/soc/esp32/include/soc/gpio_reg.h components/soc/esp32/include/soc/gpio_reg.h
components/soc/esp32/include/soc/gpio_sd_reg.h components/soc/esp32/include/soc/gpio_sd_reg.h
@@ -1903,7 +1896,6 @@ components/soc/esp32/spi_periph.c
components/soc/esp32/touch_sensor_periph.c components/soc/esp32/touch_sensor_periph.c
components/soc/esp32/uart_periph.c components/soc/esp32/uart_periph.c
components/soc/esp32c3/adc_periph.c components/soc/esp32c3/adc_periph.c
components/soc/esp32c3/gdma_periph.c
components/soc/esp32c3/gpio_periph.c components/soc/esp32c3/gpio_periph.c
components/soc/esp32c3/i2c_bbpll.h components/soc/esp32c3/i2c_bbpll.h
components/soc/esp32c3/i2c_periph.c components/soc/esp32c3/i2c_periph.c
@@ -1922,9 +1914,6 @@ components/soc/esp32c3/include/soc/efuse_reg.h
components/soc/esp32c3/include/soc/efuse_struct.h components/soc/esp32c3/include/soc/efuse_struct.h
components/soc/esp32c3/include/soc/extmem_reg.h components/soc/esp32c3/include/soc/extmem_reg.h
components/soc/esp32c3/include/soc/fe_reg.h components/soc/esp32c3/include/soc/fe_reg.h
components/soc/esp32c3/include/soc/gdma_channel.h
components/soc/esp32c3/include/soc/gdma_reg.h
components/soc/esp32c3/include/soc/gdma_struct.h
components/soc/esp32c3/include/soc/gpio_pins.h components/soc/esp32c3/include/soc/gpio_pins.h
components/soc/esp32c3/include/soc/gpio_reg.h components/soc/esp32c3/include/soc/gpio_reg.h
components/soc/esp32c3/include/soc/gpio_sd_reg.h components/soc/esp32c3/include/soc/gpio_sd_reg.h
@@ -1986,7 +1975,6 @@ components/soc/esp32c3/sigmadelta_periph.c
components/soc/esp32c3/spi_periph.c components/soc/esp32c3/spi_periph.c
components/soc/esp32c3/uart_periph.c components/soc/esp32c3/uart_periph.c
components/soc/esp32h2/adc_periph.c components/soc/esp32h2/adc_periph.c
components/soc/esp32h2/gdma_periph.c
components/soc/esp32h2/gpio_periph.c components/soc/esp32h2/gpio_periph.c
components/soc/esp32h2/i2c_periph.c components/soc/esp32h2/i2c_periph.c
components/soc/esp32h2/i2s_periph.c components/soc/esp32h2/i2s_periph.c
@@ -2005,9 +1993,6 @@ components/soc/esp32h2/include/soc/efuse_reg.h
components/soc/esp32h2/include/soc/efuse_struct.h components/soc/esp32h2/include/soc/efuse_struct.h
components/soc/esp32h2/include/soc/extmem_reg.h components/soc/esp32h2/include/soc/extmem_reg.h
components/soc/esp32h2/include/soc/fe_reg.h components/soc/esp32h2/include/soc/fe_reg.h
components/soc/esp32h2/include/soc/gdma_channel.h
components/soc/esp32h2/include/soc/gdma_reg.h
components/soc/esp32h2/include/soc/gdma_struct.h
components/soc/esp32h2/include/soc/gpio_pins.h components/soc/esp32h2/include/soc/gpio_pins.h
components/soc/esp32h2/include/soc/gpio_reg.h components/soc/esp32h2/include/soc/gpio_reg.h
components/soc/esp32h2/include/soc/gpio_sd_reg.h components/soc/esp32h2/include/soc/gpio_sd_reg.h
@@ -2098,7 +2083,6 @@ components/soc/esp32s2/include/soc/efuse_struct.h
components/soc/esp32s2/include/soc/extmem_reg.h components/soc/esp32s2/include/soc/extmem_reg.h
components/soc/esp32s2/include/soc/fe_reg.h components/soc/esp32s2/include/soc/fe_reg.h
components/soc/esp32s2/include/soc/frc_timer_reg.h components/soc/esp32s2/include/soc/frc_timer_reg.h
components/soc/esp32s2/include/soc/gdma_channel.h
components/soc/esp32s2/include/soc/gpio_pins.h components/soc/esp32s2/include/soc/gpio_pins.h
components/soc/esp32s2/include/soc/gpio_reg.h components/soc/esp32s2/include/soc/gpio_reg.h
components/soc/esp32s2/include/soc/gpio_sd_reg.h components/soc/esp32s2/include/soc/gpio_sd_reg.h
@@ -2178,7 +2162,6 @@ components/soc/esp32s2/uart_periph.c
components/soc/esp32s2/usb_periph.c components/soc/esp32s2/usb_periph.c
components/soc/esp32s3/adc_periph.c components/soc/esp32s3/adc_periph.c
components/soc/esp32s3/dedic_gpio_periph.c components/soc/esp32s3/dedic_gpio_periph.c
components/soc/esp32s3/gdma_periph.c
components/soc/esp32s3/gpio_periph.c components/soc/esp32s3/gpio_periph.c
components/soc/esp32s3/i2c_periph.c components/soc/esp32s3/i2c_periph.c
components/soc/esp32s3/i2s_periph.c components/soc/esp32s3/i2s_periph.c
@@ -2201,9 +2184,6 @@ components/soc/esp32s3/include/soc/efuse_struct.h
components/soc/esp32s3/include/soc/extmem_reg.h components/soc/esp32s3/include/soc/extmem_reg.h
components/soc/esp32s3/include/soc/extmem_struct.h components/soc/esp32s3/include/soc/extmem_struct.h
components/soc/esp32s3/include/soc/fe_reg.h components/soc/esp32s3/include/soc/fe_reg.h
components/soc/esp32s3/include/soc/gdma_channel.h
components/soc/esp32s3/include/soc/gdma_reg.h
components/soc/esp32s3/include/soc/gdma_struct.h
components/soc/esp32s3/include/soc/gpio_caps.h components/soc/esp32s3/include/soc/gpio_caps.h
components/soc/esp32s3/include/soc/gpio_pins.h components/soc/esp32s3/include/soc/gpio_pins.h
components/soc/esp32s3/include/soc/gpio_reg.h components/soc/esp32s3/include/soc/gpio_reg.h
@@ -2313,7 +2293,6 @@ components/soc/include/soc/dac_periph.h
components/soc/include/soc/dedic_gpio_periph.h components/soc/include/soc/dedic_gpio_periph.h
components/soc/include/soc/efuse_periph.h components/soc/include/soc/efuse_periph.h
components/soc/include/soc/emac_periph.h components/soc/include/soc/emac_periph.h
components/soc/include/soc/gdma_periph.h
components/soc/include/soc/gpio_periph.h components/soc/include/soc/gpio_periph.h
components/soc/include/soc/hwcrypto_periph.h components/soc/include/soc/hwcrypto_periph.h
components/soc/include/soc/i2c_periph.h components/soc/include/soc/i2c_periph.h