Blame view

include/linux/tty_ldisc.h 5.87 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
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
  #ifndef _LINUX_TTY_LDISC_H
  #define _LINUX_TTY_LDISC_H
  
  /*
   * This structure defines the interface between the tty line discipline
   * implementation and the tty routines.  The following routines can be
   * defined; unless noted otherwise, they are optional, and can be
   * filled in with a null pointer.
   *
   * int	(*open)(struct tty_struct *);
   *
   * 	This function is called when the line discipline is associated
   * 	with the tty.  The line discipline can use this as an
   * 	opportunity to initialize any state needed by the ldisc routines.
   * 
   * void	(*close)(struct tty_struct *);
   *
   *	This function is called when the line discipline is being
   * 	shutdown, either because the tty is being closed or because
   * 	the tty is being changed to use a new line discipline
   * 
   * void	(*flush_buffer)(struct tty_struct *tty);
   *
   * 	This function instructs the line discipline to clear its
   * 	buffers of any input characters it may have queued to be
   * 	delivered to the user mode process.
   * 
   * ssize_t (*chars_in_buffer)(struct tty_struct *tty);
   *
   * 	This function returns the number of input characters the line
   *	discipline may have queued up to be delivered to the user mode
   *	process.
   * 
   * ssize_t (*read)(struct tty_struct * tty, struct file * file,
   *		   unsigned char * buf, size_t nr);
   *
   * 	This function is called when the user requests to read from
   * 	the tty.  The line discipline will return whatever characters
   * 	it has buffered up for the user.  If this function is not
   * 	defined, the user will receive an EIO error.
   * 
   * ssize_t (*write)(struct tty_struct * tty, struct file * file,
   * 		    const unsigned char * buf, size_t nr);
   *
   * 	This function is called when the user requests to write to the
   * 	tty.  The line discipline will deliver the characters to the
   * 	low-level tty device for transmission, optionally performing
   * 	some processing on the characters first.  If this function is
   * 	not defined, the user will receive an EIO error.
   * 
   * int	(*ioctl)(struct tty_struct * tty, struct file * file,
   * 		 unsigned int cmd, unsigned long arg);
   *
   *	This function is called when the user requests an ioctl which
   * 	is not handled by the tty layer or the low-level tty driver.
   * 	It is intended for ioctls which affect line discpline
   * 	operation.  Note that the search order for ioctls is (1) tty
   * 	layer, (2) tty low-level driver, (3) line discpline.  So a
   * 	low-level driver can "grab" an ioctl request before the line
   * 	discpline has a chance to see it.
   * 
e10cc1df1   Paul Fulghum   tty: add compat_i...
62
63
64
65
66
   * long	(*compat_ioctl)(struct tty_struct * tty, struct file * file,
   * 		        unsigned int cmd, unsigned long arg);
   *
   *      Process ioctl calls from 32-bit process on 64-bit system
   *
edc6afc54   Alan Cox   [PATCH] tty: swit...
67
   * void	(*set_termios)(struct tty_struct *tty, struct ktermios * old);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
68
69
70
71
72
73
74
75
76
77
78
   *
   * 	This function notifies the line discpline that a change has
   * 	been made to the termios structure.
   * 
   * int	(*poll)(struct tty_struct * tty, struct file * file,
   * 		  poll_table *wait);
   *
   * 	This function is called when a user attempts to select/poll on a
   * 	tty device.  It is solely the responsibility of the line
   * 	discipline to handle poll requests.
   *
55db4c64e   Linus Torvalds   Revert "tty: make...
79
   * void	(*receive_buf)(struct tty_struct *, const unsigned char *cp,
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
80
81
82
83
84
85
86
   * 		       char *fp, int count);
   *
   * 	This function is called by the low-level tty driver to send
   * 	characters received by the hardware to the line discpline for
   * 	processing.  <cp> is a pointer to the buffer of input
   * 	character received by the device.  <fp> is a pointer to a
   * 	pointer of flag bytes which indicate whether a character was
55db4c64e   Linus Torvalds   Revert "tty: make...
87
   * 	received with a parity error, etc.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
88
   * 
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
89
90
91
92
93
94
95
96
97
98
99
100
101
   * void	(*write_wakeup)(struct tty_struct *);
   *
   * 	This function is called by the low-level tty driver to signal
   * 	that line discpline should try to send more characters to the
   * 	low-level driver for transmission.  If the line discpline does
   * 	not have any more data to send, it can just return.
   *
   * int (*hangup)(struct tty_struct *)
   *
   *	Called on a hangup. Tells the discipline that it should
   *	cease I/O to the tty driver. Can sleep. The driver should
   *	seek to perform this action quickly but should wait until
   *	any pending driver I/O is completed.
b3e63afe8   Rodolfo Giometti   ldisc: new dcd_ch...
102
103
   *
   * void (*dcd_change)(struct tty_struct *tty, unsigned int status,
6f4229b51   Alexander Gordeev   pps: unify timest...
104
   *			struct pps_event_time *ts)
b3e63afe8   Rodolfo Giometti   ldisc: new dcd_ch...
105
106
   *
   *	Tells the discipline that the DCD pin has changed its status and
12f9b1f9c   Alexander Gordeev   pps: timestamp is...
107
   *	the relative timestamp. Pointer ts cannot be NULL.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
108
109
110
111
   */
  
  #include <linux/fs.h>
  #include <linux/wait.h>
