📄 timer.c
字号:
}
} else {
return (uint32)(OPERATE_FAIL); /* 返回参数错误 */
}
#if __TIMER_CAP_GPIO > 0
/*
* 调用内部函数,初始化捕获引脚
*/
return (__timerCapGpioInit(GpTimerStruInfoData[uiID],uiParam[CapN],NULL));
#else
return (uint32)(OPERATE_SUCCESS);
#endif
}
/*********************************************************************************************************
** Function name: timerGetCap
** Descriptions: 获取选定捕获寄存器值
**
** Input parameters: uiID --部件设备号。0-Time0;1-Time1
** pcArg --字符串输入指针参数,输入参数格式为:关键字0=值0[空格]关键字1=值1[空格]......
** 关键字 :CapGetN :0~3分别表示通道CR0至通道CR3
** pRsv --保留指针参数,可输入NULL.
** Returned value: 操作失败 --OPERATE_FAIL
** 操作成功 --返回所选择的捕获通道数值.
** Using example : char pcArg[] = "CapGetN=0";
** timerGetCap( 0, pcArg, 0 );
** Notice: 设备操作失败的原因是输入不正确的定时器号或参数
*********************************************************************************************************/
uint32 timerGetCap (uint32 uiID,
char *pcArg,
void *pRsv)
{
volatile uint32 uiOffsetBase;
volatile uint32 *puiBaseAddr;
uint32 uiParam[1]={0};
if ((uiID >= __TIMER_MAX_NUM) | (pcArg == NULL)) { /* 检查参数有效性 */
return (uint32)(OPERATE_FAIL);
}
pRsv = pRsv ; /* 防止编译器警告 */
ImpCmd(Tab_GetCrN, pcArg, uiParam); /* 获取字符参数 */
/*
* 参数过滤处理
*/
if (uiParam[CapGetN] > 4) {
return (uint32)(OPERATE_FAIL);
}
/*
* 初始化结构体信息,以防止没有先进行计数功能初始化,结构体信息为空.
*/
__timerInit(uiID,pRsv);
uiOffsetBase = GpTimerStruInfoData[uiID]->uiOffsetBase; /* 必须在内部初始化后才赋地址值*/
puiBaseAddr = GpTimerStruInfoData[uiID]->puiAddrBase;
switch (uiParam[CapGetN]) {
case 0:
return (puiBaseAddr[__B_TIMER_CR0 << uiOffsetBase]); /* CR0:返回给调用函数 计数值 */
case 1:
return (puiBaseAddr[__B_TIMER_CR1 << uiOffsetBase]); /* CR1:返回给调用函数 计数值 */
case 2:
return (puiBaseAddr[__B_TIMER_CR2 << uiOffsetBase]); /* CR2:返回给调用函数 计数值 */
case 3:
return (puiBaseAddr[__B_TIMER_CR3 << uiOffsetBase]); /* CR3:返回给调用函数 计数值 */
default:
{return (uint32)(OPERATE_FAIL);}
}
}
/*********************************************************************************************************
** Function name: timerCountInit( )
** Descriptions: 定时器外部计数功能初始化
**
** Input parameters: uiID --部件设备号。0-Time0;1-Time1
** pcArg --字符串输入指针参数,输入参数格式为:关键字0=值0[空格]关键字1=值1[空格]......
** 关键字 :CntN :计数采样通道选择,0~3分别表示通道0(CAPn.0)至通道3(CAPn.3)
** CntMode :计数控制模式, 0表示CAP输入的上升沿递增计数,
** 1表示CAP输入的下降沿递增计数,
** 2表示CAP输入的上下沿都可以进行计数
** pRsv --保留指针参数,可输入NULL.
** Returned value: OPERATE_FAIL -- 操作失败
** OPERATE_SUCCESS -- 操作成功
** Using example : char pcArg[] = "CntN=2 CntMode=1";
** timerCountInit( 0, pcArg, NULL );
** Notice: 设备操作失败的原因是输入不正确的定时器号
** Modify Date: 2007-10-31 修改程序存在缺陷,没有对捕获功能进行配置,故无法正确配置.现已加上对CCR操作.
*********************************************************************************************************/
uint32 timerCountInit (uint32 uiID,
char *pcArg,
void *pRsv)
{
volatile uint32 uiOffsetBase;
volatile uint32 *puiBaseAddr;
uint32 uiParam[3]={0,0,1};
if ((uiID >= __TIMER_MAX_NUM) | (pcArg == NULL)) { /* 检查参数有效性 */
return (uint32)(OPERATE_FAIL);
}
pRsv = pRsv ; /* 防止编译器警告 */
ImpCmd(Tab_COUNT, pcArg, uiParam); /* 获取字符参数 */
/*
* 参数过滤处理
*/
if ((uiParam[CntN] > 4) || (uiParam[CntMode] > 3)) {
return (uint32)(OPERATE_FAIL);
}
/*
* 初始化器件结构体
*/
__timerInit(uiID,pRsv);
IRQDisable(); /* 关IRQ中断 */
GpTimerStruInfoData[uiID]->uiTimerFun[__TIEMR_COUNT] = 1; /* 标志使用了计数功能 */
uiOffsetBase = GpTimerStruInfoData[uiID]->uiOffsetBase; /* 必须在内部初始化后才赋地址值*/
puiBaseAddr = GpTimerStruInfoData[uiID]->puiAddrBase;
IRQEnable(); /* 开IRQ中断 */
/*
* 计数功能设置
*/
puiBaseAddr[__B_TIMER_CTCR << uiOffsetBase] &= (~(0x03 << 0) /* 将计数控制寄存器 模式位清零 */
| (0x03 << 2)); /* 将计数控制寄存器 通道位清零 */
puiBaseAddr[__B_TIMER_CTCR << uiOffsetBase] |= (uiParam[CntN] << 2);/* 设置对应的计数输入通道号 */
puiBaseAddr[__B_TIMER_CCR << uiOffsetBase ] &= (~(0x07 << uiParam[CntN]));
/* CCR对应通道参数设置位清零 */
puiBaseAddr[__B_TIMER_CCR << uiOffsetBase ] |= (uiParam[CountInt] << ((uiParam[CntN] * 3) + 2));
/* 选择捕获中断 */
switch (uiParam[CntMode]) { /* 设置对应计数输入通道采样边沿*/
case __TIME_UP:
puiBaseAddr[__B_TIMER_CTCR << uiOffsetBase] |= (0x01 << 0);
puiBaseAddr[__B_TIMER_CCR << uiOffsetBase] |= (0x01 << ((uiParam[CntN] * 3) + 0));
break;
case __TIME_DOWN:
puiBaseAddr[__B_TIMER_CTCR << uiOffsetBase] |= (0x02 << 0);
puiBaseAddr[__B_TIMER_CCR << uiOffsetBase] |= (0x01 << ((uiParam[CntN] * 3) + 1));
break;
case __TIME_DOUBLE:
puiBaseAddr[__B_TIMER_CTCR << uiOffsetBase] |= (0x03 << 0);
puiBaseAddr[__B_TIMER_CCR << uiOffsetBase] |= (0x03 << ((uiParam[CntN] * 3) + 0));
break;
default:
{return (uint32)(OPERATE_FAIL);} /* 返回参数错误 */
}
#if __TIMER_CAP_GPIO > 0
/*
* 调用内部函数,初始化捕获引脚
*/
return (__timerCapGpioInit(GpTimerStruInfoData[uiID],uiParam[CntN],NULL));
#else
return (uint32)(OPERATE_SUCCESS);
#endif
}
/*********************************************************************************************************
** Function name: timerGetCount
** Descriptions: 获取定时器对外部计数值
**
** Input parameters: uiID --部件设备号。0-Time0;1-Time1
** pRsv --保留指针参数,可输入NULL.
** Returned value: OPERATE_FAIL -- 操作失败
** OPERATE_SUCCESS -- 操作成功
** Using example : count = timerGetCount( 0, NULL ); 其中,count为一个uint32整型, 保存timerGetCount返回值
** Notice: 设备操作失败的原因是输入不正确的定时器号或参数
*********************************************************************************************************/
uint32 timerGetCount (uint32 uiID, void *pRsv)
{
volatile uint32 uiOffsetBase;
volatile uint32 *puiBaseAddr;
if (uiID >= __TIMER_MAX_NUM) { /* 检查参数是否有效 */
return (uint32)(OPERATE_FAIL);
}
pRsv = pRsv ; /* 防止编译器警告 */
/*
* 初始化结构体信息,以防止没有先进行计数功能初始化,结构体信息为空.
*/
__timerInit(uiID,pRsv);
uiOffsetBase = GpTimerStruInfoData[uiID]->uiOffsetBase; /* 必须在内部初始化后才赋地址值*/
puiBaseAddr = GpTimerStruInfoData[uiID]->puiAddrBase;
return (puiBaseAddr[__B_TIMER_TC << uiOffsetBase]); /* 返回计数器中计数值 */
}
/*********************************************************************************************************
** Function name: timer0ISR
** Descriptions: 库函数默认的中断服务函数,进行timer0中断处理,该函数挂接了钩子函数可处理用户任务
** Input parameters: NONE
** Output parameters: NONE
** Returned value: NONE
** Notice: 在调用中断服务函数之前,必须先有相关功能设置的初始化操作!
*********************************************************************************************************/
void timer0ISR (void)
{
volatile uint32 uiOffsetBase;
volatile uint32 *puiBaseAddr;
uiOffsetBase = GpTimerStruInfoData[TIME_0]->uiOffsetBase;
puiBaseAddr = GpTimerStruInfoData[TIME_0]->puiAddrBase;
time0Hook(); /* 调用钩子函数 */
*(uint32*)(puiBaseAddr + (__B_TIMER_IR << uiOffsetBase))= 0xFF; /* 清除定时器中断标志 */
VICVectAddr = 0x00; /* 通知内核中断处理结束 */
}
/*********************************************************************************************************
** Function name: timer1Irq
** Descriptions: 库函数默认的中断服务函数,进行timer1中断处理,该函数挂接了钩子函数可处理用户任务
** Input parameters: NONE
** Output parameters: NONE
** Returned value: NONE
** Notice: 在调用中断服务函数之前,必须先有相关功能设置的初始化操作!
*********************************************************************************************************/
void timer1ISR (void)
{
volatile uint32 uiOffsetBase;
volatile uint32 *puiBaseAddr;
uiOffsetBase = GpTimerStruInfoData[TIME_1]->uiOffsetBase;
puiBaseAddr = GpTimerStruInfoData[TIME_1]->puiAddrBase;
time0Hook(); /* 调用钩子函数 */
*(uint32*)(puiBaseAddr + (__B_TIMER_IR << uiOffsetBase))= 0xFF; /* 清除定时器中断标志 */
VICVectAddr = 0x00; /* 通知内核中断处理结束 */
}
#endif /* 定时器软件包裁剪 */
/*********************************************************************************************************
END of file
*********************************************************************************************************/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -