1 /*********************************************************************
6 * Status: Experimental.
7 * Author: Dag Brattli <dagb@cs.uit.no>
8 * Created at: Sat Aug 16 00:59:29 1997
9 * Modified at: Thu Oct 7 12:25:24 1999
10 * Modified by: Dag Brattli <dagb@cs.uit.no>
12 * Copyright (c) 1997, 1998-1999 Dag Brattli <dagb@cs.uit.no>,
13 * All Rights Reserved.
14 * Copyright (c) 2000-2002 Jean Tourrilhes <jt@hpl.hp.com>
16 * This program is free software; you can redistribute it and/or
17 * modify it under the terms of the GNU General Public License as
18 * published by the Free Software Foundation; either version 2 of
19 * the License, or (at your option) any later version.
21 * Neither Dag Brattli nor University of Tromsø admit liability nor
22 * provide warranty for any of this software. This material is
23 * provided "AS-IS" and at no charge.
25 ********************************************************************/
30 #include <linux/timer.h>
31 #include <linux/jiffies.h>
33 #include <asm/param.h> /* for HZ */
35 #include <net/irda/irda.h>
37 /* A few forward declarations (to make compiler happy) */
44 * Timeout definitions, some defined in IrLAP 6.13.5 - p. 92
46 #define POLL_TIMEOUT (450*HZ/1000) /* Must never exceed 500 ms */
47 #define FINAL_TIMEOUT (500*HZ/1000) /* Must never exceed 500 ms */
50 * Normally twice of p-timer. Note 3, IrLAP 6.3.11.2 - p. 60 suggests
51 * at least twice duration of the P-timer.
53 #define WD_TIMEOUT (POLL_TIMEOUT*2)
55 #define MEDIABUSY_TIMEOUT (500*HZ/1000) /* 500 msec */
56 #define SMALLBUSY_TIMEOUT (100*HZ/1000) /* 100 msec - IrLAP 6.13.4 */
59 * Slot timer must never exceed 85 ms, and must always be at least 25 ms,
60 * suggested to 75-85 msec by IrDA lite. This doesn't work with a lot of
61 * devices, and other stackes uses a lot more, so it's best we do it as well
62 * (Note : this is the default value and sysctl overrides it - Jean II)
64 #define SLOT_TIMEOUT (90*HZ/1000)
67 * The latest discovery frame (XID) is longer due to the extra discovery
68 * information (hints, device name...). This is its extra length.
69 * We use that when setting the query timeout. Jean II
71 #define XIDEXTRA_TIMEOUT (34*HZ/1000) /* 34 msec */
73 #define WATCHDOG_TIMEOUT (20*HZ) /* 20 sec */
75 typedef void (*TIMER_CALLBACK
)(void *);
77 static inline void irda_start_timer(struct timer_list
*ptimer
, int timeout
,
78 void* data
, TIMER_CALLBACK callback
)
80 ptimer
->function
= (void (*)(unsigned long)) callback
;
81 ptimer
->data
= (unsigned long) data
;
83 /* Set new value for timer (update or add timer).
84 * We use mod_timer() because it's more efficient and also
85 * safer with respect to race conditions - Jean II */
86 mod_timer(ptimer
, jiffies
+ timeout
);
90 void irlap_start_slot_timer(struct irlap_cb
*self
, int timeout
);
91 void irlap_start_query_timer(struct irlap_cb
*self
, int S
, int s
);
92 void irlap_start_final_timer(struct irlap_cb
*self
, int timeout
);
93 void irlap_start_wd_timer(struct irlap_cb
*self
, int timeout
);
94 void irlap_start_backoff_timer(struct irlap_cb
*self
, int timeout
);
96 void irlap_start_mbusy_timer(struct irlap_cb
*self
, int timeout
);
97 void irlap_stop_mbusy_timer(struct irlap_cb
*);
99 void irlmp_start_watchdog_timer(struct lsap_cb
*, int timeout
);
100 void irlmp_start_discovery_timer(struct irlmp_cb
*, int timeout
);
101 void irlmp_start_idle_timer(struct lap_cb
*, int timeout
);
102 void irlmp_stop_idle_timer(struct lap_cb
*self
);