6f4229b51   Alexander Gordeev   pps: unify timest...
112
  #include <linux/pps_kernel.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
113

a352def21   Alan Cox   tty: Ldisc revamp
114
  struct tty_ldisc_ops {
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
  	int	magic;
  	char	*name;
  	int	num;
  	int	flags;
  	
  	/*
  	 * The following routines are called from above.
  	 */
  	int	(*open)(struct tty_struct *);
  	void	(*close)(struct tty_struct *);
  	void	(*flush_buffer)(struct tty_struct *tty);
  	ssize_t	(*chars_in_buffer)(struct tty_struct *tty);
  	ssize_t	(*read)(struct tty_struct * tty, struct file * file,
  			unsigned char __user * buf, size_t nr);
  	ssize_t	(*write)(struct tty_struct * tty, struct file * file,
  			 const unsigned char * buf, size_t nr);	
  	int	(*ioctl)(struct tty_struct * tty, struct file * file,
  			 unsigned int cmd, unsigned long arg);
e10cc1df1   Paul Fulghum   tty: add compat_i...
133
134
  	long	(*compat_ioctl)(struct tty_struct * tty, struct file * file,
  				unsigned int cmd, unsigned long arg);
edc6afc54   Alan Cox   [PATCH] tty: swit...
135
  	void	(*set_termios)(struct tty_struct *tty, struct ktermios * old);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
136
137
138
139
140
141
142
  	unsigned int (*poll)(struct tty_struct *, struct file *,
  			     struct poll_table_struct *);
  	int	(*hangup)(struct tty_struct *tty);
  	
  	/*
  	 * The following routines are called from below.
  	 */
55db4c64e   Linus Torvalds   Revert "tty: make...
143
144
  	void	(*receive_buf)(struct tty_struct *, const unsigned char *cp,
  			       char *fp, int count);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
145
  	void	(*write_wakeup)(struct tty_struct *);
b3e63afe8   Rodolfo Giometti   ldisc: new dcd_ch...
146
  	void	(*dcd_change)(struct tty_struct *, unsigned int,
6f4229b51   Alexander Gordeev   pps: unify timest...
147
  				struct pps_event_time *);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
148
149
150
151
152
  
  	struct  module *owner;
  	
  	int refcount;
  };
a352def21   Alan Cox   tty: Ldisc revamp
153
154
  struct tty_ldisc {
  	struct tty_ldisc_ops *ops;
18eac1cc1   Linus Torvalds   tty-ldisc: make r...
155
  	atomic_t users;
a352def21   Alan Cox   tty: Ldisc revamp
156
  };
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
157
158
159
160
161
162
163
164
  #define TTY_LDISC_MAGIC	0x5403
  
  #define LDISC_FLAG_DEFINED	0x00000001
  
  #define MODULE_ALIAS_LDISC(ldisc) \
  	MODULE_ALIAS("tty-ldisc-" __stringify(ldisc))
  
  #endif /* _LINUX_TTY_LDISC_H */