mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
120 lines
3.4 KiB
C
120 lines
3.4 KiB
C
/*
|
|
* SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
// Note that most of the register operations in this layer are non-atomic operations.
|
|
|
|
#pragma once
|
|
|
|
#include <stdbool.h>
|
|
#include "hal/assert.h"
|
|
#include "hal/misc.h"
|
|
#include "soc/gpio_ext_struct.h"
|
|
#include "soc/soc_etm_source.h"
|
|
|
|
#define GPIO_LL_ETM_EVENT_ID_POS_EDGE(ch) (GPIO_EVT_CH0_RISE_EDGE + (ch))
|
|
#define GPIO_LL_ETM_EVENT_ID_NEG_EDGE(ch) (GPIO_EVT_CH0_FALL_EDGE + (ch))
|
|
#define GPIO_LL_ETM_EVENT_ID_ANY_EDGE(ch) (GPIO_EVT_CH0_ANY_EDGE + (ch))
|
|
|
|
#define GPIO_LL_ETM_TASK_ID_SET(ch) (GPIO_TASK_CH0_SET + (ch))
|
|
#define GPIO_LL_ETM_TASK_ID_CLR(ch) (GPIO_TASK_CH0_CLEAR + (ch))
|
|
#define GPIO_LL_ETM_TASK_ID_TOG(ch) (GPIO_TASK_CH0_TOGGLE + (ch))
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Set which GPIO to be bounded to the event channel
|
|
*
|
|
* @param dev Register base address
|
|
* @param chan Channel number
|
|
* @param gpio_num GPIO number
|
|
*/
|
|
static inline void gpio_ll_etm_event_channel_set_gpio(gpio_etm_dev_t *dev, uint32_t chan, uint32_t gpio_num)
|
|
{
|
|
dev->event_chn_cfg[chan].etm_chn_event_sel = gpio_num;
|
|
}
|
|
|
|
/**
|
|
* @brief Wether to enable the event channel
|
|
*
|
|
* @param dev Register base address
|
|
* @param chan Channel number
|
|
* @param enable True to enable, false to disable
|
|
*/
|
|
static inline void gpio_ll_etm_enable_event_channel(gpio_etm_dev_t *dev, uint32_t chan, bool enable)
|
|
{
|
|
dev->event_chn_cfg[chan].etm_chn_event_en = enable;
|
|
}
|
|
|
|
/**
|
|
* @brief Set which GPIO to be bounded to the task channel
|
|
*
|
|
* @note One channel can be bounded to multiple different GPIOs
|
|
*
|
|
* @param dev Register base address
|
|
* @param chan Channel number
|
|
* @param gpio_num GPIO number
|
|
*/
|
|
static inline void gpio_ll_etm_gpio_set_task_channel(gpio_etm_dev_t *dev, uint32_t gpio_num, uint32_t chan)
|
|
{
|
|
int g_p = gpio_num / 4;
|
|
int g_idx = gpio_num % 4;
|
|
uint32_t reg_val = dev->etm_task_pn_cfg[g_p].val;
|
|
reg_val &= ~(0x07 << (g_idx * 8 + 1));
|
|
reg_val |= ((chan & 0x07) << (g_idx * 8 + 1));
|
|
dev->etm_task_pn_cfg[g_p].val = reg_val;
|
|
}
|
|
|
|
/**
|
|
* @brief Wether to enable the GPIO to be managed by the task channel
|
|
*
|
|
* @param dev Register base address
|
|
* @param gpio_num GPIO number
|
|
* @param enable True to enable, false to disable
|
|
*/
|
|
static inline void gpio_ll_etm_enable_task_gpio(gpio_etm_dev_t *dev, uint32_t gpio_num, bool enable)
|
|
{
|
|
int g_p = gpio_num / 4;
|
|
int g_idx = gpio_num % 4;
|
|
uint32_t reg_val = dev->etm_task_pn_cfg[g_p].val;
|
|
reg_val &= ~(0x01 << (g_idx * 8));
|
|
reg_val |= ((enable & 0x01) << (g_idx * 8));
|
|
dev->etm_task_pn_cfg[g_p].val = reg_val;
|
|
}
|
|
|
|
/**
|
|
* @brief Check whether a GPIO has been enabled and managed by a task channel
|
|
*
|
|
* @param dev Register base address
|
|
* @param gpio_num GPIO number
|
|
* @return True if enabled, false otherwise
|
|
*/
|
|
static inline bool gpio_ll_etm_is_task_gpio_enabled(gpio_etm_dev_t *dev, uint32_t gpio_num)
|
|
{
|
|
int g_p = gpio_num / 4;
|
|
int g_idx = gpio_num % 4;
|
|
return dev->etm_task_pn_cfg[g_p].val & (0x01 << (g_idx * 8));
|
|
}
|
|
|
|
/**
|
|
* @brief Get the channel number that the GPIO is bounded to
|
|
*
|
|
* @param dev Register base address
|
|
* @param gpio_num GPIO number
|
|
* @return GPIO ETM Task channel number
|
|
*/
|
|
static inline uint32_t gpio_ll_etm_gpio_get_task_channel(gpio_etm_dev_t *dev, uint32_t gpio_num)
|
|
{
|
|
int g_p = gpio_num / 4;
|
|
int g_idx = gpio_num % 4;
|
|
return (dev->etm_task_pn_cfg[g_p].val >> (g_idx * 8 + 1)) & 0x07;
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|