mirror of
https://github.com/espressif/esp-idf.git
synced 2026-04-27 19:13:21 +00:00
f2d62bba74
- Add intr_priority field to gdma_channel_t structure - Add intr_bind_name field to gdma_signal_conn_t for interrupt binding - Validate intr_priority during channel allocation (must be 0-3) - Use ESP_INTR_FLAG_SHARED_PRIVATE instead of ESP_INTR_FLAG_SHARED - Use esp_intr_alloc_info() with bind_by.name for shared interrupts - Add interrupt priority configuration test case - Update all gdma_periph.c files with pair-specific bind names (gdma_gXpY)
64 lines
1.4 KiB
C
64 lines
1.4 KiB
C
/*
|
|
* SPDX-FileCopyrightText: 2020-2025 Espressif Systems (Shanghai) CO LTD
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "soc/soc_caps.h"
|
|
#include "soc/periph_defs.h"
|
|
#include "soc/regdma.h"
|
|
#if SOC_HAS(GDMA)
|
|
#include "hal/gdma_ll.h"
|
|
#endif
|
|
#if SOC_HAS(PAU)
|
|
#include "soc/retention_periph_defs.h"
|
|
#endif
|
|
|
|
#if CI_TEST_SW_RETENTION
|
|
#define GDMA_RETENTION_ENTRY REGDMA_SW_TRIGGER_ENTRY
|
|
#else
|
|
#if SOC_PHY_SUPPORTED
|
|
#define GDMA_RETENTION_ENTRY (ENTRY(0) | ENTRY(2))
|
|
#else
|
|
#define GDMA_RETENTION_ENTRY (ENTRY(0))
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#if SOC_HAS(GDMA)
|
|
typedef struct {
|
|
const int rx_irq_id;
|
|
const int tx_irq_id;
|
|
const char *name; // pair name, format: "gdma_gXpY"
|
|
} gdma_pair_signal_conn_t;
|
|
|
|
typedef struct {
|
|
struct {
|
|
const shared_periph_module_t module;
|
|
gdma_pair_signal_conn_t pairs[GDMA_LL_GET(PAIRS_PER_INST)];
|
|
} groups[GDMA_LL_GET(INST_NUM)];
|
|
} gdma_signal_conn_t;
|
|
|
|
extern const gdma_signal_conn_t gdma_periph_signals;
|
|
|
|
#if SOC_GDMA_SUPPORT_SLEEP_RETENTION && SOC_LIGHT_SLEEP_SUPPORTED
|
|
typedef struct {
|
|
const regdma_entries_config_t *link_list;
|
|
uint32_t link_num;
|
|
const periph_retention_module_t module_id;
|
|
} gdma_chx_reg_ctx_link_t;
|
|
|
|
extern const gdma_chx_reg_ctx_link_t gdma_chx_regs_retention[GDMA_LL_GET(INST_NUM)][GDMA_LL_GET(PAIRS_PER_INST)];
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|