mirror of
https://github.com/espressif/esp-idf.git
synced 2025-08-05 13:44:32 +02:00
change(hal): simplify some enable/disable function in pau_ll
This commit is contained in:
@@ -14,8 +14,10 @@
|
|||||||
#include "soc/pau_reg.h"
|
#include "soc/pau_reg.h"
|
||||||
#include "soc/pau_struct.h"
|
#include "soc/pau_struct.h"
|
||||||
#include "soc/pcr_struct.h"
|
#include "soc/pcr_struct.h"
|
||||||
|
#include "soc/lp_aon_struct.h"
|
||||||
#include "hal/pau_types.h"
|
#include "hal/pau_types.h"
|
||||||
#include "hal/assert.h"
|
#include "hal/assert.h"
|
||||||
|
#include "hal/misc.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@@ -47,14 +49,9 @@ static inline void pau_ll_set_regdma_entry_link_backup_direction(pau_dev_t *dev,
|
|||||||
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->regdma_conf.start = 1;
|
dev->regdma_conf.start = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->regdma_conf.start = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_select_wifimac_link(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_select_wifimac_link(pau_dev_t *dev)
|
||||||
@@ -107,14 +104,9 @@ static inline uint32_t pau_ll_get_regdma_intr_status(pau_dev_t *dev)
|
|||||||
return dev->int_st.val;
|
return dev->int_st.val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->int_ena.done_int_ena = 1;
|
dev->int_ena.done_int_ena = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->int_ena.done_int_ena = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev)
|
||||||
|
@@ -43,14 +43,14 @@ void IRAM_ATTR pau_hal_start_regdma_extra_link(pau_hal_context_t *hal, bool back
|
|||||||
*/
|
*/
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
||||||
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
||||||
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, true);
|
||||||
|
|
||||||
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
||||||
{
|
{
|
||||||
pau_ll_set_regdma_entry_link_backup_start_disable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, false);
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
||||||
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
||||||
}
|
}
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* SPDX-FileCopyrightText: 2023-2024 Espressif Systems (Shanghai) CO LTD
|
* SPDX-FileCopyrightText: 2023-2025 Espressif Systems (Shanghai) CO LTD
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: Apache-2.0
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@@ -47,14 +47,9 @@ static inline void pau_ll_set_regdma_entry_link_backup_direction(pau_dev_t *dev,
|
|||||||
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->regdma_conf.start = 1;
|
dev->regdma_conf.start = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->regdma_conf.start = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_select_wifimac_link(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_select_wifimac_link(pau_dev_t *dev)
|
||||||
@@ -132,14 +127,9 @@ static inline uint32_t pau_ll_get_regdma_intr_status(pau_dev_t *dev)
|
|||||||
return dev->int_st.val;
|
return dev->int_st.val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->int_ena.done_int_ena = 1;
|
dev->int_ena.done_int_ena = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->int_ena.done_int_ena = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev, bool enable)
|
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
|
@@ -46,14 +46,14 @@ void IRAM_ATTR pau_hal_start_regdma_extra_link(pau_hal_context_t *hal, bool back
|
|||||||
*/
|
*/
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
||||||
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
||||||
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, true);
|
||||||
|
|
||||||
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
||||||
{
|
{
|
||||||
pau_ll_set_regdma_entry_link_backup_start_disable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, false);
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
||||||
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
||||||
}
|
}
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* SPDX-FileCopyrightText: 2023-2024 Espressif Systems (Shanghai) CO LTD
|
* SPDX-FileCopyrightText: 2023-2025 Espressif Systems (Shanghai) CO LTD
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: Apache-2.0
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@@ -47,14 +47,9 @@ static inline void pau_ll_set_regdma_entry_link_backup_direction(pau_dev_t *dev,
|
|||||||
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->regdma_conf.start = 1;
|
dev->regdma_conf.start = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->regdma_conf.start = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_select_wifimac_link(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_select_wifimac_link(pau_dev_t *dev)
|
||||||
@@ -132,14 +127,9 @@ static inline uint32_t pau_ll_get_regdma_intr_status(pau_dev_t *dev)
|
|||||||
return dev->int_st.val;
|
return dev->int_st.val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->int_ena.done_int_ena = 1;
|
dev->int_ena.done_int_ena = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->int_ena.done_int_ena = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev, bool enable)
|
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
|
@@ -46,14 +46,14 @@ void IRAM_ATTR pau_hal_start_regdma_extra_link(pau_hal_context_t *hal, bool back
|
|||||||
*/
|
*/
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
||||||
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
||||||
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, true);
|
||||||
|
|
||||||
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
||||||
{
|
{
|
||||||
pau_ll_set_regdma_entry_link_backup_start_disable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, false);
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
||||||
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
||||||
}
|
}
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* SPDX-FileCopyrightText: 2023-2024 Espressif Systems (Shanghai) CO LTD
|
* SPDX-FileCopyrightText: 2023-2025 Espressif Systems (Shanghai) CO LTD
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: Apache-2.0
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@@ -47,14 +47,9 @@ static inline __attribute__((always_inline)) void pau_ll_set_regdma_entry_link_b
|
|||||||
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline __attribute__((always_inline)) void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev)
|
static inline __attribute__((always_inline)) void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->regdma_conf.start = 1;
|
dev->regdma_conf.start = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline __attribute__((always_inline)) void pau_ll_set_regdma_entry_link_backup_start_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->regdma_conf.start = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline __attribute__((always_inline)) void pau_ll_set_regdma_link0_addr(pau_dev_t *dev, void *link_addr)
|
static inline __attribute__((always_inline)) void pau_ll_set_regdma_link0_addr(pau_dev_t *dev, void *link_addr)
|
||||||
@@ -102,14 +97,9 @@ static inline __attribute__((always_inline)) uint32_t pau_ll_get_regdma_intr_sta
|
|||||||
return dev->int_st.val;
|
return dev->int_st.val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline __attribute__((always_inline)) void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev)
|
static inline __attribute__((always_inline)) void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->int_ena.done_int_ena = 1;
|
dev->int_ena.done_int_ena = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline __attribute__((always_inline)) void pau_ll_set_regdma_backup_done_intr_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->int_ena.done_int_ena = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev, bool enable)
|
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* SPDX-FileCopyrightText: 2022-2024 Espressif Systems (Shanghai) CO LTD
|
* SPDX-FileCopyrightText: 2022-2025 Espressif Systems (Shanghai) CO LTD
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: Apache-2.0
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
@@ -24,14 +24,14 @@ void IRAM_ATTR pau_hal_start_regdma_system_link(pau_hal_context_t *hal, bool bac
|
|||||||
|
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 0);
|
pau_ll_select_regdma_entry_link(hal->dev, 0);
|
||||||
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
||||||
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, true);
|
||||||
|
|
||||||
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
void IRAM_ATTR pau_hal_stop_regdma_system_link(pau_hal_context_t *hal)
|
void IRAM_ATTR pau_hal_stop_regdma_system_link(pau_hal_context_t *hal)
|
||||||
{
|
{
|
||||||
pau_ll_set_regdma_entry_link_backup_start_disable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, false);
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
||||||
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
||||||
}
|
}
|
||||||
@@ -64,14 +64,14 @@ void IRAM_ATTR pau_hal_start_regdma_extra_link(pau_hal_context_t *hal, bool back
|
|||||||
*/
|
*/
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
||||||
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
||||||
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, true);
|
||||||
|
|
||||||
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
||||||
{
|
{
|
||||||
pau_ll_set_regdma_entry_link_backup_start_disable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, false);
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
||||||
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
||||||
}
|
}
|
||||||
|
@@ -14,8 +14,10 @@
|
|||||||
#include "soc/pau_reg.h"
|
#include "soc/pau_reg.h"
|
||||||
#include "soc/pau_struct.h"
|
#include "soc/pau_struct.h"
|
||||||
#include "soc/pcr_struct.h"
|
#include "soc/pcr_struct.h"
|
||||||
|
#include "soc/lp_aon_struct.h"
|
||||||
#include "hal/pau_types.h"
|
#include "hal/pau_types.h"
|
||||||
#include "hal/assert.h"
|
#include "hal/assert.h"
|
||||||
|
#include "hal/misc.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@@ -47,14 +49,9 @@ static inline void pau_ll_set_regdma_entry_link_backup_direction(pau_dev_t *dev,
|
|||||||
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->regdma_conf.start = 1;
|
dev->regdma_conf.start = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->regdma_conf.start = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_select_wifimac_link(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_select_wifimac_link(pau_dev_t *dev)
|
||||||
@@ -107,14 +104,9 @@ static inline uint32_t pau_ll_get_regdma_intr_status(pau_dev_t *dev)
|
|||||||
return dev->int_st.val;
|
return dev->int_st.val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->int_ena.done_int_ena = 1;
|
dev->int_ena.done_int_ena = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->int_ena.done_int_ena = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev)
|
||||||
|
@@ -47,14 +47,14 @@ void IRAM_ATTR pau_hal_start_regdma_extra_link(pau_hal_context_t *hal, bool back
|
|||||||
*/
|
*/
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
||||||
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
||||||
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, true);
|
||||||
|
|
||||||
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
||||||
{
|
{
|
||||||
pau_ll_set_regdma_entry_link_backup_start_disable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, false);
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
||||||
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
||||||
}
|
}
|
||||||
|
@@ -25,13 +25,15 @@ static inline void gdma_ll_enable_bus_clock(int group_id, bool enable)
|
|||||||
/**
|
/**
|
||||||
* @brief Reset the DMA module
|
* @brief Reset the DMA module
|
||||||
*/
|
*/
|
||||||
static inline void gdma_ll_reset_register(int group_id)
|
static inline void _gdma_ll_reset_register(int group_id)
|
||||||
{
|
{
|
||||||
(void)group_id;
|
(void)group_id;
|
||||||
PCR.gdma_conf.gdma_rst_en = 1;
|
PCR.gdma_conf.gdma_rst_en = 1;
|
||||||
PCR.gdma_conf.gdma_rst_en = 0;
|
PCR.gdma_conf.gdma_rst_en = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define gdma_ll_reset_register(...) _gdma_ll_reset_register(__VA_ARGS__)
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@@ -14,10 +14,11 @@
|
|||||||
#include "soc/pau_reg.h"
|
#include "soc/pau_reg.h"
|
||||||
#include "soc/pau_struct.h"
|
#include "soc/pau_struct.h"
|
||||||
#include "soc/pcr_struct.h"
|
#include "soc/pcr_struct.h"
|
||||||
#include "hal/pau_types.h"
|
|
||||||
#include "hal/assert.h"
|
|
||||||
#include "soc/lp_aon_struct.h"
|
#include "soc/lp_aon_struct.h"
|
||||||
#include "soc/lp_aon_reg.h"
|
#include "soc/lp_aon_reg.h"
|
||||||
|
#include "hal/pau_types.h"
|
||||||
|
#include "hal/assert.h"
|
||||||
|
#include "hal/misc.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@@ -49,14 +50,9 @@ static inline void pau_ll_set_regdma_entry_link_backup_direction(pau_dev_t *dev,
|
|||||||
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->regdma_conf.start = 1;
|
dev->regdma_conf.start = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->regdma_conf.start = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_link0_addr(pau_dev_t *dev, void *link_addr)
|
static inline void pau_ll_set_regdma_link0_addr(pau_dev_t *dev, void *link_addr)
|
||||||
@@ -118,24 +114,14 @@ static inline uint32_t pau_ll_get_regdma_intr_status(pau_dev_t *dev)
|
|||||||
return dev->int_st.val;
|
return dev->int_st.val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->int_ena.done_int_ena = 1;
|
dev->int_ena.done_int_ena = enable;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_disable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->int_ena.done_int_ena = 0;
|
dev->int_ena.error_int_ena = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->int_ena.error_int_ena = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_error_intr_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->int_ena.error_int_ena = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_clear_regdma_backup_done_intr_state(pau_dev_t *dev)
|
static inline void pau_ll_clear_regdma_backup_done_intr_state(pau_dev_t *dev)
|
||||||
|
@@ -28,14 +28,14 @@ void IRAM_ATTR pau_hal_start_regdma_extra_link(pau_hal_context_t *hal, bool back
|
|||||||
*/
|
*/
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
||||||
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
||||||
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, true);
|
||||||
|
|
||||||
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
||||||
{
|
{
|
||||||
pau_ll_set_regdma_entry_link_backup_start_disable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, false);
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
pau_ll_select_regdma_entry_link(hal->dev, 0); /* restore link select to default */
|
||||||
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
||||||
}
|
}
|
||||||
|
@@ -55,14 +55,9 @@ static inline void pau_ll_set_regdma_entry_link_backup_direction(pau_dev_t *dev,
|
|||||||
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
dev->regdma_conf.to_mem = to_mem ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_entry_link_backup_start_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->regdma_conf.start = 1;
|
dev->regdma_conf.start = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_entry_link_backup_start_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->regdma_conf.start = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_select_wifimac_link(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_select_wifimac_link(pau_dev_t *dev)
|
||||||
@@ -140,14 +135,9 @@ static inline uint32_t pau_ll_get_regdma_intr_status(pau_dev_t *dev)
|
|||||||
return dev->int_st.val;
|
return dev->int_st.val;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev)
|
static inline void pau_ll_set_regdma_backup_done_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
{
|
{
|
||||||
dev->int_ena.done_int_ena = 1;
|
dev->int_ena.done_int_ena = enable;
|
||||||
}
|
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_done_intr_disable(pau_dev_t *dev)
|
|
||||||
{
|
|
||||||
dev->int_ena.done_int_ena = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev, bool enable)
|
static inline void pau_ll_set_regdma_backup_error_intr_enable(pau_dev_t *dev, bool enable)
|
||||||
|
@@ -51,14 +51,14 @@ void IRAM_ATTR pau_hal_start_regdma_extra_link(pau_hal_context_t *hal, bool back
|
|||||||
*/
|
*/
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
pau_ll_select_regdma_entry_link(hal->dev, 3);
|
||||||
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
pau_ll_set_regdma_entry_link_backup_direction(hal->dev, backup_or_restore);
|
||||||
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, true);
|
||||||
|
|
||||||
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
while (!(pau_ll_get_regdma_intr_raw_signal(hal->dev) & PAU_DONE_INT_RAW));
|
||||||
}
|
}
|
||||||
|
|
||||||
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
void IRAM_ATTR pau_hal_stop_regdma_extra_link(pau_hal_context_t *hal)
|
||||||
{
|
{
|
||||||
pau_ll_set_regdma_entry_link_backup_start_disable(hal->dev);
|
pau_ll_set_regdma_entry_link_backup_start_enable(hal->dev, false);
|
||||||
pau_ll_select_regdma_entry_link(hal->dev, 3); /* restore link select to default */
|
pau_ll_select_regdma_entry_link(hal->dev, 3); /* restore link select to default */
|
||||||
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
pau_ll_clear_regdma_backup_done_intr_state(hal->dev);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user