00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026 #ifndef TIMER_H
00027 #define TIMER_H
00028
00029 #include <linux/netdevice.h>
00030
00031 #include <asm/param.h>
00032
00033 #include <net/irda/irda.h>
00034 #include <net/irda/irmod.h>
00035 #include <net/irda/irlap.h>
00036 #include <net/irda/irlmp.h>
00037 #include <net/irda/irda_device.h>
00038
00039
00040
00041
00042 #define POLL_TIMEOUT (450*HZ/1000)
00043 #define FINAL_TIMEOUT (500*HZ/1000)
00044
00045
00046
00047
00048
00049 #define WD_TIMEOUT (POLL_TIMEOUT*2)
00050 #define MEDIABUSY_TIMEOUT (500*HZ/1000)
00051
00052
00053
00054
00055
00056
00057 #define SLOT_TIMEOUT (90*HZ/1000)
00058
00059
00060
00061
00062
00063 #define QUERY_TIMEOUT (HZ/10)
00064
00065 #define WATCHDOG_TIMEOUT (20*HZ)
00066
00067 typedef void (*TIMER_CALLBACK)(void *);
00068
00069 void irda_start_timer(struct timer_list *ptimer, int timeout, void* data,
00070 TIMER_CALLBACK callback);
00071
00072 inline void irlap_start_slot_timer(struct irlap_cb *self, int timeout);
00073 inline void irlap_start_query_timer(struct irlap_cb *self, int timeout);
00074 inline void irlap_start_final_timer(struct irlap_cb *self, int timeout);
00075 inline void irlap_start_wd_timer(struct irlap_cb *self, int timeout);
00076 inline void irlap_start_backoff_timer(struct irlap_cb *self, int timeout);
00077
00078 void irlap_start_mbusy_timer(struct irlap_cb *);
00079
00080 struct lsap_cb;
00081 struct lap_cb;
00082 inline void irlmp_start_watchdog_timer(struct lsap_cb *, int timeout);
00083 inline void irlmp_start_discovery_timer(struct irlmp_cb *, int timeout);
00084 inline void irlmp_start_idle_timer(struct lap_cb *, int timeout);
00085
00086 #endif
00087