Blame view

kernel/linux-imx6_3.14.28/include/net/irda/timer.h 3.63 KB
6b13f685e   김민수   BSP 최초 추가
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
  /*********************************************************************
   *                
   * 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ø 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>
  #include <linux/jiffies.h>
  
  #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