2005-04-16 15:20:36 -07:00
/*********************************************************************
*
* Filename : timer . h
* Version :
* Description :
* Status : Experimental .
* Author : Dag Brattli < dagb @ cs . uit . no >
* Created at : Sat Aug 16 00 : 59 : 29 1997
* Modified at : Thu Oct 7 12 : 25 : 24 1999
* Modified by : Dag Brattli < dagb @ cs . uit . no >
*
* Copyright ( c ) 1997 , 1998 - 1999 Dag Brattli < dagb @ cs . uit . no > ,
* All Rights Reserved .
* Copyright ( c ) 2000 - 2002 Jean Tourrilhes < jt @ hpl . hp . com >
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation ; either version 2 of
* the License , or ( at your option ) any later version .
*
* Neither Dag Brattli nor University of Troms <EFBFBD> admit liability nor
* provide warranty for any of this software . This material is
* provided " AS-IS " and at no charge .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# ifndef TIMER_H
# define TIMER_H
# include <linux/timer.h>
2006-12-03 23:15:30 -05:00
# include <linux/jiffies.h>
2005-04-16 15:20:36 -07:00
# include <asm/param.h> /* for HZ */
# include <net/irda/irda.h>
/* A few forward declarations (to make compiler happy) */
struct irlmp_cb ;
struct irlap_cb ;
struct lsap_cb ;
struct lap_cb ;
/*
* Timeout definitions , some defined in IrLAP 6.13 .5 - p . 92
*/
# define POLL_TIMEOUT (450*HZ / 1000) /* Must never exceed 500 ms */
# define FINAL_TIMEOUT (500*HZ / 1000) /* Must never exceed 500 ms */
/*
* Normally twice of p - timer . Note 3 , IrLAP 6.3 .11 .2 - p . 60 suggests
* at least twice duration of the P - timer .
*/
# define WD_TIMEOUT (POLL_TIMEOUT*2)
# define MEDIABUSY_TIMEOUT (500*HZ / 1000) /* 500 msec */
# define SMALLBUSY_TIMEOUT (100*HZ / 1000) /* 100 msec - IrLAP 6.13.4 */
/*
* Slot timer must never exceed 85 ms , and must always be at least 25 ms ,
* suggested to 75 - 85 msec by IrDA lite . This doesn ' t work with a lot of
* devices , and other stackes uses a lot more , so it ' s best we do it as well
* ( Note : this is the default value and sysctl overides it - Jean II )
*/
# define SLOT_TIMEOUT (90*HZ / 1000)
/*
* The latest discovery frame ( XID ) is longer due to the extra discovery
* information ( hints , device name . . . ) . This is its extra length .
* We use that when setting the query timeout . Jean II
*/
# define XIDEXTRA_TIMEOUT (34*HZ / 1000) /* 34 msec */
# define WATCHDOG_TIMEOUT (20*HZ) /* 20 sec */
typedef void ( * TIMER_CALLBACK ) ( void * ) ;
static inline void irda_start_timer ( struct timer_list * ptimer , int timeout ,
void * data , TIMER_CALLBACK callback )
{
ptimer - > function = ( void ( * ) ( unsigned long ) ) callback ;
ptimer - > data = ( unsigned long ) data ;
/* Set new value for timer (update or add timer).
* We use mod_timer ( ) because it ' s more efficient and also
* safer with respect to race conditions - Jean II */
mod_timer ( ptimer , jiffies + timeout ) ;
}
void irlap_start_slot_timer ( struct irlap_cb * self , int timeout ) ;
void irlap_start_query_timer ( struct irlap_cb * self , int S , int s ) ;
void irlap_start_final_timer ( struct irlap_cb * self , int timeout ) ;
void irlap_start_wd_timer ( struct irlap_cb * self , int timeout ) ;
void irlap_start_backoff_timer ( struct irlap_cb * self , int timeout ) ;
void irlap_start_mbusy_timer ( struct irlap_cb * self , int timeout ) ;
void irlap_stop_mbusy_timer ( struct irlap_cb * ) ;
void irlmp_start_watchdog_timer ( struct lsap_cb * , int timeout ) ;
void irlmp_start_discovery_timer ( struct irlmp_cb * , int timeout ) ;
void irlmp_start_idle_timer ( struct lap_cb * , int timeout ) ;
void irlmp_stop_idle_timer ( struct lap_cb * self ) ;
# endif