Subversion Repositories shark

Rev

Rev 422 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
422 giacomo 1
/* r3964 linediscipline for linux
2
 *
3
 * -----------------------------------------------------------
4
 * Copyright by
5
 * Philips Automation Projects
6
 * Kassel (Germany)
7
 * http://www.pap-philips.de
8
 * -----------------------------------------------------------
9
 * This software may be used and distributed according to the terms of
10
 * the GNU General Public License, incorporated herein by reference.
11
 *
12
 * Author:
13
 * L. Haag
14
 *
15
 * $Log: not supported by cvs2svn $
16
 * Revision 1.3  2001/03/18 13:02:24  dwmw2
17
 * Fix timer usage, use spinlocks properly.
18
 *
19
 * Revision 1.2  2001/03/18 12:53:15  dwmw2
20
 * Merge changes in 2.4.2
21
 *
22
 * Revision 1.1.1.1  1998/10/13 16:43:14  dwmw2
23
 * This'll screw the version control
24
 *
25
 * Revision 1.6  1998/09/30 00:40:38  dwmw2
26
 * Updated to use kernel's N_R3964 if available
27
 *
28
 * Revision 1.4  1998/04/02 20:29:44  lhaag
29
 * select, blocking, ...
30
 *
31
 * Revision 1.3  1998/02/12 18:58:43  root
32
 * fixed some memory leaks
33
 * calculation of checksum characters
34
 *
35
 * Revision 1.2  1998/02/07 13:03:17  root
36
 * ioctl read_telegram
37
 *
38
 * Revision 1.1  1998/02/06 19:19:43  root
39
 * Initial revision
40
 *
41
 *
42
 */
43
 
44
#ifndef __LINUX_N_R3964_H__
45
#define __LINUX_N_R3964_H__
46
 
47
/* line disciplines for r3964 protocol */
48
#include <asm/termios.h>
49
 
50
#ifdef __KERNEL__
51
/*
52
 * Common ascii handshake characters:
53
 */
54
 
55
#define STX 0x02
56
#define ETX 0x03
57
#define DLE 0x10
58
#define NAK 0x15
59
 
60
/*
61
 * Timeouts (msecs/10 msecs per timer interrupt):
62
 */
63
 
64
#define R3964_TO_QVZ 550/10
65
#define R3964_TO_ZVZ 220/10
66
#define R3964_TO_NO_BUF 400/10
67
#define R3964_NO_TX_ROOM 100/10
68
#define R3964_TO_RX_PANIC 4000/10
69
#define R3964_MAX_RETRIES 5
70
 
71
#endif
72
 
73
/*
74
 * Ioctl-commands
75
 */
76
 
77
#define R3964_ENABLE_SIGNALS      0x5301
78
#define R3964_SETPRIORITY         0x5302
79
#define R3964_USE_BCC             0x5303
80
#define R3964_READ_TELEGRAM       0x5304
81
 
82
/* Options for R3964_SETPRIORITY */
83
#define R3964_MASTER   0
84
#define R3964_SLAVE    1
85
 
86
/* Options for R3964_ENABLE_SIGNALS */
87
#define R3964_SIG_ACK   0x0001
88
#define R3964_SIG_DATA  0x0002
89
#define R3964_SIG_ALL   0x000f
90
#define R3964_SIG_NONE  0x0000
91
#define R3964_USE_SIGIO 0x1000
92
 
93
/*
94
 * r3964 operation states:
95
 */
96
#ifdef __KERNEL__
97
 
98
enum { R3964_IDLE,
99
           R3964_TX_REQUEST, R3964_TRANSMITTING,
100
           R3964_WAIT_ZVZ_BEFORE_TX_RETRY, R3964_WAIT_FOR_TX_ACK,
101
           R3964_WAIT_FOR_RX_BUF,
102
           R3964_RECEIVING, R3964_WAIT_FOR_BCC, R3964_WAIT_FOR_RX_REPEAT
103
           };
