mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-11-04 00:51:42 +01:00 
			
		
		
		
	mcpwm: clean up hal driver and add doc
This commit is contained in:
		@@ -387,10 +387,6 @@ config SOC_MCPWM_GPIO_SYNCHROS_PER_GROUP
 | 
			
		||||
    int
 | 
			
		||||
    default 3
 | 
			
		||||
 | 
			
		||||
config SOC_MCPWM_BASE_CLK_HZ
 | 
			
		||||
    int
 | 
			
		||||
    default 160000000
 | 
			
		||||
 | 
			
		||||
config SOC_MPU_CONFIGURABLE_REGIONS_SUPPORTED
 | 
			
		||||
    bool
 | 
			
		||||
    default n
 | 
			
		||||
 
 | 
			
		||||
@@ -210,6 +210,34 @@ typedef enum {
 | 
			
		||||
    UART_SCLK_DEFAULT = SOC_MOD_CLK_APB,       /*!< UART source clock default choice is APB */
 | 
			
		||||
} soc_periph_uart_clk_src_legacy_t;
 | 
			
		||||
 | 
			
		||||
//////////////////////////////////////////////////MCPWM/////////////////////////////////////////////////////////////////
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * @brief Array initializer for all supported clock sources of MCPWM Timer
 | 
			
		||||
 */
 | 
			
		||||
#define SOC_MCPWM_TIMER_CLKS {SOC_MOD_CLK_PLL_D2}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * @brief Type of MCPWM timer clock source
 | 
			
		||||
 */
 | 
			
		||||
typedef enum {
 | 
			
		||||
    MCPWM_TIMER_CLK_SRC_PLL160M = SOC_MOD_CLK_PLL_D2, /*!< Select PLL_D2 (160MHz) as the source clock */
 | 
			
		||||
    MCPWM_TIMER_CLK_SRC_DEFAULT = SOC_MOD_CLK_PLL_D2, /*!< Select PLL_D2 as the default clock choice */
 | 
			
		||||
} soc_periph_mcpwm_timer_clk_src_t;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * @brief Array initializer for all supported clock sources of MCPWM Capture Timer
 | 
			
		||||
 */
 | 
			
		||||
#define SOC_MCPWM_CAPTURE_CLKS {SOC_MOD_CLK_APB}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * @brief Type of MCPWM capture clock source
 | 
			
		||||
 */
 | 
			
		||||
typedef enum {
 | 
			
		||||
    MCPWM_CAPTURE_CLK_SRC_APB = SOC_MOD_CLK_APB,     /*!< Select APB as the source clock */
 | 
			
		||||
    MCPWM_CAPTURE_CLK_SRC_DEFAULT = SOC_MOD_CLK_APB, /*!< SElect APB as the default clock choice */
 | 
			
		||||
} soc_periph_mcpwm_capture_clk_src_t;
 | 
			
		||||
 | 
			
		||||
#ifdef __cplusplus
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
/**
 | 
			
		||||
 *  SPDX-FileCopyrightText: 2021 Espressif Systems (Shanghai) CO LTD
 | 
			
		||||
 * SPDX-FileCopyrightText: 2021-2022 Espressif Systems (Shanghai) CO LTD
 | 
			
		||||
 *
 | 
			
		||||
 *  SPDX-License-Identifier: Apache-2.0
 | 
			
		||||
 */
 | 
			
		||||
@@ -1435,7 +1435,7 @@ typedef struct {
 | 
			
		||||
    mcpwm_fh_status_reg_t fh_status;
 | 
			
		||||
} mcpwm_operator_reg_t;
 | 
			
		||||
 | 
			
		||||
typedef struct {
 | 
			
		||||
typedef struct mcpwm_dev_t {
 | 
			
		||||
    volatile mcpwm_clk_cfg_reg_t clk_cfg;
 | 
			
		||||
    volatile mcpwm_timer_regs_t timer[3];
 | 
			
		||||
    volatile mcpwm_timer_synci_cfg_reg_t timer_synci_cfg;
 | 
			
		||||
 
 | 
			
		||||
@@ -223,7 +223,6 @@
 | 
			
		||||
#define SOC_MCPWM_CAPTURE_TIMERS_PER_GROUP   (1)    ///< The number of capture timers that each group has
 | 
			
		||||
#define SOC_MCPWM_CAPTURE_CHANNELS_PER_TIMER (3)    ///< The number of capture channels that each capture timer has
 | 
			
		||||
#define SOC_MCPWM_GPIO_SYNCHROS_PER_GROUP    (3)    ///< The number of GPIO synchros that each group has
 | 
			
		||||
#define SOC_MCPWM_BASE_CLK_HZ       (160000000ULL)  ///< Base Clock frequency of 160MHz
 | 
			
		||||
 | 
			
		||||
/*-------------------------- MPU CAPS ----------------------------------------*/
 | 
			
		||||
//TODO: correct the caller and remove unsupported lines
 | 
			
		||||
 
 | 
			
		||||
@@ -1,16 +1,8 @@
 | 
			
		||||
// Copyright 2020 Espressif Systems (Shanghai) PTE LTD
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// 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.
 | 
			
		||||
/*
 | 
			
		||||
 * SPDX-FileCopyrightText: 2020-2022 Espressif Systems (Shanghai) CO LTD
 | 
			
		||||
 *
 | 
			
		||||
 * SPDX-License-Identifier: Apache-2.0
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "soc/soc.h"
 | 
			
		||||
#include "soc/mcpwm_periph.h"
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user