mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-18 18:03:31 +08:00
206 lines
9.4 KiB
C
206 lines
9.4 KiB
C
/*******************************************************************************
|
|
* Copyright (C) 2020, Huada Semiconductor Co., Ltd. All rights reserved.
|
|
*
|
|
* This software component is licensed by HDSC under BSD 3-Clause license
|
|
* (the "License"); You may not use this file except in compliance with the
|
|
* License. You may obtain a copy of the License at:
|
|
* opensource.org/licenses/BSD-3-Clause
|
|
*/
|
|
/******************************************************************************/
|
|
/** \file hc32f460_emb.h
|
|
**
|
|
** A detailed description is available at
|
|
** @link EMBGroup EMB description @endlink
|
|
**
|
|
** - 2018-11-24 CDT First version for Device Driver Library of EMB.
|
|
**
|
|
******************************************************************************/
|
|
#ifndef __HC32F460_EMB_H__
|
|
#define __HC32F460_EMB_H__
|
|
|
|
/*******************************************************************************
|
|
* Include files
|
|
******************************************************************************/
|
|
#include "hc32_common.h"
|
|
#include "ddl_config.h"
|
|
|
|
#if (DDL_EMB_ENABLE == DDL_ON)
|
|
|
|
/* C binding of definitions if building with C++ compiler */
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \defgroup EMBGroup Emergency Brake(EMB)
|
|
**
|
|
******************************************************************************/
|
|
//@{
|
|
|
|
/*******************************************************************************
|
|
* Global type definitions ('typedef')
|
|
******************************************************************************/
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief EMB status enumeration
|
|
******************************************************************************/
|
|
typedef enum en_emb_status
|
|
{
|
|
EMBFlagPortIn = 0u, ///< EMB port in brake flag
|
|
EMBFlagPWMSame = 1u, ///< EMB PWM same brake flag
|
|
EMBFlagCmp = 2u, ///< EMB CMP brake flag
|
|
EMBFlagOSCFail = 3u, ///< EMB oscillator fail brake flag
|
|
EMBPortInState = 4u, ///< EMB port in state
|
|
EMBPWMState = 5u, ///< EMB PWM same state
|
|
} en_emb_status_t;
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief EMB status clear(recover) enumeration
|
|
******************************************************************************/
|
|
typedef enum en_emb_status_clr
|
|
{
|
|
EMBPortInFlagClr = 0u, ///< EMB port in brake flag clear
|
|
EMBPWMSameFlagCLr = 1u, ///< EMB PWM same brake flag clear
|
|
EMBCmpFlagClr = 2u, ///< EMB CMP brake flag clear
|
|
EMBOSCFailFlagCLr = 3u, ///< EMB oscillator fail brake flag clear
|
|
} en_emb_status_clr_t;
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief EMB irq enumeration
|
|
******************************************************************************/
|
|
typedef enum en_emb_irq_type
|
|
{
|
|
PORTBrkIrq = 0u, ///< EMB port brake interrupt
|
|
PWMSmBrkIrq = 1u, ///< EMB PWM same brake interrupt
|
|
CMPBrkIrq = 2u, ///< EMB CMP brake interrupt
|
|
OSCFailBrkIrq = 3u, ///< EMB oscillator fail brake interrupt
|
|
} en_emb_irq_type_t;
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief EMB port in filter enumeration
|
|
******************************************************************************/
|
|
typedef enum en_emb_port_filter
|
|
{
|
|
EMBPortFltDiv0 = 0u, ///< EMB port in filter with PCLK clock
|
|
EMBPortFltDiv8 = 1u, ///< EMB port in filter with PCLK/8 clock
|
|
EMBPortFltDiv32 = 2u, ///< EMB port in filter with PCLK/32 clock
|
|
EMBPortFltDiv128 = 3u, ///< EMB port in filter with PCLK/128 clock
|
|
} en_emb_port_filter_t;
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief EMB CR0 for timer6 config
|
|
** \note
|
|
******************************************************************************/
|
|
typedef struct stc_emb_ctrl_timer6
|
|
{
|
|
bool bEnPortBrake; ///< Enable port brake
|
|
bool bEnCmp1Brake; ///< Enable CMP1 brake
|
|
bool bEnCmp2Brake; ///< Enable CMP2 brake
|
|
bool bEnCmp3Brake; ///< Enable CMP3 brake
|
|
bool bEnOSCFailBrake; ///< Enable OSC fail brake
|
|
bool bEnTimer61PWMSBrake; ///< Enable tiemr61 PWM same brake
|
|
bool bEnTimer62PWMSBrake; ///< Enable tiemr62 PWM same brake
|
|
bool bEnTimer63PWMSBrake; ///< Enable tiemr63 PWM same brake
|
|
en_emb_port_filter_t enPortInFltClkSel; ///< Port in filter clock selection
|
|
bool bEnPorInFlt; ///< Enable port in filter
|
|
bool bEnPortInLevelSel_Low; ///< Poit input active level 1: LowLevel 0:HighLevel
|
|
}stc_emb_ctrl_timer6_t;
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief EMB CR1~3 for timer4x config
|
|
** \note
|
|
******************************************************************************/
|
|
typedef struct stc_emb_ctrl_timer4
|
|
{
|
|
bool bEnPortBrake; ///< Enable port brake
|
|
bool bEnCmp1Brake; ///< Enable CMP1 brake
|
|
bool bEnCmp2Brake; ///< Enable CMP2 brake
|
|
bool bEnCmp3Brake; ///< Enable CMP3 brake
|
|
bool bEnOSCFailBrake; ///< Enable OS fail brake
|
|
bool bEnTimer4xWHLSammeBrake; ///< Enable tiemr4x PWM WH WL same brake
|
|
bool bEnTimer4xVHLSammeBrake; ///< Enable tiemr4x PWM VH VL same brake
|
|
bool bEnTimer4xUHLSammeBrake; ///< Enable tiemr4x PWM UH UL same brake
|
|
en_emb_port_filter_t enPortInFltClkSel; ///< Port in filter clock selection
|
|
bool bEnPorInFlt; ///< Enable port in filter
|
|
bool bEnPortInLevelSel_Low; ///< Poit input active level 1: LowLevel 0:HighLevel
|
|
}stc_emb_ctrl_timer4_t;
|
|
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief EMB PWM level detect timer6 config
|
|
** \note
|
|
******************************************************************************/
|
|
typedef struct stc_emb_pwm_level_timer6
|
|
{
|
|
bool bEnTimer61HighLevelDect; ///< Enable tiemr61 active detected level 1:HighLevel 0:LowLevel
|
|
bool bEnTimer62HighLevelDect; ///< Enable tiemr62 active detected level 1:HighLevel 0:LowLevel
|
|
bool bEnTimer63HighLevelDect; ///< Enable tiemr63 active detected level 1:HighLevel 0:LowLevel
|
|
}stc_emb_pwm_level_timer6_t;
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief EMB PWM level detect timer4x config
|
|
** \note
|
|
******************************************************************************/
|
|
typedef struct stc_emb_pwm_level_timer4
|
|
{
|
|
bool bEnUHLPhaseHighLevelDect; ///< Enable tiemr4x UH UL active detected level 1:HighLevel 0:LowLevel
|
|
bool bEnVHLPhaseHighLevelDect; ///< Enable tiemr4x VH VL active detected level 1:HighLevel 0:LowLevel
|
|
bool bEnWHLphaseHighLevelDect; ///< Enable tiemr4x WH WL active detected level 1:HighLevel 0:LowLevel
|
|
}stc_emb_pwm_level_timer4_t;
|
|
|
|
/*******************************************************************************
|
|
* Global pre-processor symbols/macros ('#define')
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Global variable definitions ('extern')
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
Global function prototypes (definition in C source)
|
|
******************************************************************************/
|
|
/* IRQ config */
|
|
en_result_t EMB_ConfigIrq(M4_EMB_TypeDef *EMBx,
|
|
en_emb_irq_type_t enEMBIrq,
|
|
bool bEn);
|
|
/* Get status(flag) */
|
|
bool EMB_GetStatus(M4_EMB_TypeDef *EMBx, en_emb_status_t enStatus);
|
|
/* Status(flag) clear (recover) */
|
|
en_result_t EMB_ClrStatus(M4_EMB_TypeDef *EMBx,
|
|
en_emb_status_clr_t enStatusClr);
|
|
/* Control Register(CTL) config for timer6 */
|
|
en_result_t EMB_Config_CR_Timer6(const stc_emb_ctrl_timer6_t* pstcEMBConfigCR);
|
|
/* Control Register(CTL) config for timer4 */
|
|
en_result_t EMB_Config_CR_Timer4(M4_EMB_TypeDef *EMBx,
|
|
const stc_emb_ctrl_timer4_t* pstcEMBConfigCR);
|
|
/* PWM level detect (short detection) selection config for timer6 */
|
|
en_result_t EMB_PWMLv_Timer6(const stc_emb_pwm_level_timer6_t* pstcEMBPWMlv);
|
|
/* PWM level detect (short detection) selection config for timer4 */
|
|
en_result_t EMB_PWMLv_Timer4(M4_EMB_TypeDef *EMBx,
|
|
const stc_emb_pwm_level_timer4_t* pstcEMBPWMlv);
|
|
/* Software brake */
|
|
en_result_t EMB_SwBrake(M4_EMB_TypeDef *EMBx, bool bEn);
|
|
|
|
//@} // EMBGroup
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* DDL_EMB_ENABLE */
|
|
|
|
#endif /* __HC32F460_EMB_H__ */
|
|
|
|
/*******************************************************************************
|
|
* EOF (not truncated)
|
|
******************************************************************************/
|