mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-22 20:57:25 +08:00
c784dd2ed8
git-svn-id: https://rt-thread.googlecode.com/svn/trunk@2306 bbd45198-f89e-11dd-88c7-29a3b14d5316
279 lines
14 KiB
C
279 lines
14 KiB
C
/*
|
|
*******************************************************************************
|
|
* Copyright(C) NEC Electronics Corporation 2010
|
|
* All rights reserved by NEC Electronics Corporation.
|
|
* This program should be used on your own responsibility.
|
|
* NEC Electronics Corporation assumes no responsibility for any losses
|
|
* incurred by customers or third parties arising from the use of this file.
|
|
*
|
|
* This device driver was created by Applilet3 for V850ES/Jx3
|
|
* 32-Bit Single-Chip Microcontrollers
|
|
* Filename: CG_timer.h
|
|
* Abstract: This file implements device driver for Timer module.
|
|
* APIlib: Applilet3 for V850ES/Jx3 V2.01 [20 Apr 2010]
|
|
* Device: uPD70F3746
|
|
* Compiler: IAR Systems ICCV850
|
|
* Creation date: 6/26/2010
|
|
*******************************************************************************
|
|
*/
|
|
|
|
#ifndef _MDTIMER_
|
|
#define _MDTIMER_
|
|
/*
|
|
*******************************************************************************
|
|
** Register bit define
|
|
*******************************************************************************
|
|
*/
|
|
/*
|
|
TMP control register 0 (TPnCTL0)
|
|
*/
|
|
/* TMP operation control (TPnCE) */
|
|
#define _00_TMP_OPERATION_DISABLE 0x00U /* disable internal operating clock operation (asynchronously reset TMPn) */
|
|
#define _80_TMP_OPERATION_ENABLE 0x80U /* enable internal operating clock operation */
|
|
/* Internal count clock selection (TPnCKS2 - TPnCKS0) */
|
|
#define _00_TMP_INTERNAL_CLOCK0 0x00U /* fXX */
|
|
#define _01_TMP_INTERNAL_CLOCK1 0x01U /* fXX/2 */
|
|
#define _02_TMP_INTERNAL_CLOCK2 0x02U /* fXX/2^2 */
|
|
#define _03_TMP_INTERNAL_CLOCK3 0x03U /* fXX/2^3 */
|
|
#define _04_TMP_INTERNAL_CLOCK4 0x04U /* fXX/2^4 */
|
|
#define _05_TMP_INTERNAL_CLOCK5 0x05U /* fXX/2^5 */
|
|
#define _06_TMP_INTERNAL_CLOCK6 0x06U /* fXX/2^6 or fXX/2^8 */
|
|
#define _07_TMP_INTERNAL_CLOCK7 0x07U /* fXX/2^7 or fXX/2^9 */
|
|
|
|
/*
|
|
TMP control register 1 (TPnCTL1)
|
|
*/
|
|
/* Software trigger control (TPnEST) */
|
|
#define _00_TMP_SOFTTRIGGER_OFF 0x00U /* no operation */
|
|
#define _40_TMP_SOFTTRIGGER_ON 0x40U /* in one-shot pulse mode: One-shot pulse software trigger */
|
|
/* in external trigger pulse output mode: Pulse output software trigger */
|
|
/* Count clock selection (TPnEEE) */
|
|
#define _00_TMP_INTERNAL_CLOCK 0x00U /* use the internal clock (clock selected with bits TPnCKS2 to TPnCKS0) */
|
|
#define _20_TMP_EXTERNAL_CLOCK 0x20U /* use the external clock from the TIPn0 input pin */
|
|
/* Timer mode selection (TPnMD2 - TPnMD0) */
|
|
#define _00_TMP_MODE_INTERVAL 0x00U /* interval timer mode */
|
|
#define _01_TMP_MODE_EXTERNALCOUNT 0x01U /* external event counter mode */
|
|
#define _02_TMP_MODE_EXTERNALTRG 0x02U /* external trigger pulse output mode */
|
|
#define _03_TMP_MODE_ONESHOT 0x03U /* one-shot pulse mode */
|
|
#define _04_TMP_MODE_PWM 0x04U /* PWM mode */
|
|
#define _05_TMP_MODE_FREERUNNING 0x05U /* free-running mode */
|
|
#define _06_TMP_MODE_PULSEMEASURE 0x06U /* pulse width measurement mode */
|
|
|
|
/*
|
|
TMP I/O control register 0 (TPnIOC0)
|
|
*/
|
|
/* TOPn0 pin output level setting (TPnOL0) */
|
|
#define _00_TMP_OUTPUT0_NORMAL 0x00U /* normal output */
|
|
#define _02_TMP_OUTPUT0_INVERTED 0x02U /* inverted output */
|
|
/* TOPn0 pin output setting (TPnOE0) */
|
|
#define _00_TMP_OUTPUT0_DISABLE 0x00U /* disable timer output */
|
|
#define _01_TMP_OUTPUT0_ENABLE 0x01U /* enable timer output (TOPn0 pin outputs pulses) */
|
|
/* TOPn1 pin output level setting (TPnOL1) */
|
|
#define _00_TMP_OUTPUT1_NORMAL 0x00U /* normal output */
|
|
#define _08_TMP_OUTPUT1_INVERTED 0x08U /* inverted output */
|
|
/* TOPn1 pin output setting (TPnOE1) */
|
|
#define _00_TMP_OUTPUT1_DISABLE 0x00U /* disable timer output */
|
|
#define _04_TMP_OUTPUT1_ENABLE 0x04U /* enable timer output (TOPn1 pin outputs pulses) */
|
|
|
|
/*
|
|
TMP I/O control register 1 (TPnIOC1)
|
|
*/
|
|
/* Capture trigger input signal (TIPn1 pin) valid edge setting (TPnIS3,TPnIS2) */
|
|
#define _00_TMP_INPUT1_EDGE_NONE 0x00U /* detect no edge (capture operation is invalid) */
|
|
#define _04_TMP_INPUT1_EDGE_RISING 0x04U /* detection of rising edge */
|
|
#define _08_TMP_INPUT1_EDGE_FALLING 0x08U /* detection of falling edge */
|
|
#define _0C_TMP_INPUT1_EDGE_BOTH 0x0CU /* detection of both edges */
|
|
/* Capture trigger input signal (TIPn0 pin) valid edge setting (TPnIS1,TPnIS0) */
|
|
#define _00_TMP_INPUT0_EDGE_NONE 0x00U /* detect no edge (capture operation is invalid) */
|
|
#define _01_TMP_INPUT0_EDGE_RISING 0x01U /* detection of rising edge */
|
|
#define _02_TMP_INPUT0_EDGE_FALLING 0x02U /* detection of falling edge */
|
|
#define _03_TMP_INPUT0_EDGE_BOTH 0x03U /* detection of both edges */
|
|
|
|
/*
|
|
TMP I/O control register 2 (TPnIOC2)
|
|
*/
|
|
/* External event count input signal (TIPn0 pin) valid edge setting (TPnEES1,TPnEES0) */
|
|
#define _00_TMP_EXTCOUNT_EDGE_NONE 0x00U /* detect no edge (external event count is invalid) */
|
|
#define _04_TMP_EXTCOUNT_EDGE_RISING 0x04U /* detection of rising edge */
|
|
#define _08_TMP_EXTCOUNT_EDGE_FALLING 0x08U /* detection of falling edge */
|
|
#define _0C_TMP_EXTCOUNT_EDGE_BOTH 0x0CU /* detection of both edges */
|
|
/* External trigger input signal (TIPn0 pin) valid edge setting (TPnETS1,TPnETS0) */
|
|
#define _00_TMP_EXTTRIGGER_EDGE_NONE 0x00U /* detect no edge (external trigger is invalid) */
|
|
#define _01_TMP_EXTTRIGGER_EDGE_RISING 0x01U /* detection of rising edge */
|
|
#define _02_TMP_EXTTRIGGER_EDGE_FALLING 0x02U /* detection of falling edge */
|
|
#define _03_TMP_EXTTRIGGER_EDGE_BOTH 0x03U /* detection of both edges */
|
|
|
|
/*
|
|
TMP option register 0 (TPnOPT0)
|
|
*/
|
|
/* TPnCCR1 register capture/compare selection (TPnCCS1) */
|
|
#define _00_TMP_CCR1_COMPARE 0x00U /* compare register */
|
|
#define _20_TMP_CCR1_CAPTURE 0x20U /* capture register */
|
|
/* TPnCCR0 register capture/compare selection (TPnCCS0) */
|
|
#define _00_TMP_CCR0_COMPARE 0x00U /* compare register */
|
|
#define _10_TMP_CCR0_CAPTURE 0x10U /* capture register */
|
|
/* TMPn overflow detection flag (TPnOVF) */
|
|
#define _01_TMP_OVERFLOW_OCCUR 0x01U /* overflow occurred */
|
|
#define _00_TMP_OVERFLOW_CLEAR 0x00U /* clear overflow */
|
|
|
|
/*
|
|
TMQ0 control register 0 (TQ0CTL0)
|
|
*/
|
|
/* TMQ operation control (TQ0CE) */
|
|
#define _00_TMQ_OPERATION_DISABLE 0x00U /* disable internal operating clock operation (asynchronously reset TMQ0) */
|
|
#define _80_TMQ_OPERATION_ENABLE 0x80U /* enable internal operating clock operation */
|
|
/* Internal count clock selection (TQ0CKS2 - TQ0CKS0) */
|
|
#define _00_TMQ_INTERNAL_CLOCK0 0x00U /* fXX */
|
|
#define _01_TMQ_INTERNAL_CLOCK1 0x01U /* fXX/2 */
|
|
#define _02_TMQ_INTERNAL_CLOCK2 0x02U /* fXX/2^2 */
|
|
#define _03_TMQ_INTERNAL_CLOCK3 0x03U /* fXX/2^3 */
|
|
#define _04_TMQ_INTERNAL_CLOCK4 0x04U /* fXX/2^4 */
|
|
#define _05_TMQ_INTERNAL_CLOCK5 0x05U /* fXX/2^5 */
|
|
#define _06_TMQ_INTERNAL_CLOCK6 0x06U /* fXX/2^6 */
|
|
#define _07_TMQ_INTERNAL_CLOCK7 0x07U /* fXX/2^7 */
|
|
|
|
/*
|
|
TMQ0 control register 1 (TQ0CTL1)
|
|
*/
|
|
/* Software trigger control (TQ0EST) */
|
|
#define _00_TMQ_SOFTTRIGGER_OFF 0x00U /* no operation */
|
|
#define _40_TMQ_SOFTTRIGGER_ON 0x40U /* in one-shot pulse mode: One-shot pulse software trigger */
|
|
/* in external trigger pulse output mode: Pulse output software trigger */
|
|
/* Count clock selection (TQ0EEE) */
|
|
#define _00_TMQ_INTERNAL_CLOCK 0x00U /* use the internal clock (clock selected with bits TQ0CKS2 to TQ0CKS0) */
|
|
#define _20_TMQ_EXTERNAL_CLOCK 0x20U /* use the external clock from the TIQ00 input pin */
|
|
/* Timer mode selection (TQ0MD2 - TQ0MD0) */
|
|
#define _00_TMQ_MODE_INTERVAL 0x00U /* interval timer mode */
|
|
#define _01_TMQ_MODE_EXTERNALCOUNT 0x01U /* external event counter mode */
|
|
#define _02_TMQ_MODE_EXTERNALTRG 0x02U /* external trigger pulse output mode */
|
|
#define _03_TMQ_MODE_ONESHOT 0x03U /* one-shot pulse mode */
|
|
#define _04_TMQ_MODE_PWM 0x04U /* PWM mode */
|
|
#define _05_TMQ_MODE_FREERUNNING 0x05U /* free-running mode */
|
|
#define _06_TMQ_MODE_PULSEMEASURE 0x06U /* pulse width measurement mode */
|
|
|
|
/*
|
|
TMQ0 I/O control register 0 (TQ0IOC0)
|
|
*/
|
|
/* TOQ00 pin output level setting (TQ0OL0) */
|
|
#define _00_TMQ_OUTPUT0_NORMAL 0x00U /* normal output */
|
|
#define _02_TMQ_OUTPUT0_INVERTED 0x02U /* inverted output */
|
|
/* TOQ00 pin output setting (TQ0OE0) */
|
|
#define _00_TMQ_OUTPUT0_DISABLE 0x00U /* disable timer output */
|
|
#define _01_TMQ_OUTPUT0_ENABLE 0x01U /* enable timer output (TOQ00 pin outputs pulses) */
|
|
/* TOQ01 pin output level setting (TQ0OL1) */
|
|
#define _00_TMQ_OUTPUT1_NORMAL 0x00U /* normal output */
|
|
#define _08_TMQ_OUTPUT1_INVERTED 0x08U /* inverted output */
|
|
/* TOQ01 pin output setting (TQ0OE1) */
|
|
#define _00_TMQ_OUTPUT1_DISABLE 0x00U /* disable timer output */
|
|
#define _04_TMQ_OUTPUT1_ENABLE 0x04U /* enable timer output (TOQ01 pin outputs pulses) */
|
|
/* TOQ02 pin output level setting (TQ0OL2) */
|
|
#define _00_TMQ_OUTPUT2_NORMAL 0x00U /* normal output */
|
|
#define _20_TMQ_OUTPUT2_INVERTED 0x20U /* inverted output */
|
|
/* TOQ02 pin output setting (TQ0OE2) */
|
|
#define _00_TMQ_OUTPUT2_DISABLE 0x00U /* disable timer output */
|
|
#define _10_TMQ_OUTPUT2_ENABLE 0x10U /* enable timer output (TOQ02 pin outputs pulses) */
|
|
/* TOQ03 pin output level setting (TQ0OL3) */
|
|
#define _00_TMQ_OUTPUT3_NORMAL 0x00U /* normal output */
|
|
#define _80_TMQ_OUTPUT3_INVERTED 0x80U /* inverted output */
|
|
/* TOQ03 pin output setting (TQ0OE3) */
|
|
#define _00_TMQ_OUTPUT3_DISABLE 0x00U /* disable timer output */
|
|
#define _40_TMQ_OUTPUT3_ENABLE 0x40U /* enable timer output (TOQ03 pin outputs pulses) */
|
|
|
|
/*
|
|
TMQ0 I/O control register 1 (TQ0IOC1)
|
|
*/
|
|
/* Capture trigger input signal (TIQ00 pin) valid edge setting (TQ0IS1,TQ0IS0) */
|
|
#define _00_TMQ_INPUT0_EDGE_NONE 0x00U /* detect no edge (capture operation is invalid) */
|
|
#define _01_TMQ_INPUT0_EDGE_RISING 0x01U /* detection of rising edge */
|
|
#define _02_TMQ_INPUT0_EDGE_FALLING 0x02U /* detection of falling edge */
|
|
#define _03_TMQ_INPUT0_EDGE_BOTH 0x03U /* detection of both edges */
|
|
/* Capture trigger input signal (TIQ01 pin) valid edge setting (TQ0IS3,TQ0IS2) */
|
|
#define _00_TMQ_INPUT1_EDGE_NONE 0x00U /* detect no edge (capture operation is invalid) */
|
|
#define _04_TMQ_INPUT1_EDGE_RISING 0x04U /* detection of rising edge */
|
|
#define _08_TMQ_INPUT1_EDGE_FALLING 0x08U /* detection of falling edge */
|
|
#define _0C_TMQ_INPUT1_EDGE_BOTH 0x0CU /* detection of both edges */
|
|
/* Capture trigger input signal (TIQ02 pin) valid edge setting (TQ0IS5,TQ0IS4) */
|
|
#define _00_TMQ_INPUT2_EDGE_NONE 0x00U /* detect no edge (capture operation is invalid) */
|
|
#define _10_TMQ_INPUT2_EDGE_RISING 0x10U /* detection of rising edge */
|
|
#define _20_TMQ_INPUT2_EDGE_FALLING 0x20U /* detection of falling edge */
|
|
#define _30_TMQ_INPUT2_EDGE_BOTH 0x30U /* detection of both edges */
|
|
/* Capture trigger input signal (TIQ03 pin) valid edge setting (TQ0IS7,TQ0IS6) */
|
|
#define _00_TMQ_INPUT3_EDGE_NONE 0x00U /* detect no edge (capture operation is invalid) */
|
|
#define _40_TMQ_INPUT3_EDGE_RISING 0x40U /* detection of rising edge */
|
|
#define _80_TMQ_INPUT3_EDGE_FALLING 0x80U /* detection of falling edge */
|
|
#define _C0_TMQ_INPUT3_EDGE_BOTH 0xC0U /* detection of both edges */
|
|
|
|
/*
|
|
TMQ0 I/O control register 2 (TQ0IOC2)
|
|
*/
|
|
/* External event count input signal (TIQ00 pin) valid edge setting (TQ0EES1,TQ0EES0) */
|
|
#define _00_TMQ_EXTCOUNT_EDGE_NONE 0x00U /* detect no edge (external event count is invalid) */
|
|
#define _04_TMQ_EXTCOUNT_EDGE_RISING 0x04U /* detection of rising edge */
|
|
#define _08_TMQ_EXTCOUNT_EDGE_FALLING 0x08U /* detection of falling edge */
|
|
#define _0C_TMQ_EXTCOUNT_EDGE_BOTH 0x0CU /* detection of both edges */
|
|
/* External trigger input signal (TIQ00 pin) valid edge setting (TQ0ETS1,TQ0ETS0) */
|
|
#define _00_TMQ_EXTTRIGGER_EDGE_NONE 0x00U /* detect no edge (external trigger is invalid) */
|
|
#define _01_TMQ_EXTTRIGGER_EDGE_RISING 0x01U /* detection of rising edge */
|
|
#define _02_TMQ_EXTTRIGGER_EDGE_FALLING 0x02U /* detection of falling edge */
|
|
#define _03_TMQ_EXTTRIGGER_EDGE_BOTH 0x03U /* detection of both edges */
|
|
|
|
/*
|
|
TMQ0 option register 0 (TQ0OPT0)
|
|
*/
|
|
/* TQ0CCR3 register capture/compare selection (TQ0CCS3) */
|
|
#define _00_TMQ_CCR3_COMPARE 0x00U /* compare register */
|
|
#define _80_TMQ_CCR3_CAPTURE 0x80U /* capture register */
|
|
/* TQ0CCR2 register capture/compare selection (TQ0CCS2) */
|
|
#define _00_TMQ_CCR2_COMPARE 0x00U /* compare register */
|
|
#define _40_TMQ_CCR2_CAPTURE 0x40U /* capture register */
|
|
/* TQ0CCR1 register capture/compare selection (TQ0CCS1) */
|
|
#define _00_TMQ_CCR1_COMPARE 0x00U /* compare register */
|
|
#define _20_TMQ_CCR1_CAPTURE 0x20U /* capture register */
|
|
/* TQ0CCR0 register capture/compare selection (TQ0CCS0) */
|
|
#define _00_TMQ_CCR0_COMPARE 0x00U /* compare register */
|
|
#define _10_TMQ_CCR0_CAPTURE 0x10U /* capture register */
|
|
/* TMQ0 overflow detection flag (TQ0OVF) */
|
|
#define _01_TMQ_OVERFLOW_OCCUR 0x01U /* overflow occurred */
|
|
#define _00_TMQ_OVERFLOW_CLEAR 0x00U /* clear overflow */
|
|
|
|
/*
|
|
TMM0 control register 0 (TM0CTL0)
|
|
*/
|
|
/* TMM0 operation control (TM0CE) */
|
|
#define _00_TMM_OPERATION_DISABLE 0x00U /* disable internal operating clock operation (asynchronously reset TMM0) */
|
|
#define _80_TMM_OPERATION_ENABLE 0x80U /* enable internal operating clock operation */
|
|
/* Internal count clock selection (TM0CKS2 - TM0CKS0) */
|
|
#define _00_TMM_INTERNAL_CLOCK0 0x00U /* fXX */
|
|
#define _01_TMM_INTERNAL_CLOCK1 0x01U /* fXX/2 */
|
|
#define _02_TMM_INTERNAL_CLOCK2 0x02U /* fXX/4 */
|
|
#define _03_TMM_INTERNAL_CLOCK3 0x03U /* fXX/64 */
|
|
#define _04_TMM_INTERNAL_CLOCK4 0x04U /* fXX/512 */
|
|
#define _05_TMM_INTERNAL_CLOCK5 0x05U /* INTWT */
|
|
#define _06_TMM_INTERNAL_CLOCK6 0x06U /* fR/8 */
|
|
#define _07_TMM_INTERNAL_CLOCK7 0x07U /* fXT */
|
|
/*
|
|
*******************************************************************************
|
|
** Macro define
|
|
*******************************************************************************
|
|
*/
|
|
/* TMP0 compare register 0 (TP0CCR0)*/
|
|
#define _9C3F_TMP0_CCR0_VALUE 0x9C3FU
|
|
enum TMChannel
|
|
{
|
|
TMCHANNEL0, TMCHANNEL1, TMCHANNEL2, TMCHANNEL3
|
|
};
|
|
/*
|
|
*******************************************************************************
|
|
** Function define
|
|
*******************************************************************************
|
|
*/
|
|
void TAB0_Init(void);
|
|
void TAB0_Start(void);
|
|
void TAB0_Stop(void);
|
|
MD_STATUS TAB0_ChangeTimerCondition(USHORT *array_reg, UCHAR array_num);
|
|
__interrupt void MD_INTTP0CC0(void);
|
|
|
|
/* Start user code for function. Do not edit comment generated here */
|
|
/* End user code. Do not edit comment generated here */
|
|
#endif
|