n_gsm.c (85707B)
1// SPDX-License-Identifier: GPL-2.0 2/* 3 * n_gsm.c GSM 0710 tty multiplexor 4 * Copyright (c) 2009/10 Intel Corporation 5 * 6 * * THIS IS A DEVELOPMENT SNAPSHOT IT IS NOT A FINAL RELEASE * 7 * 8 * TO DO: 9 * Mostly done: ioctls for setting modes/timing 10 * Partly done: hooks so you can pull off frames to non tty devs 11 * Restart DLCI 0 when it closes ? 12 * Improve the tx engine 13 * Resolve tx side locking by adding a queue_head and routing 14 * all control traffic via it 15 * General tidy/document 16 * Review the locking/move to refcounts more (mux now moved to an 17 * alloc/free model ready) 18 * Use newest tty open/close port helpers and install hooks 19 * What to do about power functions ? 20 * Termios setting and negotiation 21 * Do we need a 'which mux are you' ioctl to correlate mux and tty sets 22 * 23 */ 24 25#include <linux/types.h> 26#include <linux/major.h> 27#include <linux/errno.h> 28#include <linux/signal.h> 29#include <linux/fcntl.h> 30#include <linux/sched/signal.h> 31#include <linux/interrupt.h> 32#include <linux/tty.h> 33#include <linux/ctype.h> 34#include <linux/mm.h> 35#include <linux/string.h> 36#include <linux/slab.h> 37#include <linux/poll.h> 38#include <linux/bitops.h> 39#include <linux/file.h> 40#include <linux/uaccess.h> 41#include <linux/module.h> 42#include <linux/timer.h> 43#include <linux/tty_flip.h> 44#include <linux/tty_driver.h> 45#include <linux/serial.h> 46#include <linux/kfifo.h> 47#include <linux/skbuff.h> 48#include <net/arp.h> 49#include <linux/ip.h> 50#include <linux/netdevice.h> 51#include <linux/etherdevice.h> 52#include <linux/gsmmux.h> 53#include "tty.h" 54 55static int debug; 56module_param(debug, int, 0600); 57 58/* Defaults: these are from the specification */ 59 60#define T1 10 /* 100mS */ 61#define T2 34 /* 333mS */ 62#define N2 3 /* Retry 3 times */ 63 64/* Use long timers for testing at low speed with debug on */ 65#ifdef DEBUG_TIMING 66#define T1 100 67#define T2 200 68#endif 69 70/* 71 * Semi-arbitrary buffer size limits. 0710 is normally run with 32-64 byte 72 * limits so this is plenty 73 */ 74#define MAX_MRU 1500 75#define MAX_MTU 1500 76/* SOF, ADDR, CTRL, LEN1, LEN2, ..., FCS, EOF */ 77#define PROT_OVERHEAD 7 78#define GSM_NET_TX_TIMEOUT (HZ*10) 79 80/* 81 * struct gsm_mux_net - network interface 82 * 83 * Created when net interface is initialized. 84 */ 85struct gsm_mux_net { 86 struct kref ref; 87 struct gsm_dlci *dlci; 88}; 89 90/* 91 * Each block of data we have queued to go out is in the form of 92 * a gsm_msg which holds everything we need in a link layer independent 93 * format 94 */ 95 96struct gsm_msg { 97 struct list_head list; 98 u8 addr; /* DLCI address + flags */ 99 u8 ctrl; /* Control byte + flags */ 100 unsigned int len; /* Length of data block (can be zero) */ 101 unsigned char *data; /* Points into buffer but not at the start */ 102 unsigned char buffer[]; 103}; 104 105enum gsm_dlci_state { 106 DLCI_CLOSED, 107 DLCI_OPENING, /* Sending SABM not seen UA */ 108 DLCI_OPEN, /* SABM/UA complete */ 109 DLCI_CLOSING, /* Sending DISC not seen UA/DM */ 110}; 111 112enum gsm_dlci_mode { 113 DLCI_MODE_ABM, /* Normal Asynchronous Balanced Mode */ 114 DLCI_MODE_ADM, /* Asynchronous Disconnected Mode */ 115}; 116 117/* 118 * Each active data link has a gsm_dlci structure associated which ties 119 * the link layer to an optional tty (if the tty side is open). To avoid 120 * complexity right now these are only ever freed up when the mux is 121 * shut down. 122 * 123 * At the moment we don't free DLCI objects until the mux is torn down 124 * this avoid object life time issues but might be worth review later. 125 */ 126 127struct gsm_dlci { 128 struct gsm_mux *gsm; 129 int addr; 130 enum gsm_dlci_state state; 131 struct mutex mutex; 132 133 /* Link layer */ 134 enum gsm_dlci_mode mode; 135 spinlock_t lock; /* Protects the internal state */ 136 struct timer_list t1; /* Retransmit timer for SABM and UA */ 137 int retries; 138 /* Uplink tty if active */ 139 struct tty_port port; /* The tty bound to this DLCI if there is one */ 140#define TX_SIZE 4096 /* Must be power of 2. */ 141 struct kfifo fifo; /* Queue fifo for the DLCI */ 142 int adaption; /* Adaption layer in use */ 143 int prev_adaption; 144 u32 modem_rx; /* Our incoming virtual modem lines */ 145 u32 modem_tx; /* Our outgoing modem lines */ 146 bool dead; /* Refuse re-open */ 147 /* Flow control */ 148 bool throttled; /* Private copy of throttle state */ 149 bool constipated; /* Throttle status for outgoing */ 150 /* Packetised I/O */ 151 struct sk_buff *skb; /* Frame being sent */ 152 struct sk_buff_head skb_list; /* Queued frames */ 153 /* Data handling callback */ 154 void (*data)(struct gsm_dlci *dlci, const u8 *data, int len); 155 void (*prev_data)(struct gsm_dlci *dlci, const u8 *data, int len); 156 struct net_device *net; /* network interface, if created */ 157}; 158 159/* DLCI 0, 62/63 are special or reserved see gsmtty_open */ 160 161#define NUM_DLCI 64 162 163/* 164 * DLCI 0 is used to pass control blocks out of band of the data 165 * flow (and with a higher link priority). One command can be outstanding 166 * at a time and we use this structure to manage them. They are created 167 * and destroyed by the user context, and updated by the receive paths 168 * and timers 169 */ 170 171struct gsm_control { 172 u8 cmd; /* Command we are issuing */ 173 u8 *data; /* Data for the command in case we retransmit */ 174 int len; /* Length of block for retransmission */ 175 int done; /* Done flag */ 176 int error; /* Error if any */ 177}; 178 179enum gsm_mux_state { 180 GSM_SEARCH, 181 GSM_START, 182 GSM_ADDRESS, 183 GSM_CONTROL, 184 GSM_LEN, 185 GSM_DATA, 186 GSM_FCS, 187 GSM_OVERRUN, 188 GSM_LEN0, 189 GSM_LEN1, 190 GSM_SSOF, 191}; 192 193/* 194 * Each GSM mux we have is represented by this structure. If we are 195 * operating as an ldisc then we use this structure as our ldisc 196 * state. We need to sort out lifetimes and locking with respect 197 * to the gsm mux array. For now we don't free DLCI objects that 198 * have been instantiated until the mux itself is terminated. 199 * 200 * To consider further: tty open versus mux shutdown. 201 */ 202 203struct gsm_mux { 204 struct tty_struct *tty; /* The tty our ldisc is bound to */ 205 spinlock_t lock; 206 struct mutex mutex; 207 unsigned int num; 208 struct kref ref; 209 210 /* Events on the GSM channel */ 211 wait_queue_head_t event; 212 213 /* Bits for GSM mode decoding */ 214 215 /* Framing Layer */ 216 unsigned char *buf; 217 enum gsm_mux_state state; 218 unsigned int len; 219 unsigned int address; 220 unsigned int count; 221 bool escape; 222 int encoding; 223 u8 control; 224 u8 fcs; 225 u8 *txframe; /* TX framing buffer */ 226 227 /* Method for the receiver side */ 228 void (*receive)(struct gsm_mux *gsm, u8 ch); 229 230 /* Link Layer */ 231 unsigned int mru; 232 unsigned int mtu; 233 int initiator; /* Did we initiate connection */ 234 bool dead; /* Has the mux been shut down */ 235 struct gsm_dlci *dlci[NUM_DLCI]; 236 int old_c_iflag; /* termios c_iflag value before attach */ 237 bool constipated; /* Asked by remote to shut up */ 238 239 spinlock_t tx_lock; 240 unsigned int tx_bytes; /* TX data outstanding */ 241#define TX_THRESH_HI 8192 242#define TX_THRESH_LO 2048 243 struct list_head tx_list; /* Pending data packets */ 244 245 /* Control messages */ 246 struct timer_list t2_timer; /* Retransmit timer for commands */ 247 int cretries; /* Command retry counter */ 248 struct gsm_control *pending_cmd;/* Our current pending command */ 249 spinlock_t control_lock; /* Protects the pending command */ 250 251 /* Configuration */ 252 int adaption; /* 1 or 2 supported */ 253 u8 ftype; /* UI or UIH */ 254 int t1, t2; /* Timers in 1/100th of a sec */ 255 int n2; /* Retry count */ 256 257 /* Statistics (not currently exposed) */ 258 unsigned long bad_fcs; 259 unsigned long malformed; 260 unsigned long io_error; 261 unsigned long bad_size; 262 unsigned long unsupported; 263}; 264 265 266/* 267 * Mux objects - needed so that we can translate a tty index into the 268 * relevant mux and DLCI. 269 */ 270 271#define MAX_MUX 4 /* 256 minors */ 272static struct gsm_mux *gsm_mux[MAX_MUX]; /* GSM muxes */ 273static DEFINE_SPINLOCK(gsm_mux_lock); 274 275static struct tty_driver *gsm_tty_driver; 276 277/* 278 * This section of the driver logic implements the GSM encodings 279 * both the basic and the 'advanced'. Reliable transport is not 280 * supported. 281 */ 282 283#define CR 0x02 284#define EA 0x01 285#define PF 0x10 286 287/* I is special: the rest are ..*/ 288#define RR 0x01 289#define UI 0x03 290#define RNR 0x05 291#define REJ 0x09 292#define DM 0x0F 293#define SABM 0x2F 294#define DISC 0x43 295#define UA 0x63 296#define UIH 0xEF 297 298/* Channel commands */ 299#define CMD_NSC 0x09 300#define CMD_TEST 0x11 301#define CMD_PSC 0x21 302#define CMD_RLS 0x29 303#define CMD_FCOFF 0x31 304#define CMD_PN 0x41 305#define CMD_RPN 0x49 306#define CMD_FCON 0x51 307#define CMD_CLD 0x61 308#define CMD_SNC 0x69 309#define CMD_MSC 0x71 310 311/* Virtual modem bits */ 312#define MDM_FC 0x01 313#define MDM_RTC 0x02 314#define MDM_RTR 0x04 315#define MDM_IC 0x20 316#define MDM_DV 0x40 317 318#define GSM0_SOF 0xF9 319#define GSM1_SOF 0x7E 320#define GSM1_ESCAPE 0x7D 321#define GSM1_ESCAPE_BITS 0x20 322#define XON 0x11 323#define XOFF 0x13 324#define ISO_IEC_646_MASK 0x7F 325 326static const struct tty_port_operations gsm_port_ops; 327 328/* 329 * CRC table for GSM 0710 330 */ 331 332static const u8 gsm_fcs8[256] = { 333 0x00, 0x91, 0xE3, 0x72, 0x07, 0x96, 0xE4, 0x75, 334 0x0E, 0x9F, 0xED, 0x7C, 0x09, 0x98, 0xEA, 0x7B, 335 0x1C, 0x8D, 0xFF, 0x6E, 0x1B, 0x8A, 0xF8, 0x69, 336 0x12, 0x83, 0xF1, 0x60, 0x15, 0x84, 0xF6, 0x67, 337 0x38, 0xA9, 0xDB, 0x4A, 0x3F, 0xAE, 0xDC, 0x4D, 338 0x36, 0xA7, 0xD5, 0x44, 0x31, 0xA0, 0xD2, 0x43, 339 0x24, 0xB5, 0xC7, 0x56, 0x23, 0xB2, 0xC0, 0x51, 340 0x2A, 0xBB, 0xC9, 0x58, 0x2D, 0xBC, 0xCE, 0x5F, 341 0x70, 0xE1, 0x93, 0x02, 0x77, 0xE6, 0x94, 0x05, 342 0x7E, 0xEF, 0x9D, 0x0C, 0x79, 0xE8, 0x9A, 0x0B, 343 0x6C, 0xFD, 0x8F, 0x1E, 0x6B, 0xFA, 0x88, 0x19, 344 0x62, 0xF3, 0x81, 0x10, 0x65, 0xF4, 0x86, 0x17, 345 0x48, 0xD9, 0xAB, 0x3A, 0x4F, 0xDE, 0xAC, 0x3D, 346 0x46, 0xD7, 0xA5, 0x34, 0x41, 0xD0, 0xA2, 0x33, 347 0x54, 0xC5, 0xB7, 0x26, 0x53, 0xC2, 0xB0, 0x21, 348 0x5A, 0xCB, 0xB9, 0x28, 0x5D, 0xCC, 0xBE, 0x2F, 349 0xE0, 0x71, 0x03, 0x92, 0xE7, 0x76, 0x04, 0x95, 350 0xEE, 0x7F, 0x0D, 0x9C, 0xE9, 0x78, 0x0A, 0x9B, 351 0xFC, 0x6D, 0x1F, 0x8E, 0xFB, 0x6A, 0x18, 0x89, 352 0xF2, 0x63, 0x11, 0x80, 0xF5, 0x64, 0x16, 0x87, 353 0xD8, 0x49, 0x3B, 0xAA, 0xDF, 0x4E, 0x3C, 0xAD, 354 0xD6, 0x47, 0x35, 0xA4, 0xD1, 0x40, 0x32, 0xA3, 355 0xC4, 0x55, 0x27, 0xB6, 0xC3, 0x52, 0x20, 0xB1, 356 0xCA, 0x5B, 0x29, 0xB8, 0xCD, 0x5C, 0x2E, 0xBF, 357 0x90, 0x01, 0x73, 0xE2, 0x97, 0x06, 0x74, 0xE5, 358 0x9E, 0x0F, 0x7D, 0xEC, 0x99, 0x08, 0x7A, 0xEB, 359 0x8C, 0x1D, 0x6F, 0xFE, 0x8B, 0x1A, 0x68, 0xF9, 360 0x82, 0x13, 0x61, 0xF0, 0x85, 0x14, 0x66, 0xF7, 361 0xA8, 0x39, 0x4B, 0xDA, 0xAF, 0x3E, 0x4C, 0xDD, 362 0xA6, 0x37, 0x45, 0xD4, 0xA1, 0x30, 0x42, 0xD3, 363 0xB4, 0x25, 0x57, 0xC6, 0xB3, 0x22, 0x50, 0xC1, 364 0xBA, 0x2B, 0x59, 0xC8, 0xBD, 0x2C, 0x5E, 0xCF 365}; 366 367#define INIT_FCS 0xFF 368#define GOOD_FCS 0xCF 369 370static int gsmld_output(struct gsm_mux *gsm, u8 *data, int len); 371static int gsm_modem_update(struct gsm_dlci *dlci, u8 brk); 372 373/** 374 * gsm_fcs_add - update FCS 375 * @fcs: Current FCS 376 * @c: Next data 377 * 378 * Update the FCS to include c. Uses the algorithm in the specification 379 * notes. 380 */ 381 382static inline u8 gsm_fcs_add(u8 fcs, u8 c) 383{ 384 return gsm_fcs8[fcs ^ c]; 385} 386 387/** 388 * gsm_fcs_add_block - update FCS for a block 389 * @fcs: Current FCS 390 * @c: buffer of data 391 * @len: length of buffer 392 * 393 * Update the FCS to include c. Uses the algorithm in the specification 394 * notes. 395 */ 396 397static inline u8 gsm_fcs_add_block(u8 fcs, u8 *c, int len) 398{ 399 while (len--) 400 fcs = gsm_fcs8[fcs ^ *c++]; 401 return fcs; 402} 403 404/** 405 * gsm_read_ea - read a byte into an EA 406 * @val: variable holding value 407 * @c: byte going into the EA 408 * 409 * Processes one byte of an EA. Updates the passed variable 410 * and returns 1 if the EA is now completely read 411 */ 412 413static int gsm_read_ea(unsigned int *val, u8 c) 414{ 415 /* Add the next 7 bits into the value */ 416 *val <<= 7; 417 *val |= c >> 1; 418 /* Was this the last byte of the EA 1 = yes*/ 419 return c & EA; 420} 421 422/** 423 * gsm_encode_modem - encode modem data bits 424 * @dlci: DLCI to encode from 425 * 426 * Returns the correct GSM encoded modem status bits (6 bit field) for 427 * the current status of the DLCI and attached tty object 428 */ 429 430static u8 gsm_encode_modem(const struct gsm_dlci *dlci) 431{ 432 u8 modembits = 0; 433 /* FC is true flow control not modem bits */ 434 if (dlci->throttled) 435 modembits |= MDM_FC; 436 if (dlci->modem_tx & TIOCM_DTR) 437 modembits |= MDM_RTC; 438 if (dlci->modem_tx & TIOCM_RTS) 439 modembits |= MDM_RTR; 440 if (dlci->modem_tx & TIOCM_RI) 441 modembits |= MDM_IC; 442 if (dlci->modem_tx & TIOCM_CD || dlci->gsm->initiator) 443 modembits |= MDM_DV; 444 return modembits; 445} 446 447static void gsm_hex_dump_bytes(const char *fname, const u8 *data, 448 unsigned long len) 449{ 450 char *prefix; 451 452 if (!fname) { 453 print_hex_dump(KERN_INFO, "", DUMP_PREFIX_NONE, 16, 1, data, len, 454 true); 455 return; 456 } 457 458 prefix = kasprintf(GFP_ATOMIC, "%s: ", fname); 459 if (!prefix) 460 return; 461 print_hex_dump(KERN_INFO, prefix, DUMP_PREFIX_OFFSET, 16, 1, data, len, 462 true); 463 kfree(prefix); 464} 465 466/** 467 * gsm_print_packet - display a frame for debug 468 * @hdr: header to print before decode 469 * @addr: address EA from the frame 470 * @cr: C/R bit seen as initiator 471 * @control: control including PF bit 472 * @data: following data bytes 473 * @dlen: length of data 474 * 475 * Displays a packet in human readable format for debugging purposes. The 476 * style is based on amateur radio LAP-B dump display. 477 */ 478 479static void gsm_print_packet(const char *hdr, int addr, int cr, 480 u8 control, const u8 *data, int dlen) 481{ 482 if (!(debug & 1)) 483 return; 484 485 pr_info("%s %d) %c: ", hdr, addr, "RC"[cr]); 486 487 switch (control & ~PF) { 488 case SABM: 489 pr_cont("SABM"); 490 break; 491 case UA: 492 pr_cont("UA"); 493 break; 494 case DISC: 495 pr_cont("DISC"); 496 break; 497 case DM: 498 pr_cont("DM"); 499 break; 500 case UI: 501 pr_cont("UI"); 502 break; 503 case UIH: 504 pr_cont("UIH"); 505 break; 506 default: 507 if (!(control & 0x01)) { 508 pr_cont("I N(S)%d N(R)%d", 509 (control & 0x0E) >> 1, (control & 0xE0) >> 5); 510 } else switch (control & 0x0F) { 511 case RR: 512 pr_cont("RR(%d)", (control & 0xE0) >> 5); 513 break; 514 case RNR: 515 pr_cont("RNR(%d)", (control & 0xE0) >> 5); 516 break; 517 case REJ: 518 pr_cont("REJ(%d)", (control & 0xE0) >> 5); 519 break; 520 default: 521 pr_cont("[%02X]", control); 522 } 523 } 524 525 if (control & PF) 526 pr_cont("(P)"); 527 else 528 pr_cont("(F)"); 529 530 gsm_hex_dump_bytes(NULL, data, dlen); 531} 532 533 534/* 535 * Link level transmission side 536 */ 537 538/** 539 * gsm_stuff_frame - bytestuff a packet 540 * @input: input buffer 541 * @output: output buffer 542 * @len: length of input 543 * 544 * Expand a buffer by bytestuffing it. The worst case size change 545 * is doubling and the caller is responsible for handing out 546 * suitable sized buffers. 547 */ 548 549static int gsm_stuff_frame(const u8 *input, u8 *output, int len) 550{ 551 int olen = 0; 552 while (len--) { 553 if (*input == GSM1_SOF || *input == GSM1_ESCAPE 554 || (*input & ISO_IEC_646_MASK) == XON 555 || (*input & ISO_IEC_646_MASK) == XOFF) { 556 *output++ = GSM1_ESCAPE; 557 *output++ = *input++ ^ GSM1_ESCAPE_BITS; 558 olen++; 559 } else 560 *output++ = *input++; 561 olen++; 562 } 563 return olen; 564} 565 566/** 567 * gsm_send - send a control frame 568 * @gsm: our GSM mux 569 * @addr: address for control frame 570 * @cr: command/response bit seen as initiator 571 * @control: control byte including PF bit 572 * 573 * Format up and transmit a control frame. These do not go via the 574 * queueing logic as they should be transmitted ahead of data when 575 * they are needed. 576 * 577 * FIXME: Lock versus data TX path 578 */ 579 580static void gsm_send(struct gsm_mux *gsm, int addr, int cr, int control) 581{ 582 int len; 583 u8 cbuf[10]; 584 u8 ibuf[3]; 585 int ocr; 586 587 /* toggle C/R coding if not initiator */ 588 ocr = cr ^ (gsm->initiator ? 0 : 1); 589 590 switch (gsm->encoding) { 591 case 0: 592 cbuf[0] = GSM0_SOF; 593 cbuf[1] = (addr << 2) | (ocr << 1) | EA; 594 cbuf[2] = control; 595 cbuf[3] = EA; /* Length of data = 0 */ 596 cbuf[4] = 0xFF - gsm_fcs_add_block(INIT_FCS, cbuf + 1, 3); 597 cbuf[5] = GSM0_SOF; 598 len = 6; 599 break; 600 case 1: 601 case 2: 602 /* Control frame + packing (but not frame stuffing) in mode 1 */ 603 ibuf[0] = (addr << 2) | (ocr << 1) | EA; 604 ibuf[1] = control; 605 ibuf[2] = 0xFF - gsm_fcs_add_block(INIT_FCS, ibuf, 2); 606 /* Stuffing may double the size worst case */ 607 len = gsm_stuff_frame(ibuf, cbuf + 1, 3); 608 /* Now add the SOF markers */ 609 cbuf[0] = GSM1_SOF; 610 cbuf[len + 1] = GSM1_SOF; 611 /* FIXME: we can omit the lead one in many cases */ 612 len += 2; 613 break; 614 default: 615 WARN_ON(1); 616 return; 617 } 618 gsmld_output(gsm, cbuf, len); 619 if (!gsm->initiator) { 620 cr = cr & gsm->initiator; 621 control = control & ~PF; 622 } 623 gsm_print_packet("-->", addr, cr, control, NULL, 0); 624} 625 626/** 627 * gsm_response - send a control response 628 * @gsm: our GSM mux 629 * @addr: address for control frame 630 * @control: control byte including PF bit 631 * 632 * Format up and transmit a link level response frame. 633 */ 634 635static inline void gsm_response(struct gsm_mux *gsm, int addr, int control) 636{ 637 gsm_send(gsm, addr, 0, control); 638} 639 640/** 641 * gsm_command - send a control command 642 * @gsm: our GSM mux 643 * @addr: address for control frame 644 * @control: control byte including PF bit 645 * 646 * Format up and transmit a link level command frame. 647 */ 648 649static inline void gsm_command(struct gsm_mux *gsm, int addr, int control) 650{ 651 gsm_send(gsm, addr, 1, control); 652} 653 654/* Data transmission */ 655 656#define HDR_LEN 6 /* ADDR CTRL [LEN.2] DATA FCS */ 657 658/** 659 * gsm_data_alloc - allocate data frame 660 * @gsm: GSM mux 661 * @addr: DLCI address 662 * @len: length excluding header and FCS 663 * @ctrl: control byte 664 * 665 * Allocate a new data buffer for sending frames with data. Space is left 666 * at the front for header bytes but that is treated as an implementation 667 * detail and not for the high level code to use 668 */ 669 670static struct gsm_msg *gsm_data_alloc(struct gsm_mux *gsm, u8 addr, int len, 671 u8 ctrl) 672{ 673 struct gsm_msg *m = kmalloc(sizeof(struct gsm_msg) + len + HDR_LEN, 674 GFP_ATOMIC); 675 if (m == NULL) 676 return NULL; 677 m->data = m->buffer + HDR_LEN - 1; /* Allow for FCS */ 678 m->len = len; 679 m->addr = addr; 680 m->ctrl = ctrl; 681 INIT_LIST_HEAD(&m->list); 682 return m; 683} 684 685/** 686 * gsm_data_kick - poke the queue 687 * @gsm: GSM Mux 688 * @dlci: DLCI sending the data 689 * 690 * The tty device has called us to indicate that room has appeared in 691 * the transmit queue. Ram more data into the pipe if we have any 692 * If we have been flow-stopped by a CMD_FCOFF, then we can only 693 * send messages on DLCI0 until CMD_FCON 694 * 695 * FIXME: lock against link layer control transmissions 696 */ 697 698static void gsm_data_kick(struct gsm_mux *gsm, struct gsm_dlci *dlci) 699{ 700 struct gsm_msg *msg, *nmsg; 701 int len; 702 703 list_for_each_entry_safe(msg, nmsg, &gsm->tx_list, list) { 704 if (gsm->constipated && msg->addr) 705 continue; 706 if (gsm->encoding != 0) { 707 gsm->txframe[0] = GSM1_SOF; 708 len = gsm_stuff_frame(msg->data, 709 gsm->txframe + 1, msg->len); 710 gsm->txframe[len + 1] = GSM1_SOF; 711 len += 2; 712 } else { 713 gsm->txframe[0] = GSM0_SOF; 714 memcpy(gsm->txframe + 1 , msg->data, msg->len); 715 gsm->txframe[msg->len + 1] = GSM0_SOF; 716 len = msg->len + 2; 717 } 718 719 if (debug & 4) 720 gsm_hex_dump_bytes(__func__, gsm->txframe, len); 721 if (gsmld_output(gsm, gsm->txframe, len) <= 0) 722 break; 723 /* FIXME: Can eliminate one SOF in many more cases */ 724 gsm->tx_bytes -= msg->len; 725 726 list_del(&msg->list); 727 kfree(msg); 728 729 if (dlci) { 730 tty_port_tty_wakeup(&dlci->port); 731 } else { 732 int i = 0; 733 734 for (i = 0; i < NUM_DLCI; i++) 735 if (gsm->dlci[i]) 736 tty_port_tty_wakeup(&gsm->dlci[i]->port); 737 } 738 } 739} 740 741/** 742 * __gsm_data_queue - queue a UI or UIH frame 743 * @dlci: DLCI sending the data 744 * @msg: message queued 745 * 746 * Add data to the transmit queue and try and get stuff moving 747 * out of the mux tty if not already doing so. The Caller must hold 748 * the gsm tx lock. 749 */ 750 751static void __gsm_data_queue(struct gsm_dlci *dlci, struct gsm_msg *msg) 752{ 753 struct gsm_mux *gsm = dlci->gsm; 754 u8 *dp = msg->data; 755 u8 *fcs = dp + msg->len; 756 757 /* Fill in the header */ 758 if (gsm->encoding == 0) { 759 if (msg->len < 128) 760 *--dp = (msg->len << 1) | EA; 761 else { 762 *--dp = (msg->len >> 7); /* bits 7 - 15 */ 763 *--dp = (msg->len & 127) << 1; /* bits 0 - 6 */ 764 } 765 } 766 767 *--dp = msg->ctrl; 768 if (gsm->initiator) 769 *--dp = (msg->addr << 2) | CR | EA; 770 else 771 *--dp = (msg->addr << 2) | EA; 772 *fcs = gsm_fcs_add_block(INIT_FCS, dp , msg->data - dp); 773 /* Ugly protocol layering violation */ 774 if (msg->ctrl == UI || msg->ctrl == (UI|PF)) 775 *fcs = gsm_fcs_add_block(*fcs, msg->data, msg->len); 776 *fcs = 0xFF - *fcs; 777 778 gsm_print_packet("Q> ", msg->addr, gsm->initiator, msg->ctrl, 779 msg->data, msg->len); 780 781 /* Move the header back and adjust the length, also allow for the FCS 782 now tacked on the end */ 783 msg->len += (msg->data - dp) + 1; 784 msg->data = dp; 785 786 /* Add to the actual output queue */ 787 list_add_tail(&msg->list, &gsm->tx_list); 788 gsm->tx_bytes += msg->len; 789 gsm_data_kick(gsm, dlci); 790} 791 792/** 793 * gsm_data_queue - queue a UI or UIH frame 794 * @dlci: DLCI sending the data 795 * @msg: message queued 796 * 797 * Add data to the transmit queue and try and get stuff moving 798 * out of the mux tty if not already doing so. Take the 799 * the gsm tx lock and dlci lock. 800 */ 801 802static void gsm_data_queue(struct gsm_dlci *dlci, struct gsm_msg *msg) 803{ 804 unsigned long flags; 805 spin_lock_irqsave(&dlci->gsm->tx_lock, flags); 806 __gsm_data_queue(dlci, msg); 807 spin_unlock_irqrestore(&dlci->gsm->tx_lock, flags); 808} 809 810/** 811 * gsm_dlci_data_output - try and push data out of a DLCI 812 * @gsm: mux 813 * @dlci: the DLCI to pull data from 814 * 815 * Pull data from a DLCI and send it into the transmit queue if there 816 * is data. Keep to the MRU of the mux. This path handles the usual tty 817 * interface which is a byte stream with optional modem data. 818 * 819 * Caller must hold the tx_lock of the mux. 820 */ 821 822static int gsm_dlci_data_output(struct gsm_mux *gsm, struct gsm_dlci *dlci) 823{ 824 struct gsm_msg *msg; 825 u8 *dp; 826 int len, total_size, size; 827 int h = dlci->adaption - 1; 828 829 total_size = 0; 830 while (1) { 831 len = kfifo_len(&dlci->fifo); 832 if (len == 0) 833 return total_size; 834 835 /* MTU/MRU count only the data bits */ 836 if (len > gsm->mtu) 837 len = gsm->mtu; 838 839 size = len + h; 840 841 msg = gsm_data_alloc(gsm, dlci->addr, size, gsm->ftype); 842 /* FIXME: need a timer or something to kick this so it can't 843 get stuck with no work outstanding and no buffer free */ 844 if (msg == NULL) 845 return -ENOMEM; 846 dp = msg->data; 847 switch (dlci->adaption) { 848 case 1: /* Unstructured */ 849 break; 850 case 2: /* Unstructed with modem bits. 851 Always one byte as we never send inline break data */ 852 *dp++ = (gsm_encode_modem(dlci) << 1) | EA; 853 break; 854 } 855 WARN_ON(kfifo_out_locked(&dlci->fifo, dp , len, &dlci->lock) != len); 856 __gsm_data_queue(dlci, msg); 857 total_size += size; 858 } 859 /* Bytes of data we used up */ 860 return total_size; 861} 862 863/** 864 * gsm_dlci_data_output_framed - try and push data out of a DLCI 865 * @gsm: mux 866 * @dlci: the DLCI to pull data from 867 * 868 * Pull data from a DLCI and send it into the transmit queue if there 869 * is data. Keep to the MRU of the mux. This path handles framed data 870 * queued as skbuffs to the DLCI. 871 * 872 * Caller must hold the tx_lock of the mux. 873 */ 874 875static int gsm_dlci_data_output_framed(struct gsm_mux *gsm, 876 struct gsm_dlci *dlci) 877{ 878 struct gsm_msg *msg; 879 u8 *dp; 880 int len, size; 881 int last = 0, first = 0; 882 int overhead = 0; 883 884 /* One byte per frame is used for B/F flags */ 885 if (dlci->adaption == 4) 886 overhead = 1; 887 888 /* dlci->skb is locked by tx_lock */ 889 if (dlci->skb == NULL) { 890 dlci->skb = skb_dequeue_tail(&dlci->skb_list); 891 if (dlci->skb == NULL) 892 return 0; 893 first = 1; 894 } 895 len = dlci->skb->len + overhead; 896 897 /* MTU/MRU count only the data bits */ 898 if (len > gsm->mtu) { 899 if (dlci->adaption == 3) { 900 /* Over long frame, bin it */ 901 dev_kfree_skb_any(dlci->skb); 902 dlci->skb = NULL; 903 return 0; 904 } 905 len = gsm->mtu; 906 } else 907 last = 1; 908 909 size = len + overhead; 910 msg = gsm_data_alloc(gsm, dlci->addr, size, gsm->ftype); 911 912 /* FIXME: need a timer or something to kick this so it can't 913 get stuck with no work outstanding and no buffer free */ 914 if (msg == NULL) { 915 skb_queue_tail(&dlci->skb_list, dlci->skb); 916 dlci->skb = NULL; 917 return -ENOMEM; 918 } 919 dp = msg->data; 920 921 if (dlci->adaption == 4) { /* Interruptible framed (Packetised Data) */ 922 /* Flag byte to carry the start/end info */ 923 *dp++ = last << 7 | first << 6 | 1; /* EA */ 924 len--; 925 } 926 memcpy(dp, dlci->skb->data, len); 927 skb_pull(dlci->skb, len); 928 __gsm_data_queue(dlci, msg); 929 if (last) { 930 dev_kfree_skb_any(dlci->skb); 931 dlci->skb = NULL; 932 } 933 return size; 934} 935 936/** 937 * gsm_dlci_modem_output - try and push modem status out of a DLCI 938 * @gsm: mux 939 * @dlci: the DLCI to pull modem status from 940 * @brk: break signal 941 * 942 * Push an empty frame in to the transmit queue to update the modem status 943 * bits and to transmit an optional break. 944 * 945 * Caller must hold the tx_lock of the mux. 946 */ 947 948static int gsm_dlci_modem_output(struct gsm_mux *gsm, struct gsm_dlci *dlci, 949 u8 brk) 950{ 951 u8 *dp = NULL; 952 struct gsm_msg *msg; 953 int size = 0; 954 955 /* for modem bits without break data */ 956 switch (dlci->adaption) { 957 case 1: /* Unstructured */ 958 break; 959 case 2: /* Unstructured with modem bits. */ 960 size++; 961 if (brk > 0) 962 size++; 963 break; 964 default: 965 pr_err("%s: unsupported adaption %d\n", __func__, 966 dlci->adaption); 967 return -EINVAL; 968 } 969 970 msg = gsm_data_alloc(gsm, dlci->addr, size, gsm->ftype); 971 if (!msg) { 972 pr_err("%s: gsm_data_alloc error", __func__); 973 return -ENOMEM; 974 } 975 dp = msg->data; 976 switch (dlci->adaption) { 977 case 1: /* Unstructured */ 978 break; 979 case 2: /* Unstructured with modem bits. */ 980 if (brk == 0) { 981 *dp++ = (gsm_encode_modem(dlci) << 1) | EA; 982 } else { 983 *dp++ = gsm_encode_modem(dlci) << 1; 984 *dp++ = (brk << 4) | 2 | EA; /* Length, Break, EA */ 985 } 986 break; 987 default: 988 /* Handled above */ 989 break; 990 } 991 992 __gsm_data_queue(dlci, msg); 993 return size; 994} 995 996/** 997 * gsm_dlci_data_sweep - look for data to send 998 * @gsm: the GSM mux 999 * 1000 * Sweep the GSM mux channels in priority order looking for ones with 1001 * data to send. We could do with optimising this scan a bit. We aim 1002 * to fill the queue totally or up to TX_THRESH_HI bytes. Once we hit 1003 * TX_THRESH_LO we get called again 1004 * 1005 * FIXME: We should round robin between groups and in theory you can 1006 * renegotiate DLCI priorities with optional stuff. Needs optimising. 1007 */ 1008 1009static void gsm_dlci_data_sweep(struct gsm_mux *gsm) 1010{ 1011 int len; 1012 /* Priority ordering: We should do priority with RR of the groups */ 1013 int i = 1; 1014 1015 while (i < NUM_DLCI) { 1016 struct gsm_dlci *dlci; 1017 1018 if (gsm->tx_bytes > TX_THRESH_HI) 1019 break; 1020 dlci = gsm->dlci[i]; 1021 if (dlci == NULL || dlci->constipated) { 1022 i++; 1023 continue; 1024 } 1025 if (dlci->adaption < 3 && !dlci->net) 1026 len = gsm_dlci_data_output(gsm, dlci); 1027 else 1028 len = gsm_dlci_data_output_framed(gsm, dlci); 1029 if (len < 0) 1030 break; 1031 /* DLCI empty - try the next */ 1032 if (len == 0) 1033 i++; 1034 } 1035} 1036 1037/** 1038 * gsm_dlci_data_kick - transmit if possible 1039 * @dlci: DLCI to kick 1040 * 1041 * Transmit data from this DLCI if the queue is empty. We can't rely on 1042 * a tty wakeup except when we filled the pipe so we need to fire off 1043 * new data ourselves in other cases. 1044 */ 1045 1046static void gsm_dlci_data_kick(struct gsm_dlci *dlci) 1047{ 1048 unsigned long flags; 1049 int sweep; 1050 1051 if (dlci->constipated) 1052 return; 1053 1054 spin_lock_irqsave(&dlci->gsm->tx_lock, flags); 1055 /* If we have nothing running then we need to fire up */ 1056 sweep = (dlci->gsm->tx_bytes < TX_THRESH_LO); 1057 if (dlci->gsm->tx_bytes == 0) { 1058 if (dlci->net) 1059 gsm_dlci_data_output_framed(dlci->gsm, dlci); 1060 else 1061 gsm_dlci_data_output(dlci->gsm, dlci); 1062 } 1063 if (sweep) 1064 gsm_dlci_data_sweep(dlci->gsm); 1065 spin_unlock_irqrestore(&dlci->gsm->tx_lock, flags); 1066} 1067 1068/* 1069 * Control message processing 1070 */ 1071 1072 1073/** 1074 * gsm_control_reply - send a response frame to a control 1075 * @gsm: gsm channel 1076 * @cmd: the command to use 1077 * @data: data to follow encoded info 1078 * @dlen: length of data 1079 * 1080 * Encode up and queue a UI/UIH frame containing our response. 1081 */ 1082 1083static void gsm_control_reply(struct gsm_mux *gsm, int cmd, const u8 *data, 1084 int dlen) 1085{ 1086 struct gsm_msg *msg; 1087 msg = gsm_data_alloc(gsm, 0, dlen + 2, gsm->ftype); 1088 if (msg == NULL) 1089 return; 1090 msg->data[0] = (cmd & 0xFE) << 1 | EA; /* Clear C/R */ 1091 msg->data[1] = (dlen << 1) | EA; 1092 memcpy(msg->data + 2, data, dlen); 1093 gsm_data_queue(gsm->dlci[0], msg); 1094} 1095 1096/** 1097 * gsm_process_modem - process received modem status 1098 * @tty: virtual tty bound to the DLCI 1099 * @dlci: DLCI to affect 1100 * @modem: modem bits (full EA) 1101 * @slen: number of signal octets 1102 * 1103 * Used when a modem control message or line state inline in adaption 1104 * layer 2 is processed. Sort out the local modem state and throttles 1105 */ 1106 1107static void gsm_process_modem(struct tty_struct *tty, struct gsm_dlci *dlci, 1108 u32 modem, int slen) 1109{ 1110 int mlines = 0; 1111 u8 brk = 0; 1112 int fc; 1113 1114 /* The modem status command can either contain one octet (V.24 signals) 1115 * or two octets (V.24 signals + break signals). This is specified in 1116 * section 5.4.6.3.7 of the 07.10 mux spec. 1117 */ 1118 1119 if (slen == 1) 1120 modem = modem & 0x7f; 1121 else { 1122 brk = modem & 0x7f; 1123 modem = (modem >> 7) & 0x7f; 1124 } 1125 1126 /* Flow control/ready to communicate */ 1127 fc = (modem & MDM_FC) || !(modem & MDM_RTR); 1128 if (fc && !dlci->constipated) { 1129 /* Need to throttle our output on this device */ 1130 dlci->constipated = true; 1131 } else if (!fc && dlci->constipated) { 1132 dlci->constipated = false; 1133 gsm_dlci_data_kick(dlci); 1134 } 1135 1136 /* Map modem bits */ 1137 if (modem & MDM_RTC) 1138 mlines |= TIOCM_DSR | TIOCM_DTR; 1139 if (modem & MDM_RTR) 1140 mlines |= TIOCM_RTS | TIOCM_CTS; 1141 if (modem & MDM_IC) 1142 mlines |= TIOCM_RI; 1143 if (modem & MDM_DV) 1144 mlines |= TIOCM_CD; 1145 1146 /* Carrier drop -> hangup */ 1147 if (tty) { 1148 if ((mlines & TIOCM_CD) == 0 && (dlci->modem_rx & TIOCM_CD)) 1149 if (!C_CLOCAL(tty)) 1150 tty_hangup(tty); 1151 } 1152 if (brk & 0x01) 1153 tty_insert_flip_char(&dlci->port, 0, TTY_BREAK); 1154 dlci->modem_rx = mlines; 1155} 1156 1157/** 1158 * gsm_control_modem - modem status received 1159 * @gsm: GSM channel 1160 * @data: data following command 1161 * @clen: command length 1162 * 1163 * We have received a modem status control message. This is used by 1164 * the GSM mux protocol to pass virtual modem line status and optionally 1165 * to indicate break signals. Unpack it, convert to Linux representation 1166 * and if need be stuff a break message down the tty. 1167 */ 1168 1169static void gsm_control_modem(struct gsm_mux *gsm, const u8 *data, int clen) 1170{ 1171 unsigned int addr = 0; 1172 unsigned int modem = 0; 1173 struct gsm_dlci *dlci; 1174 int len = clen; 1175 int slen; 1176 const u8 *dp = data; 1177 struct tty_struct *tty; 1178 1179 while (gsm_read_ea(&addr, *dp++) == 0) { 1180 len--; 1181 if (len == 0) 1182 return; 1183 } 1184 /* Must be at least one byte following the EA */ 1185 len--; 1186 if (len <= 0) 1187 return; 1188 1189 addr >>= 1; 1190 /* Closed port, or invalid ? */ 1191 if (addr == 0 || addr >= NUM_DLCI || gsm->dlci[addr] == NULL) 1192 return; 1193 dlci = gsm->dlci[addr]; 1194 1195 slen = len; 1196 while (gsm_read_ea(&modem, *dp++) == 0) { 1197 len--; 1198 if (len == 0) 1199 return; 1200 } 1201 len--; 1202 tty = tty_port_tty_get(&dlci->port); 1203 gsm_process_modem(tty, dlci, modem, slen - len); 1204 if (tty) { 1205 tty_wakeup(tty); 1206 tty_kref_put(tty); 1207 } 1208 gsm_control_reply(gsm, CMD_MSC, data, clen); 1209} 1210 1211/** 1212 * gsm_control_rls - remote line status 1213 * @gsm: GSM channel 1214 * @data: data bytes 1215 * @clen: data length 1216 * 1217 * The modem sends us a two byte message on the control channel whenever 1218 * it wishes to send us an error state from the virtual link. Stuff 1219 * this into the uplink tty if present 1220 */ 1221 1222static void gsm_control_rls(struct gsm_mux *gsm, const u8 *data, int clen) 1223{ 1224 struct tty_port *port; 1225 unsigned int addr = 0; 1226 u8 bits; 1227 int len = clen; 1228 const u8 *dp = data; 1229 1230 while (gsm_read_ea(&addr, *dp++) == 0) { 1231 len--; 1232 if (len == 0) 1233 return; 1234 } 1235 /* Must be at least one byte following ea */ 1236 len--; 1237 if (len <= 0) 1238 return; 1239 addr >>= 1; 1240 /* Closed port, or invalid ? */ 1241 if (addr == 0 || addr >= NUM_DLCI || gsm->dlci[addr] == NULL) 1242 return; 1243 /* No error ? */ 1244 bits = *dp; 1245 if ((bits & 1) == 0) 1246 return; 1247 1248 port = &gsm->dlci[addr]->port; 1249 1250 if (bits & 2) 1251 tty_insert_flip_char(port, 0, TTY_OVERRUN); 1252 if (bits & 4) 1253 tty_insert_flip_char(port, 0, TTY_PARITY); 1254 if (bits & 8) 1255 tty_insert_flip_char(port, 0, TTY_FRAME); 1256 1257 tty_flip_buffer_push(port); 1258 1259 gsm_control_reply(gsm, CMD_RLS, data, clen); 1260} 1261 1262static void gsm_dlci_begin_close(struct gsm_dlci *dlci); 1263 1264/** 1265 * gsm_control_message - DLCI 0 control processing 1266 * @gsm: our GSM mux 1267 * @command: the command EA 1268 * @data: data beyond the command/length EAs 1269 * @clen: length 1270 * 1271 * Input processor for control messages from the other end of the link. 1272 * Processes the incoming request and queues a response frame or an 1273 * NSC response if not supported 1274 */ 1275 1276static void gsm_control_message(struct gsm_mux *gsm, unsigned int command, 1277 const u8 *data, int clen) 1278{ 1279 u8 buf[1]; 1280 unsigned long flags; 1281 1282 switch (command) { 1283 case CMD_CLD: { 1284 struct gsm_dlci *dlci = gsm->dlci[0]; 1285 /* Modem wishes to close down */ 1286 if (dlci) { 1287 dlci->dead = true; 1288 gsm->dead = true; 1289 gsm_dlci_begin_close(dlci); 1290 } 1291 } 1292 break; 1293 case CMD_TEST: 1294 /* Modem wishes to test, reply with the data */ 1295 gsm_control_reply(gsm, CMD_TEST, data, clen); 1296 break; 1297 case CMD_FCON: 1298 /* Modem can accept data again */ 1299 gsm->constipated = false; 1300 gsm_control_reply(gsm, CMD_FCON, NULL, 0); 1301 /* Kick the link in case it is idling */ 1302 spin_lock_irqsave(&gsm->tx_lock, flags); 1303 gsm_data_kick(gsm, NULL); 1304 spin_unlock_irqrestore(&gsm->tx_lock, flags); 1305 break; 1306 case CMD_FCOFF: 1307 /* Modem wants us to STFU */ 1308 gsm->constipated = true; 1309 gsm_control_reply(gsm, CMD_FCOFF, NULL, 0); 1310 break; 1311 case CMD_MSC: 1312 /* Out of band modem line change indicator for a DLCI */ 1313 gsm_control_modem(gsm, data, clen); 1314 break; 1315 case CMD_RLS: 1316 /* Out of band error reception for a DLCI */ 1317 gsm_control_rls(gsm, data, clen); 1318 break; 1319 case CMD_PSC: 1320 /* Modem wishes to enter power saving state */ 1321 gsm_control_reply(gsm, CMD_PSC, NULL, 0); 1322 break; 1323 /* Optional unsupported commands */ 1324 case CMD_PN: /* Parameter negotiation */ 1325 case CMD_RPN: /* Remote port negotiation */ 1326 case CMD_SNC: /* Service negotiation command */ 1327 default: 1328 /* Reply to bad commands with an NSC */ 1329 buf[0] = command; 1330 gsm_control_reply(gsm, CMD_NSC, buf, 1); 1331 break; 1332 } 1333} 1334 1335/** 1336 * gsm_control_response - process a response to our control 1337 * @gsm: our GSM mux 1338 * @command: the command (response) EA 1339 * @data: data beyond the command/length EA 1340 * @clen: length 1341 * 1342 * Process a response to an outstanding command. We only allow a single 1343 * control message in flight so this is fairly easy. All the clean up 1344 * is done by the caller, we just update the fields, flag it as done 1345 * and return 1346 */ 1347 1348static void gsm_control_response(struct gsm_mux *gsm, unsigned int command, 1349 const u8 *data, int clen) 1350{ 1351 struct gsm_control *ctrl; 1352 unsigned long flags; 1353 1354 spin_lock_irqsave(&gsm->control_lock, flags); 1355 1356 ctrl = gsm->pending_cmd; 1357 /* Does the reply match our command */ 1358 command |= 1; 1359 if (ctrl != NULL && (command == ctrl->cmd || command == CMD_NSC)) { 1360 /* Our command was replied to, kill the retry timer */ 1361 del_timer(&gsm->t2_timer); 1362 gsm->pending_cmd = NULL; 1363 /* Rejected by the other end */ 1364 if (command == CMD_NSC) 1365 ctrl->error = -EOPNOTSUPP; 1366 ctrl->done = 1; 1367 wake_up(&gsm->event); 1368 } 1369 spin_unlock_irqrestore(&gsm->control_lock, flags); 1370} 1371 1372/** 1373 * gsm_control_transmit - send control packet 1374 * @gsm: gsm mux 1375 * @ctrl: frame to send 1376 * 1377 * Send out a pending control command (called under control lock) 1378 */ 1379 1380static void gsm_control_transmit(struct gsm_mux *gsm, struct gsm_control *ctrl) 1381{ 1382 struct gsm_msg *msg = gsm_data_alloc(gsm, 0, ctrl->len + 2, gsm->ftype); 1383 if (msg == NULL) 1384 return; 1385 msg->data[0] = (ctrl->cmd << 1) | CR | EA; /* command */ 1386 msg->data[1] = (ctrl->len << 1) | EA; 1387 memcpy(msg->data + 2, ctrl->data, ctrl->len); 1388 gsm_data_queue(gsm->dlci[0], msg); 1389} 1390 1391/** 1392 * gsm_control_retransmit - retransmit a control frame 1393 * @t: timer contained in our gsm object 1394 * 1395 * Called off the T2 timer expiry in order to retransmit control frames 1396 * that have been lost in the system somewhere. The control_lock protects 1397 * us from colliding with another sender or a receive completion event. 1398 * In that situation the timer may still occur in a small window but 1399 * gsm->pending_cmd will be NULL and we just let the timer expire. 1400 */ 1401 1402static void gsm_control_retransmit(struct timer_list *t) 1403{ 1404 struct gsm_mux *gsm = from_timer(gsm, t, t2_timer); 1405 struct gsm_control *ctrl; 1406 unsigned long flags; 1407 spin_lock_irqsave(&gsm->control_lock, flags); 1408 ctrl = gsm->pending_cmd; 1409 if (ctrl) { 1410 if (gsm->cretries == 0) { 1411 gsm->pending_cmd = NULL; 1412 ctrl->error = -ETIMEDOUT; 1413 ctrl->done = 1; 1414 spin_unlock_irqrestore(&gsm->control_lock, flags); 1415 wake_up(&gsm->event); 1416 return; 1417 } 1418 gsm->cretries--; 1419 gsm_control_transmit(gsm, ctrl); 1420 mod_timer(&gsm->t2_timer, jiffies + gsm->t2 * HZ / 100); 1421 } 1422 spin_unlock_irqrestore(&gsm->control_lock, flags); 1423} 1424 1425/** 1426 * gsm_control_send - send a control frame on DLCI 0 1427 * @gsm: the GSM channel 1428 * @command: command to send including CR bit 1429 * @data: bytes of data (must be kmalloced) 1430 * @clen: length of the block to send 1431 * 1432 * Queue and dispatch a control command. Only one command can be 1433 * active at a time. In theory more can be outstanding but the matching 1434 * gets really complicated so for now stick to one outstanding. 1435 */ 1436 1437static struct gsm_control *gsm_control_send(struct gsm_mux *gsm, 1438 unsigned int command, u8 *data, int clen) 1439{ 1440 struct gsm_control *ctrl = kzalloc(sizeof(struct gsm_control), 1441 GFP_KERNEL); 1442 unsigned long flags; 1443 if (ctrl == NULL) 1444 return NULL; 1445retry: 1446 wait_event(gsm->event, gsm->pending_cmd == NULL); 1447 spin_lock_irqsave(&gsm->control_lock, flags); 1448 if (gsm->pending_cmd != NULL) { 1449 spin_unlock_irqrestore(&gsm->control_lock, flags); 1450 goto retry; 1451 } 1452 ctrl->cmd = command; 1453 ctrl->data = data; 1454 ctrl->len = clen; 1455 gsm->pending_cmd = ctrl; 1456 1457 /* If DLCI0 is in ADM mode skip retries, it won't respond */ 1458 if (gsm->dlci[0]->mode == DLCI_MODE_ADM) 1459 gsm->cretries = 0; 1460 else 1461 gsm->cretries = gsm->n2; 1462 1463 mod_timer(&gsm->t2_timer, jiffies + gsm->t2 * HZ / 100); 1464 gsm_control_transmit(gsm, ctrl); 1465 spin_unlock_irqrestore(&gsm->control_lock, flags); 1466 return ctrl; 1467} 1468 1469/** 1470 * gsm_control_wait - wait for a control to finish 1471 * @gsm: GSM mux 1472 * @control: control we are waiting on 1473 * 1474 * Waits for the control to complete or time out. Frees any used 1475 * resources and returns 0 for success, or an error if the remote 1476 * rejected or ignored the request. 1477 */ 1478 1479static int gsm_control_wait(struct gsm_mux *gsm, struct gsm_control *control) 1480{ 1481 int err; 1482 wait_event(gsm->event, control->done == 1); 1483 err = control->error; 1484 kfree(control); 1485 return err; 1486} 1487 1488 1489/* 1490 * DLCI level handling: Needs krefs 1491 */ 1492 1493/* 1494 * State transitions and timers 1495 */ 1496 1497/** 1498 * gsm_dlci_close - a DLCI has closed 1499 * @dlci: DLCI that closed 1500 * 1501 * Perform processing when moving a DLCI into closed state. If there 1502 * is an attached tty this is hung up 1503 */ 1504 1505static void gsm_dlci_close(struct gsm_dlci *dlci) 1506{ 1507 unsigned long flags; 1508 1509 del_timer(&dlci->t1); 1510 if (debug & 8) 1511 pr_debug("DLCI %d goes closed.\n", dlci->addr); 1512 dlci->state = DLCI_CLOSED; 1513 if (dlci->addr != 0) { 1514 tty_port_tty_hangup(&dlci->port, false); 1515 spin_lock_irqsave(&dlci->lock, flags); 1516 kfifo_reset(&dlci->fifo); 1517 spin_unlock_irqrestore(&dlci->lock, flags); 1518 /* Ensure that gsmtty_open() can return. */ 1519 tty_port_set_initialized(&dlci->port, 0); 1520 wake_up_interruptible(&dlci->port.open_wait); 1521 } else 1522 dlci->gsm->dead = true; 1523 wake_up(&dlci->gsm->event); 1524 /* A DLCI 0 close is a MUX termination so we need to kick that 1525 back to userspace somehow */ 1526} 1527 1528/** 1529 * gsm_dlci_open - a DLCI has opened 1530 * @dlci: DLCI that opened 1531 * 1532 * Perform processing when moving a DLCI into open state. 1533 */ 1534 1535static void gsm_dlci_open(struct gsm_dlci *dlci) 1536{ 1537 /* Note that SABM UA .. SABM UA first UA lost can mean that we go 1538 open -> open */ 1539 del_timer(&dlci->t1); 1540 /* This will let a tty open continue */ 1541 dlci->state = DLCI_OPEN; 1542 if (debug & 8) 1543 pr_debug("DLCI %d goes open.\n", dlci->addr); 1544 /* Send current modem state */ 1545 if (dlci->addr) 1546 gsm_modem_update(dlci, 0); 1547 wake_up(&dlci->gsm->event); 1548} 1549 1550/** 1551 * gsm_dlci_t1 - T1 timer expiry 1552 * @t: timer contained in the DLCI that opened 1553 * 1554 * The T1 timer handles retransmits of control frames (essentially of 1555 * SABM and DISC). We resend the command until the retry count runs out 1556 * in which case an opening port goes back to closed and a closing port 1557 * is simply put into closed state (any further frames from the other 1558 * end will get a DM response) 1559 * 1560 * Some control dlci can stay in ADM mode with other dlci working just 1561 * fine. In that case we can just keep the control dlci open after the 1562 * DLCI_OPENING retries time out. 1563 */ 1564 1565static void gsm_dlci_t1(struct timer_list *t) 1566{ 1567 struct gsm_dlci *dlci = from_timer(dlci, t, t1); 1568 struct gsm_mux *gsm = dlci->gsm; 1569 1570 switch (dlci->state) { 1571 case DLCI_OPENING: 1572 dlci->retries--; 1573 if (dlci->retries) { 1574 gsm_command(dlci->gsm, dlci->addr, SABM|PF); 1575 mod_timer(&dlci->t1, jiffies + gsm->t1 * HZ / 100); 1576 } else if (!dlci->addr && gsm->control == (DM | PF)) { 1577 if (debug & 8) 1578 pr_info("DLCI %d opening in ADM mode.\n", 1579 dlci->addr); 1580 dlci->mode = DLCI_MODE_ADM; 1581 gsm_dlci_open(dlci); 1582 } else { 1583 gsm_dlci_begin_close(dlci); /* prevent half open link */ 1584 } 1585 1586 break; 1587 case DLCI_CLOSING: 1588 dlci->retries--; 1589 if (dlci->retries) { 1590 gsm_command(dlci->gsm, dlci->addr, DISC|PF); 1591 mod_timer(&dlci->t1, jiffies + gsm->t1 * HZ / 100); 1592 } else 1593 gsm_dlci_close(dlci); 1594 break; 1595 default: 1596 pr_debug("%s: unhandled state: %d\n", __func__, dlci->state); 1597 break; 1598 } 1599} 1600 1601/** 1602 * gsm_dlci_begin_open - start channel open procedure 1603 * @dlci: DLCI to open 1604 * 1605 * Commence opening a DLCI from the Linux side. We issue SABM messages 1606 * to the modem which should then reply with a UA or ADM, at which point 1607 * we will move into open state. Opening is done asynchronously with retry 1608 * running off timers and the responses. 1609 */ 1610 1611static void gsm_dlci_begin_open(struct gsm_dlci *dlci) 1612{ 1613 struct gsm_mux *gsm = dlci->gsm; 1614 if (dlci->state == DLCI_OPEN || dlci->state == DLCI_OPENING) 1615 return; 1616 dlci->retries = gsm->n2; 1617 dlci->state = DLCI_OPENING; 1618 gsm_command(dlci->gsm, dlci->addr, SABM|PF); 1619 mod_timer(&dlci->t1, jiffies + gsm->t1 * HZ / 100); 1620} 1621 1622/** 1623 * gsm_dlci_begin_close - start channel open procedure 1624 * @dlci: DLCI to open 1625 * 1626 * Commence closing a DLCI from the Linux side. We issue DISC messages 1627 * to the modem which should then reply with a UA, at which point we 1628 * will move into closed state. Closing is done asynchronously with retry 1629 * off timers. We may also receive a DM reply from the other end which 1630 * indicates the channel was already closed. 1631 */ 1632 1633static void gsm_dlci_begin_close(struct gsm_dlci *dlci) 1634{ 1635 struct gsm_mux *gsm = dlci->gsm; 1636 if (dlci->state == DLCI_CLOSED || dlci->state == DLCI_CLOSING) 1637 return; 1638 dlci->retries = gsm->n2; 1639 dlci->state = DLCI_CLOSING; 1640 gsm_command(dlci->gsm, dlci->addr, DISC|PF); 1641 mod_timer(&dlci->t1, jiffies + gsm->t1 * HZ / 100); 1642} 1643 1644/** 1645 * gsm_dlci_data - data arrived 1646 * @dlci: channel 1647 * @data: block of bytes received 1648 * @clen: length of received block 1649 * 1650 * A UI or UIH frame has arrived which contains data for a channel 1651 * other than the control channel. If the relevant virtual tty is 1652 * open we shovel the bits down it, if not we drop them. 1653 */ 1654 1655static void gsm_dlci_data(struct gsm_dlci *dlci, const u8 *data, int clen) 1656{ 1657 /* krefs .. */ 1658 struct tty_port *port = &dlci->port; 1659 struct tty_struct *tty; 1660 unsigned int modem = 0; 1661 int len = clen; 1662 int slen = 0; 1663 1664 if (debug & 16) 1665 pr_debug("%d bytes for tty\n", len); 1666 switch (dlci->adaption) { 1667 /* Unsupported types */ 1668 case 4: /* Packetised interruptible data */ 1669 break; 1670 case 3: /* Packetised uininterruptible voice/data */ 1671 break; 1672 case 2: /* Asynchronous serial with line state in each frame */ 1673 while (gsm_read_ea(&modem, *data++) == 0) { 1674 len--; 1675 slen++; 1676 if (len == 0) 1677 return; 1678 } 1679 len--; 1680 slen++; 1681 tty = tty_port_tty_get(port); 1682 if (tty) { 1683 gsm_process_modem(tty, dlci, modem, slen); 1684 tty_wakeup(tty); 1685 tty_kref_put(tty); 1686 } 1687 fallthrough; 1688 case 1: /* Line state will go via DLCI 0 controls only */ 1689 default: 1690 tty_insert_flip_string(port, data, len); 1691 tty_flip_buffer_push(port); 1692 } 1693} 1694 1695/** 1696 * gsm_dlci_command - data arrived on control channel 1697 * @dlci: channel 1698 * @data: block of bytes received 1699 * @len: length of received block 1700 * 1701 * A UI or UIH frame has arrived which contains data for DLCI 0 the 1702 * control channel. This should contain a command EA followed by 1703 * control data bytes. The command EA contains a command/response bit 1704 * and we divide up the work accordingly. 1705 */ 1706 1707static void gsm_dlci_command(struct gsm_dlci *dlci, const u8 *data, int len) 1708{ 1709 /* See what command is involved */ 1710 unsigned int command = 0; 1711 while (len-- > 0) { 1712 if (gsm_read_ea(&command, *data++) == 1) { 1713 int clen = *data++; 1714 len--; 1715 /* FIXME: this is properly an EA */ 1716 clen >>= 1; 1717 /* Malformed command ? */ 1718 if (clen > len) 1719 return; 1720 if (command & 1) 1721 gsm_control_message(dlci->gsm, command, 1722 data, clen); 1723 else 1724 gsm_control_response(dlci->gsm, command, 1725 data, clen); 1726 return; 1727 } 1728 } 1729} 1730 1731/* 1732 * Allocate/Free DLCI channels 1733 */ 1734 1735/** 1736 * gsm_dlci_alloc - allocate a DLCI 1737 * @gsm: GSM mux 1738 * @addr: address of the DLCI 1739 * 1740 * Allocate and install a new DLCI object into the GSM mux. 1741 * 1742 * FIXME: review locking races 1743 */ 1744 1745static struct gsm_dlci *gsm_dlci_alloc(struct gsm_mux *gsm, int addr) 1746{ 1747 struct gsm_dlci *dlci = kzalloc(sizeof(struct gsm_dlci), GFP_ATOMIC); 1748 if (dlci == NULL) 1749 return NULL; 1750 spin_lock_init(&dlci->lock); 1751 mutex_init(&dlci->mutex); 1752 if (kfifo_alloc(&dlci->fifo, TX_SIZE, GFP_KERNEL) < 0) { 1753 kfree(dlci); 1754 return NULL; 1755 } 1756 1757 skb_queue_head_init(&dlci->skb_list); 1758 timer_setup(&dlci->t1, gsm_dlci_t1, 0); 1759 tty_port_init(&dlci->port); 1760 dlci->port.ops = &gsm_port_ops; 1761 dlci->gsm = gsm; 1762 dlci->addr = addr; 1763 dlci->adaption = gsm->adaption; 1764 dlci->state = DLCI_CLOSED; 1765 if (addr) 1766 dlci->data = gsm_dlci_data; 1767 else 1768 dlci->data = gsm_dlci_command; 1769 gsm->dlci[addr] = dlci; 1770 return dlci; 1771} 1772 1773/** 1774 * gsm_dlci_free - free DLCI 1775 * @port: tty port for DLCI to free 1776 * 1777 * Free up a DLCI. 1778 * 1779 * Can sleep. 1780 */ 1781static void gsm_dlci_free(struct tty_port *port) 1782{ 1783 struct gsm_dlci *dlci = container_of(port, struct gsm_dlci, port); 1784 1785 del_timer_sync(&dlci->t1); 1786 dlci->gsm->dlci[dlci->addr] = NULL; 1787 kfifo_free(&dlci->fifo); 1788 while ((dlci->skb = skb_dequeue(&dlci->skb_list))) 1789 dev_kfree_skb(dlci->skb); 1790 kfree(dlci); 1791} 1792 1793static inline void dlci_get(struct gsm_dlci *dlci) 1794{ 1795 tty_port_get(&dlci->port); 1796} 1797 1798static inline void dlci_put(struct gsm_dlci *dlci) 1799{ 1800 tty_port_put(&dlci->port); 1801} 1802 1803static void gsm_destroy_network(struct gsm_dlci *dlci); 1804 1805/** 1806 * gsm_dlci_release - release DLCI 1807 * @dlci: DLCI to destroy 1808 * 1809 * Release a DLCI. Actual free is deferred until either 1810 * mux is closed or tty is closed - whichever is last. 1811 * 1812 * Can sleep. 1813 */ 1814static void gsm_dlci_release(struct gsm_dlci *dlci) 1815{ 1816 struct tty_struct *tty = tty_port_tty_get(&dlci->port); 1817 if (tty) { 1818 mutex_lock(&dlci->mutex); 1819 gsm_destroy_network(dlci); 1820 mutex_unlock(&dlci->mutex); 1821 1822 /* We cannot use tty_hangup() because in tty_kref_put() the tty 1823 * driver assumes that the hangup queue is free and reuses it to 1824 * queue release_one_tty() -> NULL pointer panic in 1825 * process_one_work(). 1826 */ 1827 tty_vhangup(tty); 1828 1829 tty_port_tty_set(&dlci->port, NULL); 1830 tty_kref_put(tty); 1831 } 1832 dlci->state = DLCI_CLOSED; 1833 dlci_put(dlci); 1834} 1835 1836/* 1837 * LAPBish link layer logic 1838 */ 1839 1840/** 1841 * gsm_queue - a GSM frame is ready to process 1842 * @gsm: pointer to our gsm mux 1843 * 1844 * At this point in time a frame has arrived and been demangled from 1845 * the line encoding. All the differences between the encodings have 1846 * been handled below us and the frame is unpacked into the structures. 1847 * The fcs holds the header FCS but any data FCS must be added here. 1848 */ 1849 1850static void gsm_queue(struct gsm_mux *gsm) 1851{ 1852 struct gsm_dlci *dlci; 1853 u8 cr; 1854 int address; 1855 1856 if (gsm->fcs != GOOD_FCS) { 1857 gsm->bad_fcs++; 1858 if (debug & 4) 1859 pr_debug("BAD FCS %02x\n", gsm->fcs); 1860 return; 1861 } 1862 address = gsm->address >> 1; 1863 if (address >= NUM_DLCI) 1864 goto invalid; 1865 1866 cr = gsm->address & 1; /* C/R bit */ 1867 cr ^= gsm->initiator ? 0 : 1; /* Flip so 1 always means command */ 1868 1869 gsm_print_packet("<--", address, cr, gsm->control, gsm->buf, gsm->len); 1870 1871 dlci = gsm->dlci[address]; 1872 1873 switch (gsm->control) { 1874 case SABM|PF: 1875 if (cr == 1) 1876 goto invalid; 1877 if (dlci == NULL) 1878 dlci = gsm_dlci_alloc(gsm, address); 1879 if (dlci == NULL) 1880 return; 1881 if (dlci->dead) 1882 gsm_response(gsm, address, DM|PF); 1883 else { 1884 gsm_response(gsm, address, UA|PF); 1885 gsm_dlci_open(dlci); 1886 } 1887 break; 1888 case DISC|PF: 1889 if (cr == 1) 1890 goto invalid; 1891 if (dlci == NULL || dlci->state == DLCI_CLOSED) { 1892 gsm_response(gsm, address, DM|PF); 1893 return; 1894 } 1895 /* Real close complete */ 1896 gsm_response(gsm, address, UA|PF); 1897 gsm_dlci_close(dlci); 1898 break; 1899 case UA|PF: 1900 if (cr == 0 || dlci == NULL) 1901 break; 1902 switch (dlci->state) { 1903 case DLCI_CLOSING: 1904 gsm_dlci_close(dlci); 1905 break; 1906 case DLCI_OPENING: 1907 gsm_dlci_open(dlci); 1908 break; 1909 default: 1910 pr_debug("%s: unhandled state: %d\n", __func__, 1911 dlci->state); 1912 break; 1913 } 1914 break; 1915 case DM: /* DM can be valid unsolicited */ 1916 case DM|PF: 1917 if (cr) 1918 goto invalid; 1919 if (dlci == NULL) 1920 return; 1921 gsm_dlci_close(dlci); 1922 break; 1923 case UI: 1924 case UI|PF: 1925 case UIH: 1926 case UIH|PF: 1927 if (dlci == NULL || dlci->state != DLCI_OPEN) { 1928 gsm_command(gsm, address, DM|PF); 1929 return; 1930 } 1931 dlci->data(dlci, gsm->buf, gsm->len); 1932 break; 1933 default: 1934 goto invalid; 1935 } 1936 return; 1937invalid: 1938 gsm->malformed++; 1939 return; 1940} 1941 1942 1943/** 1944 * gsm0_receive - perform processing for non-transparency 1945 * @gsm: gsm data for this ldisc instance 1946 * @c: character 1947 * 1948 * Receive bytes in gsm mode 0 1949 */ 1950 1951static void gsm0_receive(struct gsm_mux *gsm, unsigned char c) 1952{ 1953 unsigned int len; 1954 1955 switch (gsm->state) { 1956 case GSM_SEARCH: /* SOF marker */ 1957 if (c == GSM0_SOF) { 1958 gsm->state = GSM_ADDRESS; 1959 gsm->address = 0; 1960 gsm->len = 0; 1961 gsm->fcs = INIT_FCS; 1962 } 1963 break; 1964 case GSM_ADDRESS: /* Address EA */ 1965 gsm->fcs = gsm_fcs_add(gsm->fcs, c); 1966 if (gsm_read_ea(&gsm->address, c)) 1967 gsm->state = GSM_CONTROL; 1968 break; 1969 case GSM_CONTROL: /* Control Byte */ 1970 gsm->fcs = gsm_fcs_add(gsm->fcs, c); 1971 gsm->control = c; 1972 gsm->state = GSM_LEN0; 1973 break; 1974 case GSM_LEN0: /* Length EA */ 1975 gsm->fcs = gsm_fcs_add(gsm->fcs, c); 1976 if (gsm_read_ea(&gsm->len, c)) { 1977 if (gsm->len > gsm->mru) { 1978 gsm->bad_size++; 1979 gsm->state = GSM_SEARCH; 1980 break; 1981 } 1982 gsm->count = 0; 1983 if (!gsm->len) 1984 gsm->state = GSM_FCS; 1985 else 1986 gsm->state = GSM_DATA; 1987 break; 1988 } 1989 gsm->state = GSM_LEN1; 1990 break; 1991 case GSM_LEN1: 1992 gsm->fcs = gsm_fcs_add(gsm->fcs, c); 1993 len = c; 1994 gsm->len |= len << 7; 1995 if (gsm->len > gsm->mru) { 1996 gsm->bad_size++; 1997 gsm->state = GSM_SEARCH; 1998 break; 1999 } 2000 gsm->count = 0; 2001 if (!gsm->len) 2002 gsm->state = GSM_FCS; 2003 else 2004 gsm->state = GSM_DATA; 2005 break; 2006 case GSM_DATA: /* Data */ 2007 gsm->buf[gsm->count++] = c; 2008 if (gsm->count == gsm->len) { 2009 /* Calculate final FCS for UI frames over all data */ 2010 if ((gsm->control & ~PF) != UIH) { 2011 gsm->fcs = gsm_fcs_add_block(gsm->fcs, gsm->buf, 2012 gsm->count); 2013 } 2014 gsm->state = GSM_FCS; 2015 } 2016 break; 2017 case GSM_FCS: /* FCS follows the packet */ 2018 gsm->fcs = gsm_fcs_add(gsm->fcs, c); 2019 gsm->state = GSM_SSOF; 2020 break; 2021 case GSM_SSOF: 2022 gsm->state = GSM_SEARCH; 2023 if (c == GSM0_SOF) 2024 gsm_queue(gsm); 2025 else 2026 gsm->bad_size++; 2027 break; 2028 default: 2029 pr_debug("%s: unhandled state: %d\n", __func__, gsm->state); 2030 break; 2031 } 2032} 2033 2034/** 2035 * gsm1_receive - perform processing for non-transparency 2036 * @gsm: gsm data for this ldisc instance 2037 * @c: character 2038 * 2039 * Receive bytes in mode 1 (Advanced option) 2040 */ 2041 2042static void gsm1_receive(struct gsm_mux *gsm, unsigned char c) 2043{ 2044 /* handle XON/XOFF */ 2045 if ((c & ISO_IEC_646_MASK) == XON) { 2046 gsm->constipated = true; 2047 return; 2048 } else if ((c & ISO_IEC_646_MASK) == XOFF) { 2049 gsm->constipated = false; 2050 /* Kick the link in case it is idling */ 2051 gsm_data_kick(gsm, NULL); 2052 return; 2053 } 2054 if (c == GSM1_SOF) { 2055 /* EOF is only valid in frame if we have got to the data state */ 2056 if (gsm->state == GSM_DATA) { 2057 if (gsm->count < 1) { 2058 /* Missing FSC */ 2059 gsm->malformed++; 2060 gsm->state = GSM_START; 2061 return; 2062 } 2063 /* Remove the FCS from data */ 2064 gsm->count--; 2065 if ((gsm->control & ~PF) != UIH) { 2066 /* Calculate final FCS for UI frames over all 2067 * data but FCS 2068 */ 2069 gsm->fcs = gsm_fcs_add_block(gsm->fcs, gsm->buf, 2070 gsm->count); 2071 } 2072 /* Add the FCS itself to test against GOOD_FCS */ 2073 gsm->fcs = gsm_fcs_add(gsm->fcs, gsm->buf[gsm->count]); 2074 gsm->len = gsm->count; 2075 gsm_queue(gsm); 2076 gsm->state = GSM_START; 2077 return; 2078 } 2079 /* Any partial frame was a runt so go back to start */ 2080 if (gsm->state != GSM_START) { 2081 if (gsm->state != GSM_SEARCH) 2082 gsm->malformed++; 2083 gsm->state = GSM_START; 2084 } 2085 /* A SOF in GSM_START means we are still reading idling or 2086 framing bytes */ 2087 return; 2088 } 2089 2090 if (c == GSM1_ESCAPE) { 2091 gsm->escape = true; 2092 return; 2093 } 2094 2095 /* Only an unescaped SOF gets us out of GSM search */ 2096 if (gsm->state == GSM_SEARCH) 2097 return; 2098 2099 if (gsm->escape) { 2100 c ^= GSM1_ESCAPE_BITS; 2101 gsm->escape = false; 2102 } 2103 switch (gsm->state) { 2104 case GSM_START: /* First byte after SOF */ 2105 gsm->address = 0; 2106 gsm->state = GSM_ADDRESS; 2107 gsm->fcs = INIT_FCS; 2108 fallthrough; 2109 case GSM_ADDRESS: /* Address continuation */ 2110 gsm->fcs = gsm_fcs_add(gsm->fcs, c); 2111 if (gsm_read_ea(&gsm->address, c)) 2112 gsm->state = GSM_CONTROL; 2113 break; 2114 case GSM_CONTROL: /* Control Byte */ 2115 gsm->fcs = gsm_fcs_add(gsm->fcs, c); 2116 gsm->control = c; 2117 gsm->count = 0; 2118 gsm->state = GSM_DATA; 2119 break; 2120 case GSM_DATA: /* Data */ 2121 if (gsm->count > gsm->mru) { /* Allow one for the FCS */ 2122 gsm->state = GSM_OVERRUN; 2123 gsm->bad_size++; 2124 } else 2125 gsm->buf[gsm->count++] = c; 2126 break; 2127 case GSM_OVERRUN: /* Over-long - eg a dropped SOF */ 2128 break; 2129 default: 2130 pr_debug("%s: unhandled state: %d\n", __func__, gsm->state); 2131 break; 2132 } 2133} 2134 2135/** 2136 * gsm_error - handle tty error 2137 * @gsm: ldisc data 2138 * 2139 * Handle an error in the receipt of data for a frame. Currently we just 2140 * go back to hunting for a SOF. 2141 * 2142 * FIXME: better diagnostics ? 2143 */ 2144 2145static void gsm_error(struct gsm_mux *gsm) 2146{ 2147 gsm->state = GSM_SEARCH; 2148 gsm->io_error++; 2149} 2150 2151/** 2152 * gsm_cleanup_mux - generic GSM protocol cleanup 2153 * @gsm: our mux 2154 * @disc: disconnect link? 2155 * 2156 * Clean up the bits of the mux which are the same for all framing 2157 * protocols. Remove the mux from the mux table, stop all the timers 2158 * and then shut down each device hanging up the channels as we go. 2159 */ 2160 2161static void gsm_cleanup_mux(struct gsm_mux *gsm, bool disc) 2162{ 2163 int i; 2164 struct gsm_dlci *dlci = gsm->dlci[0]; 2165 struct gsm_msg *txq, *ntxq; 2166 2167 gsm->dead = true; 2168 mutex_lock(&gsm->mutex); 2169 2170 if (dlci) { 2171 if (disc && dlci->state != DLCI_CLOSED) { 2172 gsm_dlci_begin_close(dlci); 2173 wait_event(gsm->event, dlci->state == DLCI_CLOSED); 2174 } 2175 dlci->dead = true; 2176 } 2177 2178 /* Finish outstanding timers, making sure they are done */ 2179 del_timer_sync(&gsm->t2_timer); 2180 2181 /* Free up any link layer users and finally the control channel */ 2182 for (i = NUM_DLCI - 1; i >= 0; i--) 2183 if (gsm->dlci[i]) 2184 gsm_dlci_release(gsm->dlci[i]); 2185 mutex_unlock(&gsm->mutex); 2186 /* Now wipe the queues */ 2187 tty_ldisc_flush(gsm->tty); 2188 list_for_each_entry_safe(txq, ntxq, &gsm->tx_list, list) 2189 kfree(txq); 2190 INIT_LIST_HEAD(&gsm->tx_list); 2191} 2192 2193/** 2194 * gsm_activate_mux - generic GSM setup 2195 * @gsm: our mux 2196 * 2197 * Set up the bits of the mux which are the same for all framing 2198 * protocols. Add the mux to the mux table so it can be opened and 2199 * finally kick off connecting to DLCI 0 on the modem. 2200 */ 2201 2202static int gsm_activate_mux(struct gsm_mux *gsm) 2203{ 2204 struct gsm_dlci *dlci; 2205 2206 timer_setup(&gsm->t2_timer, gsm_control_retransmit, 0); 2207 init_waitqueue_head(&gsm->event); 2208 spin_lock_init(&gsm->control_lock); 2209 spin_lock_init(&gsm->tx_lock); 2210 2211 if (gsm->encoding == 0) 2212 gsm->receive = gsm0_receive; 2213 else 2214 gsm->receive = gsm1_receive; 2215 2216 dlci = gsm_dlci_alloc(gsm, 0); 2217 if (dlci == NULL) 2218 return -ENOMEM; 2219 gsm->dead = false; /* Tty opens are now permissible */ 2220 return 0; 2221} 2222 2223/** 2224 * gsm_free_mux - free up a mux 2225 * @gsm: mux to free 2226 * 2227 * Dispose of allocated resources for a dead mux 2228 */ 2229static void gsm_free_mux(struct gsm_mux *gsm) 2230{ 2231 int i; 2232 2233 for (i = 0; i < MAX_MUX; i++) { 2234 if (gsm == gsm_mux[i]) { 2235 gsm_mux[i] = NULL; 2236 break; 2237 } 2238 } 2239 mutex_destroy(&gsm->mutex); 2240 kfree(gsm->txframe); 2241 kfree(gsm->buf); 2242 kfree(gsm); 2243} 2244 2245/** 2246 * gsm_free_muxr - free up a mux 2247 * @ref: kreference to the mux to free 2248 * 2249 * Dispose of allocated resources for a dead mux 2250 */ 2251static void gsm_free_muxr(struct kref *ref) 2252{ 2253 struct gsm_mux *gsm = container_of(ref, struct gsm_mux, ref); 2254 gsm_free_mux(gsm); 2255} 2256 2257static inline void mux_get(struct gsm_mux *gsm) 2258{ 2259 unsigned long flags; 2260 2261 spin_lock_irqsave(&gsm_mux_lock, flags); 2262 kref_get(&gsm->ref); 2263 spin_unlock_irqrestore(&gsm_mux_lock, flags); 2264} 2265 2266static inline void mux_put(struct gsm_mux *gsm) 2267{ 2268 unsigned long flags; 2269 2270 spin_lock_irqsave(&gsm_mux_lock, flags); 2271 kref_put(&gsm->ref, gsm_free_muxr); 2272 spin_unlock_irqrestore(&gsm_mux_lock, flags); 2273} 2274 2275static inline unsigned int mux_num_to_base(struct gsm_mux *gsm) 2276{ 2277 return gsm->num * NUM_DLCI; 2278} 2279 2280static inline unsigned int mux_line_to_num(unsigned int line) 2281{ 2282 return line / NUM_DLCI; 2283} 2284 2285/** 2286 * gsm_alloc_mux - allocate a mux 2287 * 2288 * Creates a new mux ready for activation. 2289 */ 2290 2291static struct gsm_mux *gsm_alloc_mux(void) 2292{ 2293 int i; 2294 struct gsm_mux *gsm = kzalloc(sizeof(struct gsm_mux), GFP_KERNEL); 2295 if (gsm == NULL) 2296 return NULL; 2297 gsm->buf = kmalloc(MAX_MRU + 1, GFP_KERNEL); 2298 if (gsm->buf == NULL) { 2299 kfree(gsm); 2300 return NULL; 2301 } 2302 gsm->txframe = kmalloc(2 * (MAX_MTU + PROT_OVERHEAD - 1), GFP_KERNEL); 2303 if (gsm->txframe == NULL) { 2304 kfree(gsm->buf); 2305 kfree(gsm); 2306 return NULL; 2307 } 2308 spin_lock_init(&gsm->lock); 2309 mutex_init(&gsm->mutex); 2310 kref_init(&gsm->ref); 2311 INIT_LIST_HEAD(&gsm->tx_list); 2312 2313 gsm->t1 = T1; 2314 gsm->t2 = T2; 2315 gsm->n2 = N2; 2316 gsm->ftype = UIH; 2317 gsm->adaption = 1; 2318 gsm->encoding = 1; 2319 gsm->mru = 64; /* Default to encoding 1 so these should be 64 */ 2320 gsm->mtu = 64; 2321 gsm->dead = true; /* Avoid early tty opens */ 2322 2323 /* Store the instance to the mux array or abort if no space is 2324 * available. 2325 */ 2326 spin_lock(&gsm_mux_lock); 2327 for (i = 0; i < MAX_MUX; i++) { 2328 if (!gsm_mux[i]) { 2329 gsm_mux[i] = gsm; 2330 gsm->num = i; 2331 break; 2332 } 2333 } 2334 spin_unlock(&gsm_mux_lock); 2335 if (i == MAX_MUX) { 2336 mutex_destroy(&gsm->mutex); 2337 kfree(gsm->txframe); 2338 kfree(gsm->buf); 2339 kfree(gsm); 2340 return NULL; 2341 } 2342 2343 return gsm; 2344} 2345 2346static void gsm_copy_config_values(struct gsm_mux *gsm, 2347 struct gsm_config *c) 2348{ 2349 memset(c, 0, sizeof(*c)); 2350 c->adaption = gsm->adaption; 2351 c->encapsulation = gsm->encoding; 2352 c->initiator = gsm->initiator; 2353 c->t1 = gsm->t1; 2354 c->t2 = gsm->t2; 2355 c->t3 = 0; /* Not supported */ 2356 c->n2 = gsm->n2; 2357 if (gsm->ftype == UIH) 2358 c->i = 1; 2359 else 2360 c->i = 2; 2361 pr_debug("Ftype %d i %d\n", gsm->ftype, c->i); 2362 c->mru = gsm->mru; 2363 c->mtu = gsm->mtu; 2364 c->k = 0; 2365} 2366 2367static int gsm_config(struct gsm_mux *gsm, struct gsm_config *c) 2368{ 2369 int ret = 0; 2370 int need_close = 0; 2371 int need_restart = 0; 2372 2373 /* Stuff we don't support yet - UI or I frame transport, windowing */ 2374 if ((c->adaption != 1 && c->adaption != 2) || c->k) 2375 return -EOPNOTSUPP; 2376 /* Check the MRU/MTU range looks sane */ 2377 if (c->mru > MAX_MRU || c->mtu > MAX_MTU || c->mru < 8 || c->mtu < 8) 2378 return -EINVAL; 2379 if (c->n2 > 255) 2380 return -EINVAL; 2381 if (c->encapsulation > 1) /* Basic, advanced, no I */ 2382 return -EINVAL; 2383 if (c->initiator > 1) 2384 return -EINVAL; 2385 if (c->i == 0 || c->i > 2) /* UIH and UI only */ 2386 return -EINVAL; 2387 /* 2388 * See what is needed for reconfiguration 2389 */ 2390 2391 /* Timing fields */ 2392 if (c->t1 != 0 && c->t1 != gsm->t1) 2393 need_restart = 1; 2394 if (c->t2 != 0 && c->t2 != gsm->t2) 2395 need_restart = 1; 2396 if (c->encapsulation != gsm->encoding) 2397 need_restart = 1; 2398 if (c->adaption != gsm->adaption) 2399 need_restart = 1; 2400 /* Requires care */ 2401 if (c->initiator != gsm->initiator) 2402 need_close = 1; 2403 if (c->mru != gsm->mru) 2404 need_restart = 1; 2405 if (c->mtu != gsm->mtu) 2406 need_restart = 1; 2407 2408 /* 2409 * Close down what is needed, restart and initiate the new 2410 * configuration. On the first time there is no DLCI[0] 2411 * and closing or cleaning up is not necessary. 2412 */ 2413 if (need_close || need_restart) 2414 gsm_cleanup_mux(gsm, true); 2415 2416 gsm->initiator = c->initiator; 2417 gsm->mru = c->mru; 2418 gsm->mtu = c->mtu; 2419 gsm->encoding = c->encapsulation; 2420 gsm->adaption = c->adaption; 2421 gsm->n2 = c->n2; 2422 2423 if (c->i == 1) 2424 gsm->ftype = UIH; 2425 else if (c->i == 2) 2426 gsm->ftype = UI; 2427 2428 if (c->t1) 2429 gsm->t1 = c->t1; 2430 if (c->t2) 2431 gsm->t2 = c->t2; 2432 2433 /* 2434 * FIXME: We need to separate activation/deactivation from adding 2435 * and removing from the mux array 2436 */ 2437 if (gsm->dead) { 2438 ret = gsm_activate_mux(gsm); 2439 if (ret) 2440 return ret; 2441 if (gsm->initiator) 2442 gsm_dlci_begin_open(gsm->dlci[0]); 2443 } 2444 return 0; 2445} 2446 2447/** 2448 * gsmld_output - write to link 2449 * @gsm: our mux 2450 * @data: bytes to output 2451 * @len: size 2452 * 2453 * Write a block of data from the GSM mux to the data channel. This 2454 * will eventually be serialized from above but at the moment isn't. 2455 */ 2456 2457static int gsmld_output(struct gsm_mux *gsm, u8 *data, int len) 2458{ 2459 if (tty_write_room(gsm->tty) < len) { 2460 set_bit(TTY_DO_WRITE_WAKEUP, &gsm->tty->flags); 2461 return -ENOSPC; 2462 } 2463 if (debug & 4) 2464 gsm_hex_dump_bytes(__func__, data, len); 2465 return gsm->tty->ops->write(gsm->tty, data, len); 2466} 2467 2468/** 2469 * gsmld_attach_gsm - mode set up 2470 * @tty: our tty structure 2471 * @gsm: our mux 2472 * 2473 * Set up the MUX for basic mode and commence connecting to the 2474 * modem. Currently called from the line discipline set up but 2475 * will need moving to an ioctl path. 2476 */ 2477 2478static int gsmld_attach_gsm(struct tty_struct *tty, struct gsm_mux *gsm) 2479{ 2480 unsigned int base; 2481 int ret, i; 2482 2483 gsm->tty = tty_kref_get(tty); 2484 /* Turn off tty XON/XOFF handling to handle it explicitly. */ 2485 gsm->old_c_iflag = tty->termios.c_iflag; 2486 tty->termios.c_iflag &= (IXON | IXOFF); 2487 ret = gsm_activate_mux(gsm); 2488 if (ret != 0) 2489 tty_kref_put(gsm->tty); 2490 else { 2491 /* Don't register device 0 - this is the control channel and not 2492 a usable tty interface */ 2493 base = mux_num_to_base(gsm); /* Base for this MUX */ 2494 for (i = 1; i < NUM_DLCI; i++) { 2495 struct device *dev; 2496 2497 dev = tty_register_device(gsm_tty_driver, 2498 base + i, NULL); 2499 if (IS_ERR(dev)) { 2500 for (i--; i >= 1; i--) 2501 tty_unregister_device(gsm_tty_driver, 2502 base + i); 2503 return PTR_ERR(dev); 2504 } 2505 } 2506 } 2507 return ret; 2508} 2509 2510 2511/** 2512 * gsmld_detach_gsm - stop doing 0710 mux 2513 * @tty: tty attached to the mux 2514 * @gsm: mux 2515 * 2516 * Shutdown and then clean up the resources used by the line discipline 2517 */ 2518 2519static void gsmld_detach_gsm(struct tty_struct *tty, struct gsm_mux *gsm) 2520{ 2521 unsigned int base = mux_num_to_base(gsm); /* Base for this MUX */ 2522 int i; 2523 2524 WARN_ON(tty != gsm->tty); 2525 for (i = 1; i < NUM_DLCI; i++) 2526 tty_unregister_device(gsm_tty_driver, base + i); 2527 /* Restore tty XON/XOFF handling. */ 2528 gsm->tty->termios.c_iflag = gsm->old_c_iflag; 2529 tty_kref_put(gsm->tty); 2530 gsm->tty = NULL; 2531} 2532 2533static void gsmld_receive_buf(struct tty_struct *tty, const unsigned char *cp, 2534 const char *fp, int count) 2535{ 2536 struct gsm_mux *gsm = tty->disc_data; 2537 char flags = TTY_NORMAL; 2538 2539 if (debug & 4) 2540 gsm_hex_dump_bytes(__func__, cp, count); 2541 2542 for (; count; count--, cp++) { 2543 if (fp) 2544 flags = *fp++; 2545 switch (flags) { 2546 case TTY_NORMAL: 2547 gsm->receive(gsm, *cp); 2548 break; 2549 case TTY_OVERRUN: 2550 case TTY_BREAK: 2551 case TTY_PARITY: 2552 case TTY_FRAME: 2553 gsm_error(gsm); 2554 break; 2555 default: 2556 WARN_ONCE(1, "%s: unknown flag %d\n", 2557 tty_name(tty), flags); 2558 break; 2559 } 2560 } 2561 /* FASYNC if needed ? */ 2562 /* If clogged call tty_throttle(tty); */ 2563} 2564 2565/** 2566 * gsmld_flush_buffer - clean input queue 2567 * @tty: terminal device 2568 * 2569 * Flush the input buffer. Called when the line discipline is 2570 * being closed, when the tty layer wants the buffer flushed (eg 2571 * at hangup). 2572 */ 2573 2574static void gsmld_flush_buffer(struct tty_struct *tty) 2575{ 2576} 2577 2578/** 2579 * gsmld_close - close the ldisc for this tty 2580 * @tty: device 2581 * 2582 * Called from the terminal layer when this line discipline is 2583 * being shut down, either because of a close or becsuse of a 2584 * discipline change. The function will not be called while other 2585 * ldisc methods are in progress. 2586 */ 2587 2588static void gsmld_close(struct tty_struct *tty) 2589{ 2590 struct gsm_mux *gsm = tty->disc_data; 2591 2592 /* The ldisc locks and closes the port before calling our close. This 2593 * means we have no way to do a proper disconnect. We will not bother 2594 * to do one. 2595 */ 2596 gsm_cleanup_mux(gsm, false); 2597 2598 gsmld_detach_gsm(tty, gsm); 2599 2600 gsmld_flush_buffer(tty); 2601 /* Do other clean up here */ 2602 mux_put(gsm); 2603} 2604 2605/** 2606 * gsmld_open - open an ldisc 2607 * @tty: terminal to open 2608 * 2609 * Called when this line discipline is being attached to the 2610 * terminal device. Can sleep. Called serialized so that no 2611 * other events will occur in parallel. No further open will occur 2612 * until a close. 2613 */ 2614 2615static int gsmld_open(struct tty_struct *tty) 2616{ 2617 struct gsm_mux *gsm; 2618 int ret; 2619 2620 if (tty->ops->write == NULL) 2621 return -EINVAL; 2622 2623 /* Attach our ldisc data */ 2624 gsm = gsm_alloc_mux(); 2625 if (gsm == NULL) 2626 return -ENOMEM; 2627 2628 tty->disc_data = gsm; 2629 tty->receive_room = 65536; 2630 2631 /* Attach the initial passive connection */ 2632 gsm->encoding = 1; 2633 2634 ret = gsmld_attach_gsm(tty, gsm); 2635 if (ret != 0) { 2636 gsm_cleanup_mux(gsm, false); 2637 mux_put(gsm); 2638 } 2639 return ret; 2640} 2641 2642/** 2643 * gsmld_write_wakeup - asynchronous I/O notifier 2644 * @tty: tty device 2645 * 2646 * Required for the ptys, serial driver etc. since processes 2647 * that attach themselves to the master and rely on ASYNC 2648 * IO must be woken up 2649 */ 2650 2651static void gsmld_write_wakeup(struct tty_struct *tty) 2652{ 2653 struct gsm_mux *gsm = tty->disc_data; 2654 unsigned long flags; 2655 2656 /* Queue poll */ 2657 clear_bit(TTY_DO_WRITE_WAKEUP, &tty->flags); 2658 spin_lock_irqsave(&gsm->tx_lock, flags); 2659 gsm_data_kick(gsm, NULL); 2660 if (gsm->tx_bytes < TX_THRESH_LO) { 2661 gsm_dlci_data_sweep(gsm); 2662 } 2663 spin_unlock_irqrestore(&gsm->tx_lock, flags); 2664} 2665 2666/** 2667 * gsmld_read - read function for tty 2668 * @tty: tty device 2669 * @file: file object 2670 * @buf: userspace buffer pointer 2671 * @nr: size of I/O 2672 * @cookie: unused 2673 * @offset: unused 2674 * 2675 * Perform reads for the line discipline. We are guaranteed that the 2676 * line discipline will not be closed under us but we may get multiple 2677 * parallel readers and must handle this ourselves. We may also get 2678 * a hangup. Always called in user context, may sleep. 2679 * 2680 * This code must be sure never to sleep through a hangup. 2681 */ 2682 2683static ssize_t gsmld_read(struct tty_struct *tty, struct file *file, 2684 unsigned char *buf, size_t nr, 2685 void **cookie, unsigned long offset) 2686{ 2687 return -EOPNOTSUPP; 2688} 2689 2690/** 2691 * gsmld_write - write function for tty 2692 * @tty: tty device 2693 * @file: file object 2694 * @buf: userspace buffer pointer 2695 * @nr: size of I/O 2696 * 2697 * Called when the owner of the device wants to send a frame 2698 * itself (or some other control data). The data is transferred 2699 * as-is and must be properly framed and checksummed as appropriate 2700 * by userspace. Frames are either sent whole or not at all as this 2701 * avoids pain user side. 2702 */ 2703 2704static ssize_t gsmld_write(struct tty_struct *tty, struct file *file, 2705 const unsigned char *buf, size_t nr) 2706{ 2707 int space = tty_write_room(tty); 2708 if (space >= nr) 2709 return tty->ops->write(tty, buf, nr); 2710 set_bit(TTY_DO_WRITE_WAKEUP, &tty->flags); 2711 return -ENOBUFS; 2712} 2713 2714/** 2715 * gsmld_poll - poll method for N_GSM0710 2716 * @tty: terminal device 2717 * @file: file accessing it 2718 * @wait: poll table 2719 * 2720 * Called when the line discipline is asked to poll() for data or 2721 * for special events. This code is not serialized with respect to 2722 * other events save open/close. 2723 * 2724 * This code must be sure never to sleep through a hangup. 2725 * Called without the kernel lock held - fine 2726 */ 2727 2728static __poll_t gsmld_poll(struct tty_struct *tty, struct file *file, 2729 poll_table *wait) 2730{ 2731 __poll_t mask = 0; 2732 struct gsm_mux *gsm = tty->disc_data; 2733 2734 poll_wait(file, &tty->read_wait, wait); 2735 poll_wait(file, &tty->write_wait, wait); 2736 if (tty_hung_up_p(file)) 2737 mask |= EPOLLHUP; 2738 if (!tty_is_writelocked(tty) && tty_write_room(tty) > 0) 2739 mask |= EPOLLOUT | EPOLLWRNORM; 2740 if (gsm->dead) 2741 mask |= EPOLLHUP; 2742 return mask; 2743} 2744 2745static int gsmld_ioctl(struct tty_struct *tty, unsigned int cmd, 2746 unsigned long arg) 2747{ 2748 struct gsm_config c; 2749 struct gsm_mux *gsm = tty->disc_data; 2750 unsigned int base; 2751 2752 switch (cmd) { 2753 case GSMIOC_GETCONF: 2754 gsm_copy_config_values(gsm, &c); 2755 if (copy_to_user((void __user *)arg, &c, sizeof(c))) 2756 return -EFAULT; 2757 return 0; 2758 case GSMIOC_SETCONF: 2759 if (copy_from_user(&c, (void __user *)arg, sizeof(c))) 2760 return -EFAULT; 2761 return gsm_config(gsm, &c); 2762 case GSMIOC_GETFIRST: 2763 base = mux_num_to_base(gsm); 2764 return put_user(base + 1, (__u32 __user *)arg); 2765 default: 2766 return n_tty_ioctl_helper(tty, cmd, arg); 2767 } 2768} 2769 2770/* 2771 * Network interface 2772 * 2773 */ 2774 2775static int gsm_mux_net_open(struct net_device *net) 2776{ 2777 pr_debug("%s called\n", __func__); 2778 netif_start_queue(net); 2779 return 0; 2780} 2781 2782static int gsm_mux_net_close(struct net_device *net) 2783{ 2784 netif_stop_queue(net); 2785 return 0; 2786} 2787 2788static void dlci_net_free(struct gsm_dlci *dlci) 2789{ 2790 if (!dlci->net) { 2791 WARN_ON(1); 2792 return; 2793 } 2794 dlci->adaption = dlci->prev_adaption; 2795 dlci->data = dlci->prev_data; 2796 free_netdev(dlci->net); 2797 dlci->net = NULL; 2798} 2799static void net_free(struct kref *ref) 2800{ 2801 struct gsm_mux_net *mux_net; 2802 struct gsm_dlci *dlci; 2803 2804 mux_net = container_of(ref, struct gsm_mux_net, ref); 2805 dlci = mux_net->dlci; 2806 2807 if (dlci->net) { 2808 unregister_netdev(dlci->net); 2809 dlci_net_free(dlci); 2810 } 2811} 2812 2813static inline void muxnet_get(struct gsm_mux_net *mux_net) 2814{ 2815 kref_get(&mux_net->ref); 2816} 2817 2818static inline void muxnet_put(struct gsm_mux_net *mux_net) 2819{ 2820 kref_put(&mux_net->ref, net_free); 2821} 2822 2823static netdev_tx_t gsm_mux_net_start_xmit(struct sk_buff *skb, 2824 struct net_device *net) 2825{ 2826 struct gsm_mux_net *mux_net = netdev_priv(net); 2827 struct gsm_dlci *dlci = mux_net->dlci; 2828 muxnet_get(mux_net); 2829 2830 skb_queue_head(&dlci->skb_list, skb); 2831 net->stats.tx_packets++; 2832 net->stats.tx_bytes += skb->len; 2833 gsm_dlci_data_kick(dlci); 2834 /* And tell the kernel when the last transmit started. */ 2835 netif_trans_update(net); 2836 muxnet_put(mux_net); 2837 return NETDEV_TX_OK; 2838} 2839 2840/* called when a packet did not ack after watchdogtimeout */ 2841static void gsm_mux_net_tx_timeout(struct net_device *net, unsigned int txqueue) 2842{ 2843 /* Tell syslog we are hosed. */ 2844 dev_dbg(&net->dev, "Tx timed out.\n"); 2845 2846 /* Update statistics */ 2847 net->stats.tx_errors++; 2848} 2849 2850static void gsm_mux_rx_netchar(struct gsm_dlci *dlci, 2851 const unsigned char *in_buf, int size) 2852{ 2853 struct net_device *net = dlci->net; 2854 struct sk_buff *skb; 2855 struct gsm_mux_net *mux_net = netdev_priv(net); 2856 muxnet_get(mux_net); 2857 2858 /* Allocate an sk_buff */ 2859 skb = dev_alloc_skb(size + NET_IP_ALIGN); 2860 if (!skb) { 2861 /* We got no receive buffer. */ 2862 net->stats.rx_dropped++; 2863 muxnet_put(mux_net); 2864 return; 2865 } 2866 skb_reserve(skb, NET_IP_ALIGN); 2867 skb_put_data(skb, in_buf, size); 2868 2869 skb->dev = net; 2870 skb->protocol = htons(ETH_P_IP); 2871 2872 /* Ship it off to the kernel */ 2873 netif_rx(skb); 2874 2875 /* update out statistics */ 2876 net->stats.rx_packets++; 2877 net->stats.rx_bytes += size; 2878 muxnet_put(mux_net); 2879 return; 2880} 2881 2882static void gsm_mux_net_init(struct net_device *net) 2883{ 2884 static const struct net_device_ops gsm_netdev_ops = { 2885 .ndo_open = gsm_mux_net_open, 2886 .ndo_stop = gsm_mux_net_close, 2887 .ndo_start_xmit = gsm_mux_net_start_xmit, 2888 .ndo_tx_timeout = gsm_mux_net_tx_timeout, 2889 }; 2890 2891 net->netdev_ops = &gsm_netdev_ops; 2892 2893 /* fill in the other fields */ 2894 net->watchdog_timeo = GSM_NET_TX_TIMEOUT; 2895 net->flags = IFF_POINTOPOINT | IFF_NOARP | IFF_MULTICAST; 2896 net->type = ARPHRD_NONE; 2897 net->tx_queue_len = 10; 2898} 2899 2900 2901/* caller holds the dlci mutex */ 2902static void gsm_destroy_network(struct gsm_dlci *dlci) 2903{ 2904 struct gsm_mux_net *mux_net; 2905 2906 pr_debug("destroy network interface\n"); 2907 if (!dlci->net) 2908 return; 2909 mux_net = netdev_priv(dlci->net); 2910 muxnet_put(mux_net); 2911} 2912 2913 2914/* caller holds the dlci mutex */ 2915static int gsm_create_network(struct gsm_dlci *dlci, struct gsm_netconfig *nc) 2916{ 2917 char *netname; 2918 int retval = 0; 2919 struct net_device *net; 2920 struct gsm_mux_net *mux_net; 2921 2922 if (!capable(CAP_NET_ADMIN)) 2923 return -EPERM; 2924 2925 /* Already in a non tty mode */ 2926 if (dlci->adaption > 2) 2927 return -EBUSY; 2928 2929 if (nc->protocol != htons(ETH_P_IP)) 2930 return -EPROTONOSUPPORT; 2931 2932 if (nc->adaption != 3 && nc->adaption != 4) 2933 return -EPROTONOSUPPORT; 2934 2935 pr_debug("create network interface\n"); 2936 2937 netname = "gsm%d"; 2938 if (nc->if_name[0] != '\0') 2939 netname = nc->if_name; 2940 net = alloc_netdev(sizeof(struct gsm_mux_net), netname, 2941 NET_NAME_UNKNOWN, gsm_mux_net_init); 2942 if (!net) { 2943 pr_err("alloc_netdev failed\n"); 2944 return -ENOMEM; 2945 } 2946 net->mtu = dlci->gsm->mtu; 2947 net->min_mtu = 8; 2948 net->max_mtu = dlci->gsm->mtu; 2949 mux_net = netdev_priv(net); 2950 mux_net->dlci = dlci; 2951 kref_init(&mux_net->ref); 2952 strncpy(nc->if_name, net->name, IFNAMSIZ); /* return net name */ 2953 2954 /* reconfigure dlci for network */ 2955 dlci->prev_adaption = dlci->adaption; 2956 dlci->prev_data = dlci->data; 2957 dlci->adaption = nc->adaption; 2958 dlci->data = gsm_mux_rx_netchar; 2959 dlci->net = net; 2960 2961 pr_debug("register netdev\n"); 2962 retval = register_netdev(net); 2963 if (retval) { 2964 pr_err("network register fail %d\n", retval); 2965 dlci_net_free(dlci); 2966 return retval; 2967 } 2968 return net->ifindex; /* return network index */ 2969} 2970 2971/* Line discipline for real tty */ 2972static struct tty_ldisc_ops tty_ldisc_packet = { 2973 .owner = THIS_MODULE, 2974 .num = N_GSM0710, 2975 .name = "n_gsm", 2976 .open = gsmld_open, 2977 .close = gsmld_close, 2978 .flush_buffer = gsmld_flush_buffer, 2979 .read = gsmld_read, 2980 .write = gsmld_write, 2981 .ioctl = gsmld_ioctl, 2982 .poll = gsmld_poll, 2983 .receive_buf = gsmld_receive_buf, 2984 .write_wakeup = gsmld_write_wakeup 2985}; 2986 2987/* 2988 * Virtual tty side 2989 */ 2990 2991/** 2992 * gsm_modem_upd_via_data - send modem bits via convergence layer 2993 * @dlci: channel 2994 * @brk: break signal 2995 * 2996 * Send an empty frame to signal mobile state changes and to transmit the 2997 * break signal for adaption 2. 2998 */ 2999 3000static void gsm_modem_upd_via_data(struct gsm_dlci *dlci, u8 brk) 3001{ 3002 struct gsm_mux *gsm = dlci->gsm; 3003 unsigned long flags; 3004 3005 if (dlci->state != DLCI_OPEN || dlci->adaption != 2) 3006 return; 3007 3008 spin_lock_irqsave(&gsm->tx_lock, flags); 3009 gsm_dlci_modem_output(gsm, dlci, brk); 3010 spin_unlock_irqrestore(&gsm->tx_lock, flags); 3011} 3012 3013/** 3014 * gsm_modem_upd_via_msc - send modem bits via control frame 3015 * @dlci: channel 3016 * @brk: break signal 3017 */ 3018 3019static int gsm_modem_upd_via_msc(struct gsm_dlci *dlci, u8 brk) 3020{ 3021 u8 modembits[3]; 3022 struct gsm_control *ctrl; 3023 int len = 2; 3024 3025 if (dlci->gsm->encoding != 0) 3026 return 0; 3027 3028 modembits[0] = (dlci->addr << 2) | 2 | EA; /* DLCI, Valid, EA */ 3029 if (!brk) { 3030 modembits[1] = (gsm_encode_modem(dlci) << 1) | EA; 3031 } else { 3032 modembits[1] = gsm_encode_modem(dlci) << 1; 3033 modembits[2] = (brk << 4) | 2 | EA; /* Length, Break, EA */ 3034 len++; 3035 } 3036 ctrl = gsm_control_send(dlci->gsm, CMD_MSC, modembits, len); 3037 if (ctrl == NULL) 3038 return -ENOMEM; 3039 return gsm_control_wait(dlci->gsm, ctrl); 3040} 3041 3042/** 3043 * gsm_modem_update - send modem status line state 3044 * @dlci: channel 3045 * @brk: break signal 3046 */ 3047 3048static int gsm_modem_update(struct gsm_dlci *dlci, u8 brk) 3049{ 3050 if (dlci->adaption == 2) { 3051 /* Send convergence layer type 2 empty data frame. */ 3052 gsm_modem_upd_via_data(dlci, brk); 3053 return 0; 3054 } else if (dlci->gsm->encoding == 0) { 3055 /* Send as MSC control message. */ 3056 return gsm_modem_upd_via_msc(dlci, brk); 3057 } 3058 3059 /* Modem status lines are not supported. */ 3060 return -EPROTONOSUPPORT; 3061} 3062 3063static int gsm_carrier_raised(struct tty_port *port) 3064{ 3065 struct gsm_dlci *dlci = container_of(port, struct gsm_dlci, port); 3066 struct gsm_mux *gsm = dlci->gsm; 3067 3068 /* Not yet open so no carrier info */ 3069 if (dlci->state != DLCI_OPEN) 3070 return 0; 3071 if (debug & 2) 3072 return 1; 3073 3074 /* 3075 * Basic mode with control channel in ADM mode may not respond 3076 * to CMD_MSC at all and modem_rx is empty. 3077 */ 3078 if (gsm->encoding == 0 && gsm->dlci[0]->mode == DLCI_MODE_ADM && 3079 !dlci->modem_rx) 3080 return 1; 3081 3082 return dlci->modem_rx & TIOCM_CD; 3083} 3084 3085static void gsm_dtr_rts(struct tty_port *port, int onoff) 3086{ 3087 struct gsm_dlci *dlci = container_of(port, struct gsm_dlci, port); 3088 unsigned int modem_tx = dlci->modem_tx; 3089 if (onoff) 3090 modem_tx |= TIOCM_DTR | TIOCM_RTS; 3091 else 3092 modem_tx &= ~(TIOCM_DTR | TIOCM_RTS); 3093 if (modem_tx != dlci->modem_tx) { 3094 dlci->modem_tx = modem_tx; 3095 gsm_modem_update(dlci, 0); 3096 } 3097} 3098 3099static const struct tty_port_operations gsm_port_ops = { 3100 .carrier_raised = gsm_carrier_raised, 3101 .dtr_rts = gsm_dtr_rts, 3102 .destruct = gsm_dlci_free, 3103}; 3104 3105static int gsmtty_install(struct tty_driver *driver, struct tty_struct *tty) 3106{ 3107 struct gsm_mux *gsm; 3108 struct gsm_dlci *dlci; 3109 unsigned int line = tty->index; 3110 unsigned int mux = mux_line_to_num(line); 3111 bool alloc = false; 3112 int ret; 3113 3114 line = line & 0x3F; 3115 3116 if (mux >= MAX_MUX) 3117 return -ENXIO; 3118 /* FIXME: we need to lock gsm_mux for lifetimes of ttys eventually */ 3119 if (gsm_mux[mux] == NULL) 3120 return -EUNATCH; 3121 if (line == 0 || line > 61) /* 62/63 reserved */ 3122 return -ECHRNG; 3123 gsm = gsm_mux[mux]; 3124 if (gsm->dead) 3125 return -EL2HLT; 3126 /* If DLCI 0 is not yet fully open return an error. 3127 This is ok from a locking 3128 perspective as we don't have to worry about this 3129 if DLCI0 is lost */ 3130 mutex_lock(&gsm->mutex); 3131 if (gsm->dlci[0] && gsm->dlci[0]->state != DLCI_OPEN) { 3132 mutex_unlock(&gsm->mutex); 3133 return -EL2NSYNC; 3134 } 3135 dlci = gsm->dlci[line]; 3136 if (dlci == NULL) { 3137 alloc = true; 3138 dlci = gsm_dlci_alloc(gsm, line); 3139 } 3140 if (dlci == NULL) { 3141 mutex_unlock(&gsm->mutex); 3142 return -ENOMEM; 3143 } 3144 ret = tty_port_install(&dlci->port, driver, tty); 3145 if (ret) { 3146 if (alloc) 3147 dlci_put(dlci); 3148 mutex_unlock(&gsm->mutex); 3149 return ret; 3150 } 3151 3152 dlci_get(dlci); 3153 dlci_get(gsm->dlci[0]); 3154 mux_get(gsm); 3155 tty->driver_data = dlci; 3156 mutex_unlock(&gsm->mutex); 3157 3158 return 0; 3159} 3160 3161static int gsmtty_open(struct tty_struct *tty, struct file *filp) 3162{ 3163 struct gsm_dlci *dlci = tty->driver_data; 3164 struct tty_port *port = &dlci->port; 3165 struct gsm_mux *gsm = dlci->gsm; 3166 3167 port->count++; 3168 tty_port_tty_set(port, tty); 3169 3170 dlci->modem_rx = 0; 3171 /* We could in theory open and close before we wait - eg if we get 3172 a DM straight back. This is ok as that will have caused a hangup */ 3173 tty_port_set_initialized(port, 1); 3174 /* Start sending off SABM messages */ 3175 if (gsm->initiator) 3176 gsm_dlci_begin_open(dlci); 3177 /* And wait for virtual carrier */ 3178 return tty_port_block_til_ready(port, tty, filp); 3179} 3180 3181static void gsmtty_close(struct tty_struct *tty, struct file *filp) 3182{ 3183 struct gsm_dlci *dlci = tty->driver_data; 3184 3185 if (dlci == NULL) 3186 return; 3187 if (dlci->state == DLCI_CLOSED) 3188 return; 3189 mutex_lock(&dlci->mutex); 3190 gsm_destroy_network(dlci); 3191 mutex_unlock(&dlci->mutex); 3192 if (tty_port_close_start(&dlci->port, tty, filp) == 0) 3193 return; 3194 gsm_dlci_begin_close(dlci); 3195 if (tty_port_initialized(&dlci->port) && C_HUPCL(tty)) 3196 tty_port_lower_dtr_rts(&dlci->port); 3197 tty_port_close_end(&dlci->port, tty); 3198 tty_port_tty_set(&dlci->port, NULL); 3199 return; 3200} 3201 3202static void gsmtty_hangup(struct tty_struct *tty) 3203{ 3204 struct gsm_dlci *dlci = tty->driver_data; 3205 if (dlci->state == DLCI_CLOSED) 3206 return; 3207 tty_port_hangup(&dlci->port); 3208 gsm_dlci_begin_close(dlci); 3209} 3210 3211static int gsmtty_write(struct tty_struct *tty, const unsigned char *buf, 3212 int len) 3213{ 3214 int sent; 3215 struct gsm_dlci *dlci = tty->driver_data; 3216 if (dlci->state == DLCI_CLOSED) 3217 return -EINVAL; 3218 /* Stuff the bytes into the fifo queue */ 3219 sent = kfifo_in_locked(&dlci->fifo, buf, len, &dlci->lock); 3220 /* Need to kick the channel */ 3221 gsm_dlci_data_kick(dlci); 3222 return sent; 3223} 3224 3225static unsigned int gsmtty_write_room(struct tty_struct *tty) 3226{ 3227 struct gsm_dlci *dlci = tty->driver_data; 3228 if (dlci->state == DLCI_CLOSED) 3229 return 0; 3230 return kfifo_avail(&dlci->fifo); 3231} 3232 3233static unsigned int gsmtty_chars_in_buffer(struct tty_struct *tty) 3234{ 3235 struct gsm_dlci *dlci = tty->driver_data; 3236 if (dlci->state == DLCI_CLOSED) 3237 return 0; 3238 return kfifo_len(&dlci->fifo); 3239} 3240 3241static void gsmtty_flush_buffer(struct tty_struct *tty) 3242{ 3243 struct gsm_dlci *dlci = tty->driver_data; 3244 unsigned long flags; 3245 3246 if (dlci->state == DLCI_CLOSED) 3247 return; 3248 /* Caution needed: If we implement reliable transport classes 3249 then the data being transmitted can't simply be junked once 3250 it has first hit the stack. Until then we can just blow it 3251 away */ 3252 spin_lock_irqsave(&dlci->lock, flags); 3253 kfifo_reset(&dlci->fifo); 3254 spin_unlock_irqrestore(&dlci->lock, flags); 3255 /* Need to unhook this DLCI from the transmit queue logic */ 3256} 3257 3258static void gsmtty_wait_until_sent(struct tty_struct *tty, int timeout) 3259{ 3260 /* The FIFO handles the queue so the kernel will do the right 3261 thing waiting on chars_in_buffer before calling us. No work 3262 to do here */ 3263} 3264 3265static int gsmtty_tiocmget(struct tty_struct *tty) 3266{ 3267 struct gsm_dlci *dlci = tty->driver_data; 3268 if (dlci->state == DLCI_CLOSED) 3269 return -EINVAL; 3270 return dlci->modem_rx; 3271} 3272 3273static int gsmtty_tiocmset(struct tty_struct *tty, 3274 unsigned int set, unsigned int clear) 3275{ 3276 struct gsm_dlci *dlci = tty->driver_data; 3277 unsigned int modem_tx = dlci->modem_tx; 3278 3279 if (dlci->state == DLCI_CLOSED) 3280 return -EINVAL; 3281 modem_tx &= ~clear; 3282 modem_tx |= set; 3283 3284 if (modem_tx != dlci->modem_tx) { 3285 dlci->modem_tx = modem_tx; 3286 return gsm_modem_update(dlci, 0); 3287 } 3288 return 0; 3289} 3290 3291 3292static int gsmtty_ioctl(struct tty_struct *tty, 3293 unsigned int cmd, unsigned long arg) 3294{ 3295 struct gsm_dlci *dlci = tty->driver_data; 3296 struct gsm_netconfig nc; 3297 int index; 3298 3299 if (dlci->state == DLCI_CLOSED) 3300 return -EINVAL; 3301 switch (cmd) { 3302 case GSMIOC_ENABLE_NET: 3303 if (copy_from_user(&nc, (void __user *)arg, sizeof(nc))) 3304 return -EFAULT; 3305 nc.if_name[IFNAMSIZ-1] = '\0'; 3306 /* return net interface index or error code */ 3307 mutex_lock(&dlci->mutex); 3308 index = gsm_create_network(dlci, &nc); 3309 mutex_unlock(&dlci->mutex); 3310 if (copy_to_user((void __user *)arg, &nc, sizeof(nc))) 3311 return -EFAULT; 3312 return index; 3313 case GSMIOC_DISABLE_NET: 3314 if (!capable(CAP_NET_ADMIN)) 3315 return -EPERM; 3316 mutex_lock(&dlci->mutex); 3317 gsm_destroy_network(dlci); 3318 mutex_unlock(&dlci->mutex); 3319 return 0; 3320 default: 3321 return -ENOIOCTLCMD; 3322 } 3323} 3324 3325static void gsmtty_set_termios(struct tty_struct *tty, struct ktermios *old) 3326{ 3327 struct gsm_dlci *dlci = tty->driver_data; 3328 if (dlci->state == DLCI_CLOSED) 3329 return; 3330 /* For the moment its fixed. In actual fact the speed information 3331 for the virtual channel can be propogated in both directions by 3332 the RPN control message. This however rapidly gets nasty as we 3333 then have to remap modem signals each way according to whether 3334 our virtual cable is null modem etc .. */ 3335 tty_termios_copy_hw(&tty->termios, old); 3336} 3337 3338static void gsmtty_throttle(struct tty_struct *tty) 3339{ 3340 struct gsm_dlci *dlci = tty->driver_data; 3341 if (dlci->state == DLCI_CLOSED) 3342 return; 3343 if (C_CRTSCTS(tty)) 3344 dlci->modem_tx &= ~TIOCM_RTS; 3345 dlci->throttled = true; 3346 /* Send an MSC with RTS cleared */ 3347 gsm_modem_update(dlci, 0); 3348} 3349 3350static void gsmtty_unthrottle(struct tty_struct *tty) 3351{ 3352 struct gsm_dlci *dlci = tty->driver_data; 3353 if (dlci->state == DLCI_CLOSED) 3354 return; 3355 if (C_CRTSCTS(tty)) 3356 dlci->modem_tx |= TIOCM_RTS; 3357 dlci->throttled = false; 3358 /* Send an MSC with RTS set */ 3359 gsm_modem_update(dlci, 0); 3360} 3361 3362static int gsmtty_break_ctl(struct tty_struct *tty, int state) 3363{ 3364 struct gsm_dlci *dlci = tty->driver_data; 3365 int encode = 0; /* Off */ 3366 if (dlci->state == DLCI_CLOSED) 3367 return -EINVAL; 3368 3369 if (state == -1) /* "On indefinitely" - we can't encode this 3370 properly */ 3371 encode = 0x0F; 3372 else if (state > 0) { 3373 encode = state / 200; /* mS to encoding */ 3374 if (encode > 0x0F) 3375 encode = 0x0F; /* Best effort */ 3376 } 3377 return gsm_modem_update(dlci, encode); 3378} 3379 3380static void gsmtty_cleanup(struct tty_struct *tty) 3381{ 3382 struct gsm_dlci *dlci = tty->driver_data; 3383 struct gsm_mux *gsm = dlci->gsm; 3384 3385 dlci_put(dlci); 3386 dlci_put(gsm->dlci[0]); 3387 mux_put(gsm); 3388} 3389 3390/* Virtual ttys for the demux */ 3391static const struct tty_operations gsmtty_ops = { 3392 .install = gsmtty_install, 3393 .open = gsmtty_open, 3394 .close = gsmtty_close, 3395 .write = gsmtty_write, 3396 .write_room = gsmtty_write_room, 3397 .chars_in_buffer = gsmtty_chars_in_buffer, 3398 .flush_buffer = gsmtty_flush_buffer, 3399 .ioctl = gsmtty_ioctl, 3400 .throttle = gsmtty_throttle, 3401 .unthrottle = gsmtty_unthrottle, 3402 .set_termios = gsmtty_set_termios, 3403 .hangup = gsmtty_hangup, 3404 .wait_until_sent = gsmtty_wait_until_sent, 3405 .tiocmget = gsmtty_tiocmget, 3406 .tiocmset = gsmtty_tiocmset, 3407 .break_ctl = gsmtty_break_ctl, 3408 .cleanup = gsmtty_cleanup, 3409}; 3410 3411 3412 3413static int __init gsm_init(void) 3414{ 3415 /* Fill in our line protocol discipline, and register it */ 3416 int status = tty_register_ldisc(&tty_ldisc_packet); 3417 if (status != 0) { 3418 pr_err("n_gsm: can't register line discipline (err = %d)\n", 3419 status); 3420 return status; 3421 } 3422 3423 gsm_tty_driver = tty_alloc_driver(256, TTY_DRIVER_REAL_RAW | 3424 TTY_DRIVER_DYNAMIC_DEV | TTY_DRIVER_HARDWARE_BREAK); 3425 if (IS_ERR(gsm_tty_driver)) { 3426 pr_err("gsm_init: tty allocation failed.\n"); 3427 status = PTR_ERR(gsm_tty_driver); 3428 goto err_unreg_ldisc; 3429 } 3430 gsm_tty_driver->driver_name = "gsmtty"; 3431 gsm_tty_driver->name = "gsmtty"; 3432 gsm_tty_driver->major = 0; /* Dynamic */ 3433 gsm_tty_driver->minor_start = 0; 3434 gsm_tty_driver->type = TTY_DRIVER_TYPE_SERIAL; 3435 gsm_tty_driver->subtype = SERIAL_TYPE_NORMAL; 3436 gsm_tty_driver->init_termios = tty_std_termios; 3437 /* Fixme */ 3438 gsm_tty_driver->init_termios.c_lflag &= ~ECHO; 3439 tty_set_operations(gsm_tty_driver, &gsmtty_ops); 3440 3441 if (tty_register_driver(gsm_tty_driver)) { 3442 pr_err("gsm_init: tty registration failed.\n"); 3443 status = -EBUSY; 3444 goto err_put_driver; 3445 } 3446 pr_debug("gsm_init: loaded as %d,%d.\n", 3447 gsm_tty_driver->major, gsm_tty_driver->minor_start); 3448 return 0; 3449err_put_driver: 3450 tty_driver_kref_put(gsm_tty_driver); 3451err_unreg_ldisc: 3452 tty_unregister_ldisc(&tty_ldisc_packet); 3453 return status; 3454} 3455 3456static void __exit gsm_exit(void) 3457{ 3458 tty_unregister_ldisc(&tty_ldisc_packet); 3459 tty_unregister_driver(gsm_tty_driver); 3460 tty_driver_kref_put(gsm_tty_driver); 3461} 3462 3463module_init(gsm_init); 3464module_exit(gsm_exit); 3465 3466 3467MODULE_LICENSE("GPL"); 3468MODULE_ALIAS_LDISC(N_GSM0710);