mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-16 06:19:24 +08:00
212 lines
4.9 KiB
C
212 lines
4.9 KiB
C
/*""FILE COMMENT""*******************************************************
|
|
* System Name : Timer TMR API for RX62Nxx
|
|
* File Name : r_pdl_tmr.h
|
|
* Version : 1.02
|
|
* Contents : Timer TMR API header
|
|
* Customer :
|
|
* Model :
|
|
* Order :
|
|
* CPU : RX
|
|
* Compiler : RXC
|
|
* OS : Nothing
|
|
* Programmer :
|
|
* Note :
|
|
************************************************************************
|
|
* Copyright, 2011. Renesas Electronics Corporation
|
|
* and Renesas Solutions Corporation
|
|
************************************************************************
|
|
* History : 2011.04.08
|
|
* : Ver 1.02
|
|
* : CS-5 release.
|
|
*""FILE COMMENT END""**************************************************/
|
|
|
|
#ifndef R_PDL_TMR_H
|
|
#define R_PDL_TMR_H
|
|
|
|
#include "r_pdl_common_defs_RX62Nxx.h"
|
|
|
|
/* Function prototypes */
|
|
bool R_TMR_Set(
|
|
uint8_t
|
|
);
|
|
bool R_TMR_CreateChannel(
|
|
uint8_t,
|
|
uint32_t,
|
|
uint8_t,
|
|
uint8_t,
|
|
uint8_t,
|
|
uint8_t,
|
|
void *,
|
|
void *,
|
|
void *,
|
|
uint8_t
|
|
);
|
|
bool R_TMR_CreateUnit(
|
|
uint8_t,
|
|
uint32_t,
|
|
uint8_t,
|
|
uint16_t,
|
|
uint16_t,
|
|
uint16_t,
|
|
void *,
|
|
void *,
|
|
void *,
|
|
uint8_t
|
|
);
|
|
bool R_TMR_CreatePeriodic(
|
|
uint8_t,
|
|
uint32_t,
|
|
float,
|
|
float,
|
|
void *,
|
|
void *,
|
|
uint8_t
|
|
);
|
|
bool R_TMR_CreateOneShot(
|
|
uint8_t,
|
|
uint32_t,
|
|
float,
|
|
void *,
|
|
uint8_t
|
|
);
|
|
bool R_TMR_Destroy(
|
|
uint8_t
|
|
);
|
|
bool R_TMR_ControlChannel(
|
|
uint8_t,
|
|
uint32_t,
|
|
uint8_t,
|
|
uint8_t,
|
|
uint8_t
|
|
);
|
|
bool R_TMR_ControlUnit(
|
|
uint8_t,
|
|
uint32_t,
|
|
uint16_t,
|
|
uint16_t,
|
|
uint16_t
|
|
);
|
|
bool R_TMR_ControlPeriodic(
|
|
uint8_t,
|
|
uint32_t,
|
|
float,
|
|
float
|
|
);
|
|
bool R_TMR_ReadChannel(
|
|
uint8_t,
|
|
uint8_t *,
|
|
uint8_t *,
|
|
uint8_t *,
|
|
uint8_t *
|
|
);
|
|
bool R_TMR_ReadUnit(
|
|
uint8_t,
|
|
uint8_t *,
|
|
uint16_t *,
|
|
uint16_t *,
|
|
uint16_t *
|
|
);
|
|
|
|
/* Pin selection */
|
|
#define PDL_TMR_PIN_TMR0_A 0x01u
|
|
#define PDL_TMR_PIN_TMR0_B 0x02u
|
|
#define PDL_TMR_PIN_TMR1_A 0x04u
|
|
#define PDL_TMR_PIN_TMR1_B 0x08u
|
|
#define PDL_TMR_PIN_TMR2_A 0x10u
|
|
#define PDL_TMR_PIN_TMR2_B 0x20u
|
|
#define PDL_TMR_PIN_TMR3_A 0x40u
|
|
#define PDL_TMR_PIN_TMR3_B 0x80u
|
|
|
|
/* Counter clock sources */
|
|
#define PDL_TMR_CLK_OFF 0x00000001ul
|
|
#define PDL_TMR_CLK_EXT_RISING 0x00000002ul
|
|
#define PDL_TMR_CLK_EXT_FALLING 0x00000004ul
|
|
#define PDL_TMR_CLK_EXT_BOTH 0x00000008ul
|
|
#define PDL_TMR_CLK_PCLK_DIV_1 0x00000010ul
|
|
#define PDL_TMR_CLK_PCLK_DIV_2 0x00000020ul
|
|
#define PDL_TMR_CLK_PCLK_DIV_8 0x00000040ul
|
|
#define PDL_TMR_CLK_PCLK_DIV_32 0x00000080ul
|
|
#define PDL_TMR_CLK_PCLK_DIV_64 0x00000100ul
|
|
#define PDL_TMR_CLK_PCLK_DIV_1024 0x00000200ul
|
|
#define PDL_TMR_CLK_PCLK_DIV_8192 0x00000400ul
|
|
#define PDL_TMR_CLK_TMR1_OVERFLOW 0x00000800ul
|
|
#define PDL_TMR_CLK_TMR3_OVERFLOW 0x00001000ul
|
|
#define PDL_TMR_CLK_TMR0_CM_A 0x00002000ul
|
|
#define PDL_TMR_CLK_TMR2_CM_A 0x00004000ul
|
|
|
|
/* A/D trigger control */
|
|
#define PDL_TMR_ADC_TRIGGER_DISABLE 0x00008000ul
|
|
#define PDL_TMR_ADC_TRIGGER_ENABLE 0x00010000ul
|
|
|
|
/* Counter clearing options */
|
|
#define PDL_TMR_CLEAR_DISABLE 0x00020000ul
|
|
#define PDL_TMR_CLEAR_CM_A 0x00040000ul
|
|
#define PDL_TMR_CLEAR_CM_B 0x00080000ul
|
|
#define PDL_TMR_CLEAR_RESET_RISING 0x00100000ul
|
|
#define PDL_TMR_CLEAR_RESET_HIGH 0x00200000ul
|
|
|
|
/* DTC CMA trigger control */
|
|
#define PDL_TMR_CM_A_DTC_TRIGGER_DISABLE 0x00400000ul
|
|
#define PDL_TMR_CM_A_DTC_TRIGGER_ENABLE 0x00800000ul
|
|
|
|
/* DTC CMB trigger control */
|
|
#define PDL_TMR_CM_B_DTC_TRIGGER_DISABLE 0x01000000ul
|
|
#define PDL_TMR_CM_B_DTC_TRIGGER_ENABLE 0x02000000ul
|
|
|
|
/* Output control options */
|
|
#define PDL_TMR_OUTPUT_IGNORE_CM_A 0x01u
|
|
#define PDL_TMR_OUTPUT_LOW_CM_A 0x02u
|
|
#define PDL_TMR_OUTPUT_HIGH_CM_A 0x04u
|
|
#define PDL_TMR_OUTPUT_INV_CM_A 0x08u
|
|
#define PDL_TMR_OUTPUT_IGNORE_CM_B 0x10u
|
|
#define PDL_TMR_OUTPUT_LOW_CM_B 0x20u
|
|
#define PDL_TMR_OUTPUT_HIGH_CM_B 0x40u
|
|
#define PDL_TMR_OUTPUT_INV_CM_B 0x80u
|
|
|
|
/* Channels and units */
|
|
#define PDL_TMR_TMR0 0
|
|
#define PDL_TMR_TMR1 1
|
|
#define PDL_TMR_TMR2 2
|
|
#define PDL_TMR_TMR3 3
|
|
#define PDL_TMR_UNIT0 4
|
|
#define PDL_TMR_UNIT1 5
|
|
|
|
/* Period or frequency selection */
|
|
#define PDL_TMR_PERIOD 0x00000001ul
|
|
#define PDL_TMR_FREQUENCY 0x00000002ul
|
|
|
|
/* Output pin control */
|
|
#define PDL_TMR_OUTPUT_HIGH 0x00000004ul
|
|
#define PDL_TMR_OUTPUT_LOW 0x00000008ul
|
|
#define PDL_TMR_OUTPUT_OFF 0x00000010ul
|
|
#define PDL_TMR_OUTPUT_ENABLE 0x00000020ul
|
|
#define PDL_TMR_OUTPUT_DISABLE 0x00000040ul
|
|
|
|
/* ADC trigger control */
|
|
#define PDL_TMR_ADC_TRIGGER_ON 0x00000080ul
|
|
#define PDL_TMR_ADC_TRIGGER_OFF 0x00000100ul
|
|
|
|
/* Pulse DTC trigger control */
|
|
#define PDL_TMR_PULSE_DTC_TRIGGER_DISABLE 0x00000200ul
|
|
#define PDL_TMR_PULSE_DTC_TRIGGER_ENABLE 0x00000400ul
|
|
|
|
/* Period DTC trigger control */
|
|
#define PDL_TMR_PERIOD_DTC_TRIGGER_DISABLE 0x00000800ul
|
|
#define PDL_TMR_PERIOD_DTC_TRIGGER_ENABLE 0x00001000ul
|
|
|
|
/* CPU control */
|
|
#define PDL_TMR_CPU_ON 0x00002000ul
|
|
#define PDL_TMR_CPU_OFF 0x00004000ul
|
|
|
|
/* Timer counter control */
|
|
#define PDL_TMR_STOP 0x00008000ul
|
|
#define PDL_TMR_START 0x00010000ul
|
|
|
|
/* Register selections */
|
|
#define PDL_TMR_COUNTER 0x00020000ul
|
|
#define PDL_TMR_TIME_CONSTANT_A 0x00040000ul
|
|
#define PDL_TMR_TIME_CONSTANT_B 0x00080000ul
|
|
|
|
#endif
|
|
/* End of file */
|