168 lines
4.3 KiB
C
168 lines
4.3 KiB
C
|
/********************************** (C) COPYRIGHT *******************************
|
|||
|
* File Name : CH58x_pwm.h
|
|||
|
* Author : WCH
|
|||
|
* Version : V1.2
|
|||
|
* Date : 2021/11/17
|
|||
|
* Description : head file(ch585/ch584)
|
|||
|
*********************************************************************************
|
|||
|
* Copyright (c) 2021 Nanjing Qinheng Microelectronics Co., Ltd.
|
|||
|
* Attention: This software (modified or not) and binary are used for
|
|||
|
* microcontroller manufactured by Nanjing Qinheng Microelectronics.
|
|||
|
*******************************************************************************/
|
|||
|
|
|||
|
#ifndef __CH58x_PWM_H__
|
|||
|
#define __CH58x_PWM_H__
|
|||
|
|
|||
|
#ifdef __cplusplus
|
|||
|
extern "C" {
|
|||
|
#endif
|
|||
|
|
|||
|
/**
|
|||
|
* @brief channel of PWM define
|
|||
|
*/
|
|||
|
#define CH_PWM4 0x01 // PWM4 ͨ<><CDA8>
|
|||
|
#define CH_PWM5 0x02 // PWM5 ͨ<><CDA8>
|
|||
|
#define CH_PWM6 0x04 // PWM6 ͨ<><CDA8>
|
|||
|
#define CH_PWM7 0x08 // PWM7 ͨ<><CDA8>
|
|||
|
#define CH_PWM8 0x10 // PWM8 ͨ<><CDA8>
|
|||
|
#define CH_PWM9 0x20 // PWM9 ͨ<><CDA8>
|
|||
|
#define CH_PWM10 0x40 // PWM10 ͨ<><CDA8>
|
|||
|
#define CH_PWM11 0x80 // PWM11 ͨ<><CDA8>
|
|||
|
|
|||
|
/**
|
|||
|
* @brief channel of PWM define
|
|||
|
*/
|
|||
|
typedef enum
|
|||
|
{
|
|||
|
High_Level = 0, // Ĭ<>ϵ͵<CFB5>ƽ<EFBFBD><C6BD><EFBFBD>ߵ<EFBFBD>ƽ<EFBFBD><C6BD>Ч
|
|||
|
Low_Level, // Ĭ<>ϸߵ<CFB8>ƽ<EFBFBD><C6BD><EFBFBD>͵<EFBFBD>ƽ<EFBFBD><C6BD>Ч
|
|||
|
} PWMX_PolarTypeDef;
|
|||
|
|
|||
|
/**
|
|||
|
* @brief Configuration PWM4_11 Cycle size
|
|||
|
*/
|
|||
|
typedef enum
|
|||
|
{
|
|||
|
PWMX_Cycle_256 = 0, // 256 <20><>PWMX<4D><58><EFBFBD><EFBFBD>
|
|||
|
PWMX_Cycle_255, // 255 <20><>PWMX<4D><58><EFBFBD><EFBFBD>
|
|||
|
PWMX_Cycle_128, // 128 <20><>PWMX<4D><58><EFBFBD><EFBFBD>
|
|||
|
PWMX_Cycle_127, // 127 <20><>PWMX<4D><58><EFBFBD><EFBFBD>
|
|||
|
PWMX_Cycle_64, // 64 <20><>PWMX<4D><58><EFBFBD><EFBFBD>
|
|||
|
PWMX_Cycle_63, // 63 <20><>PWMX<4D><58><EFBFBD><EFBFBD>
|
|||
|
} PWMX_CycleTypeDef;
|
|||
|
|
|||
|
/**
|
|||
|
* @brief PWM4-PWM11 ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param d - ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD> = d*Tsys
|
|||
|
*/
|
|||
|
#define PWMX_CLKCfg(d) (R8_PWM_CLOCK_DIV = d)
|
|||
|
|
|||
|
/**
|
|||
|
* @brief PWM4-PWM11<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param cyc - refer to PWMX_CycleTypeDef
|
|||
|
*/
|
|||
|
void PWMX_CycleCfg(PWMX_CycleTypeDef cyc);
|
|||
|
|
|||
|
/**
|
|||
|
* @brief PWM4-PWM9 16λ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param cyc - 16λ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*/
|
|||
|
void PWMX_16bit_CycleCfg(uint16_t cyc);
|
|||
|
|
|||
|
/**
|
|||
|
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD> PWM4 <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param d - <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*/
|
|||
|
#define PWM4_ActDataWidth(d) (R8_PWM4_DATA = d)
|
|||
|
|
|||
|
/**
|
|||
|
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD> PWM5 <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param d - <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*/
|
|||
|
#define PWM5_ActDataWidth(d) (R8_PWM5_DATA = d)
|
|||
|
|
|||
|
/**
|
|||
|
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD> PWM6 <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param d - <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*/
|
|||
|
#define PWM6_ActDataWidth(d) (R8_PWM6_DATA = d)
|
|||
|
|
|||
|
/**
|
|||
|
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD> PWM7 <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param d - <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*/
|
|||
|
#define PWM7_ActDataWidth(d) (R8_PWM7_DATA = d)
|
|||
|
|
|||
|
/**
|
|||
|
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD> PWM8 <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param d - <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*/
|
|||
|
#define PWM8_ActDataWidth(d) (R8_PWM8_DATA = d)
|
|||
|
|
|||
|
/**
|
|||
|
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD> PWM9 <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param d - <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*/
|
|||
|
#define PWM9_ActDataWidth(d) (R8_PWM9_DATA = d)
|
|||
|
|
|||
|
/**
|
|||
|
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD> PWM10 <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param d - <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*/
|
|||
|
#define PWM10_ActDataWidth(d) (R8_PWM10_DATA = d)
|
|||
|
|
|||
|
/**
|
|||
|
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD> PWM11 <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param d - <EFBFBD><EFBFBD>Ч<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*/
|
|||
|
#define PWM11_ActDataWidth(d) (R8_PWM11_DATA = d)
|
|||
|
|
|||
|
/**
|
|||
|
* @brief PWM4-PWM11ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param ch - select channel of pwm, refer to channel of PWM define
|
|||
|
* @param da - effective pulse width
|
|||
|
* @param pr - select wave polar, refer to PWMX_PolarTypeDef
|
|||
|
* @param s - control pwmx function, ENABLE or DISABLE
|
|||
|
*/
|
|||
|
void PWMX_ACTOUT(uint8_t ch, uint8_t da, PWMX_PolarTypeDef pr, FunctionalState s);
|
|||
|
|
|||
|
/**
|
|||
|
* @brief PWM4-PWM9 ͨ<EFBFBD><EFBFBD>16λ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param ch - select channel of pwm, refer to channel of PWM define
|
|||
|
* @param da - effective pulse width
|
|||
|
* @param pr - select wave polar, refer to PWMX_PolarTypeDef
|
|||
|
* @param s - control pwmx function, ENABLE or DISABLE
|
|||
|
*/
|
|||
|
void PWMX_16bit_ACTOUT(uint8_t ch, uint16_t da, PWMX_PolarTypeDef pr, FunctionalState s);
|
|||
|
|
|||
|
/**
|
|||
|
* @brief PWM <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ģʽ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*
|
|||
|
* @param ch - select group of PWM alternate output
|
|||
|
* RB_PWM4_5_STAG_EN - PWM4 <EFBFBD><EFBFBD> PWM5 ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
* RB_PWM6_7_STAG_EN - PWM6 <EFBFBD><EFBFBD> PWM7 ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
* RB_PWM8_9_STAG_EN - PWM8 <EFBFBD><EFBFBD> PWM9 ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
* RB_PWM10_11_STAG_EN - PWM10 <EFBFBD><EFBFBD> PWM11 ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
* @param s - control pwmx function, ENABLE or DISABLE
|
|||
|
*/
|
|||
|
void PWMX_AlterOutCfg(uint8_t ch, FunctionalState s);
|
|||
|
|
|||
|
#ifdef __cplusplus
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
#endif // __CH58x_PWM_H__
|