]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
TTY: isdn, use xmit_buf from tty_port
authorJiri Slaby <jslaby@suse.cz>
Mon, 2 Apr 2012 11:53:58 +0000 (13:53 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 9 Apr 2012 18:16:55 +0000 (11:16 -0700)
Signed-off-by: Jiri Slaby <jslaby@suse.cz>
Cc: Karsten Keil <isdn@linux-pingi.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/isdn/i4l/isdn_tty.c
include/linux/isdn.h

index 869885620c94b65e7b0481824a8facd8dbc67196..dfb83e68bd86409ada378d839eb347f0cfec813b 100644 (file)
@@ -333,7 +333,7 @@ isdn_tty_countDLE(unsigned char *buf, int len)
 static int
 isdn_tty_handleDLEdown(modem_info *info, atemu *m, int len)
 {
-       unsigned char *p = &info->xmit_buf[info->xmit_count];
+       unsigned char *p = &info->port.xmit_buf[info->xmit_count];
        int count = 0;
 
        while (len > 0) {
@@ -477,7 +477,7 @@ isdn_tty_senddown(modem_info *info)
                return;
        }
        skb_reserve(skb, skb_res);
-       memcpy(skb_put(skb, buflen), info->xmit_buf, buflen);
+       memcpy(skb_put(skb, buflen), info->port.xmit_buf, buflen);
        info->xmit_count = 0;
 #ifdef CONFIG_ISDN_AUDIO
        if (info->vonline & 2) {
@@ -1152,7 +1152,7 @@ isdn_tty_write(struct tty_struct *tty, const u_char *buf, int count)
                                isdn_tty_check_esc(buf, m->mdmreg[REG_ESC], c,
                                                   &(m->pluscount),
                                                   &(m->lastplus));
-                       memcpy(&(info->xmit_buf[info->xmit_count]), buf, c);
+                       memcpy(&info->port.xmit_buf[info->xmit_count], buf, c);
 #ifdef CONFIG_ISDN_AUDIO
                        if (info->vonline) {
                                int cc = isdn_tty_handleDLEdown(info, m, c);
@@ -1906,13 +1906,15 @@ isdn_tty_modem_init(void)
 #ifdef CONFIG_ISDN_AUDIO
                skb_queue_head_init(&info->dtmf_queue);
 #endif
-               if (!(info->xmit_buf = kmalloc(ISDN_SERIAL_XMIT_MAX + 5, GFP_KERNEL))) {
+               info->port.xmit_buf = kmalloc(ISDN_SERIAL_XMIT_MAX + 5,
+                               GFP_KERNEL);
+               if (!info->port.xmit_buf) {
                        printk(KERN_ERR "Could not allocate modem xmit-buffer\n");
                        retval = -ENOMEM;
                        goto err_unregister;
                }
                /* Make room for T.70 header */
-               info->xmit_buf += 4;
+               info->port.xmit_buf += 4;
        }
        return 0;
 err_unregister:
@@ -1921,7 +1923,7 @@ err_unregister:
 #ifdef CONFIG_ISDN_TTY_FAX
                kfree(info->fax);
 #endif
-               kfree(info->xmit_buf - 4);
+               kfree(info->port.xmit_buf - 4);
        }
        tty_unregister_driver(m->tty_modem);
 err:
@@ -1942,7 +1944,7 @@ isdn_tty_exit(void)
 #ifdef CONFIG_ISDN_TTY_FAX
                kfree(info->fax);
 #endif
-               kfree(info->xmit_buf - 4);
+               kfree(info->port.xmit_buf - 4);
        }
        tty_unregister_driver(dev->mdm.tty_modem);
        put_tty_driver(dev->mdm.tty_modem);
index 95883ac5a2f41ce14d1cc410e6c4f3040e9618cc..215c41602af80904a68ab1cfb9aedd2a2c74de93 100644 (file)
@@ -461,7 +461,6 @@ typedef struct modem_info {
   int                   send_outstanding;/* # of outstanding send-requests */
   int                   xmit_size;       /* max. # of chars in xmit_buf    */
   int                   xmit_count;      /* # of chars in xmit_buf         */
-  unsigned char         *xmit_buf;       /* transmit buffer                */
   struct sk_buff_head   xmit_queue;      /* transmit queue                 */
   atomic_t              xmit_lock;       /* Semaphore for isdn_tty_write   */
 #ifdef CONFIG_ISDN_AUDIO