104
 
105
/*
106
 * All open file-handles are 'clients' and are stored in a linked list:
107
 */
108
 
109
struct r3964_message;
110
 
111
struct r3964_client_info {
112
        spinlock_t     lock;
113
        pid_t          pid;
114
        unsigned int   sig_flags;
115
 
116
        struct r3964_client_info *next;
117
 
118
        struct r3964_message *first_msg;
119
        struct r3964_message *last_msg;
120
        struct r3964_block_header *next_block_to_read;
121
        int            msg_count;
122
};
123
 
124
 
125
#endif
126
 
127
/* types for msg_id: */
128
enum {R3964_MSG_ACK=1, R3964_MSG_DATA };
129
 
130
#define R3964_MAX_MSG_COUNT 32
131
 
132
/* error codes for client messages */
133
#define R3964_OK 0        /* no error. */
134
#define R3964_TX_FAIL -1  /* transmission error, block NOT sent */
135
#define R3964_OVERFLOW -2 /* msg queue overflow */
136
 
137
/* the client gets this struct when calling read(fd,...): */
138
struct r3964_client_message {
139
          int     msg_id;
140
          int     arg;
141
          int     error_code;
142
};
143
 
144
#define R3964_MTU      256
145
 
146
 
147
#ifdef __KERNEL__
148
 
149
struct r3964_block_header;
150
 
151
/* internal version of client_message: */
152
struct r3964_message {
153
          int     msg_id;
154
          int     arg;
155
          int     error_code;
156
          struct r3964_block_header *block;
157
          struct r3964_message *next;
158
};
159
 
160
/*
161
 * Header of received block in rx_buf/tx_buf:
162
 */
163
 
164
struct r3964_block_header
165
{
166
        unsigned int length;             /* length in chars without header */
167
        unsigned char *data;             /* usually data is located
168
                                        immediately behind this struct */
169
        unsigned int locks;              /* only used in rx_buffer */
170
 
171
    struct r3964_block_header *next;
172
        struct r3964_client_info *owner;  /* =NULL in rx_buffer */
173
};
174
 
175
/*
176
 * If rx_buf hasn't enough space to store R3964_MTU chars,
177
 * we will reject all incoming STX-requests by sending NAK.
178
 */
179
 
180
#define RX_BUF_SIZE    4000
181
#define TX_BUF_SIZE    4000
182
#define R3964_MAX_BLOCKS_IN_RX_QUEUE 100
183
 
184
#define R3964_PARITY 0x0001
185
#define R3964_FRAME  0x0002
186
#define R3964_OVERRUN 0x0004
187
#define R3964_UNKNOWN 0x0008
188
#define R3964_BREAK   0x0010
189
#define R3964_CHECKSUM 0x0020
190
#define R3964_ERROR  0x003f
191
#define R3964_BCC   0x4000
192
#define R3964_DEBUG 0x8000
193
 
194
 
195
struct r3964_info {
196
        spinlock_t     lock;
197
        struct tty_struct *tty;
198
        unsigned char priority;
199
        unsigned char *rx_buf;            /* ring buffer */
200
        unsigned char *tx_buf;
201
 
202
        wait_queue_head_t read_wait;
203
        //struct wait_queue *read_wait;
204
 
205
        struct r3964_block_header *rx_first;
206
        struct r3964_block_header *rx_last;
207
        struct r3964_block_header *tx_first;
208
        struct r3964_block_header *tx_last;
209
        unsigned int tx_position;
210
        unsigned int rx_position;
211
        unsigned char last_rx;
212
        unsigned char bcc;
213
        unsigned int  blocks_in_rx_queue;
214
 
215
 
216
        struct r3964_client_info *firstClient;
217
        unsigned int state;
218
        unsigned int flags;
219
 
220
        struct timer_list tmr;
221
        int nRetry;
222
};
223
 
224
#endif  
225
 
226
#endif