mirror of
https://github.com/espressif/esp-idf
synced 2025-03-10 01:29:21 -04:00
97 lines
3.5 KiB
C
97 lines
3.5 KiB
C
/*
|
|
* SPDX-FileCopyrightText: 2020-2024 Espressif Systems (Shanghai) CO LTD
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#include "soc/pcnt_periph.h"
|
|
#include "soc/gpio_sig_map.h"
|
|
#include "soc/pcnt_reg.h"
|
|
|
|
const pcnt_signal_conn_t pcnt_periph_signals = {
|
|
.groups = {
|
|
[0] = {
|
|
.irq = ETS_PCNT_INTR_SOURCE,
|
|
.units = {
|
|
[0] = {
|
|
.channels = {
|
|
[0] = {
|
|
.control_sig = PCNT_CTRL_CH0_IN0_IDX,
|
|
.pulse_sig = PCNT_SIG_CH0_IN0_IDX
|
|
},
|
|
[1] = {
|
|
.control_sig = PCNT_CTRL_CH1_IN0_IDX,
|
|
.pulse_sig = PCNT_SIG_CH1_IN0_IDX
|
|
}
|
|
}
|
|
},
|
|
[1] = {
|
|
.channels = {
|
|
[0] = {
|
|
.control_sig = PCNT_CTRL_CH0_IN1_IDX,
|
|
.pulse_sig = PCNT_SIG_CH0_IN1_IDX
|
|
},
|
|
[1] = {
|
|
.control_sig = PCNT_CTRL_CH1_IN1_IDX,
|
|
.pulse_sig = PCNT_SIG_CH1_IN1_IDX
|
|
}
|
|
}
|
|
},
|
|
[2] = {
|
|
.channels = {
|
|
[0] = {
|
|
.control_sig = PCNT_CTRL_CH0_IN2_IDX,
|
|
.pulse_sig = PCNT_SIG_CH0_IN2_IDX
|
|
},
|
|
[1] = {
|
|
.control_sig = PCNT_CTRL_CH1_IN2_IDX,
|
|
.pulse_sig = PCNT_SIG_CH1_IN2_IDX
|
|
}
|
|
}
|
|
},
|
|
[3] = {
|
|
.channels = {
|
|
[0] = {
|
|
.control_sig = PCNT_CTRL_CH0_IN3_IDX,
|
|
.pulse_sig = PCNT_SIG_CH0_IN3_IDX
|
|
},
|
|
[1] = {
|
|
.control_sig = PCNT_CTRL_CH1_IN3_IDX,
|
|
.pulse_sig = PCNT_SIG_CH1_IN3_IDX
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
/**
|
|
* PCNT Registers to be saved during sleep retention
|
|
* - Configuration registers, e.g.: PCNT_CTRL_REG, PCNT_U0_CONF0_REG, PCNT_U0_CONF1_REG, PCNT_U0_CONF2_REG, PCNT_U1_CONF0_REG...
|
|
* - Interrupt enable registers, e.g.: PCNT_INT_ENA_REG
|
|
*/
|
|
#define PCNT_RETENTION_REGS_CNT 14
|
|
#define PCNT_RETENTION_REGS_BASE (DR_REG_PCNT_BASE + 0x0)
|
|
static const uint32_t pcnt_regs_map[4] = {0x1040fff, 0x0, 0x0, 0x0};
|
|
static const regdma_entries_config_t pcnt_regs_retention[] = {
|
|
// backup stage: save configuration registers
|
|
// restore stage: restore the configuration registers
|
|
[0] = {
|
|
.config = REGDMA_LINK_ADDR_MAP_INIT(REGDMA_PCNT_LINK(0x00), \
|
|
PCNT_RETENTION_REGS_BASE, PCNT_RETENTION_REGS_BASE, \
|
|
PCNT_RETENTION_REGS_CNT, 0, 0, \
|
|
pcnt_regs_map[0], pcnt_regs_map[1], \
|
|
pcnt_regs_map[2], pcnt_regs_map[3]), \
|
|
.owner = ENTRY(0) | ENTRY(2)
|
|
}, \
|
|
};
|
|
|
|
const pcnt_reg_retention_info_t pcnt_reg_retention_info[SOC_PCNT_GROUPS] = {
|
|
[0] = {
|
|
.regdma_entry_array = pcnt_regs_retention,
|
|
.array_size = ARRAY_SIZE(pcnt_regs_retention),
|
|
.retention_module = SLEEP_RETENTION_MODULE_PCNT0
|
|
},
|
|
};
|