⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 timer.c

📁 philips arm7 lpc2103的常用功能的库函数第二部分
💻 C
📖 第 1 页 / 共 4 页
字号:
        }

     } 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 + -