2  *  TUN - Universal TUN/TAP device driver.
 
   3  *  Copyright (C) 1999-2002 Maxim Krasnyansky <maxk@qualcomm.com>
 
   5  *  This program is free software; you can redistribute it and/or modify
 
   6  *  it under the terms of the GNU General Public License as published by
 
   7  *  the Free Software Foundation; either version 2 of the License, or
 
   8  *  (at your option) any later version.
 
  10  *  This program is distributed in the hope that it will be useful,
 
  11  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  12  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 
  13  *  GNU General Public License for more details.
 
  15  *  $Id: tun.c,v 1.15 2002/03/01 02:44:24 maxk Exp $
 
  21  *  Mike Kershaw <dragorn@kismetwireless.net> 2005/08/14
 
  22  *    Add TUNSETLINK ioctl to set the link encapsulation
 
  24  *  Mark Smith <markzzzsmith@yahoo.com.au>
 
  25  *    Use random_ether_addr() for tap MAC address.
 
  27  *  Harald Roelle <harald.roelle@ifi.lmu.de>  2004/04/20
 
  28  *    Fixes in packet dropping, queue length setting and queue wakeup.
 
  29  *    Increased default tx queue length.
 
  33  *  Daniel Podlejski <underley@underley.eu.org>
 
  34  *    Modifications for 2.3.99-pre5 kernel.
 
  37 #define DRV_NAME        "tun"
 
  38 #define DRV_VERSION     "1.6"
 
  39 #define DRV_DESCRIPTION "Universal TUN/TAP device driver"
 
  40 #define DRV_COPYRIGHT   "(C) 1999-2004 Max Krasnyansky <maxk@qualcomm.com>"
 
  42 #include <linux/module.h>
 
  43 #include <linux/errno.h>
 
  44 #include <linux/kernel.h>
 
  45 #include <linux/major.h>
 
  46 #include <linux/slab.h>
 
  47 #include <linux/smp_lock.h>
 
  48 #include <linux/poll.h>
 
  49 #include <linux/fcntl.h>
 
  50 #include <linux/init.h>
 
  51 #include <linux/skbuff.h>
 
  52 #include <linux/netdevice.h>
 
  53 #include <linux/etherdevice.h>
 
  54 #include <linux/miscdevice.h>
 
  55 #include <linux/ethtool.h>
 
  56 #include <linux/rtnetlink.h>
 
  58 #include <linux/if_arp.h>
 
  59 #include <linux/if_ether.h>
 
  60 #include <linux/if_tun.h>
 
  61 #include <linux/crc32.h>
 
  62 #include <linux/nsproxy.h>
 
  63 #include <linux/virtio_net.h>
 
  64 #include <net/net_namespace.h>
 
  65 #include <net/netns/generic.h>
 
  67 #include <asm/system.h>
 
  68 #include <asm/uaccess.h>
 
  70 /* Uncomment to enable debugging */
 
  71 /* #define TUN_DEBUG 1 */
 
  76 #define DBG  if(tun->debug)printk
 
  77 #define DBG1 if(debug==2)printk
 
  83 #define FLT_EXACT_COUNT 8
 
  85         unsigned int    count;    /* Number of addrs. Zero means disabled */
 
  86         u32             mask[2];  /* Mask of the hashed addrs */
 
  87         unsigned char   addr[FLT_EXACT_COUNT][ETH_ALEN];
 
  91         struct list_head        list;
 
  97         wait_queue_head_t       read_wait;
 
  98         struct sk_buff_head     readq;
 
 100         struct net_device       *dev;
 
 101         struct fasync_struct    *fasync;
 
 103         struct tap_filter       txflt;
 
 111 static void addr_hash_set(u32 *mask, const u8 *addr)
 
 113         int n = ether_crc(ETH_ALEN, addr) >> 26;
 
 114         mask[n >> 5] |= (1 << (n & 31));
 
 117 static unsigned int addr_hash_test(const u32 *mask, const u8 *addr)
 
 119         int n = ether_crc(ETH_ALEN, addr) >> 26;
 
 120         return mask[n >> 5] & (1 << (n & 31));
 
 123 static int update_filter(struct tap_filter *filter, void __user *arg)
 
 125         struct { u8 u[ETH_ALEN]; } *addr;
 
 126         struct tun_filter uf;
 
 127         int err, alen, n, nexact;
 
 129         if (copy_from_user(&uf, arg, sizeof(uf)))
 
 138         alen = ETH_ALEN * uf.count;
 
 139         addr = kmalloc(alen, GFP_KERNEL);
 
 143         if (copy_from_user(addr, arg + sizeof(uf), alen)) {
 
 148         /* The filter is updated without holding any locks. Which is
 
 149          * perfectly safe. We disable it first and in the worst
 
 150          * case we'll accept a few undesired packets. */
 
 154         /* Use first set of addresses as an exact filter */
 
 155         for (n = 0; n < uf.count && n < FLT_EXACT_COUNT; n++)
 
 156                 memcpy(filter->addr[n], addr[n].u, ETH_ALEN);
 
 160         /* The rest is hashed */
 
 161         memset(filter->mask, 0, sizeof(filter->mask));
 
 162         for (; n < uf.count; n++)
 
 163                 addr_hash_set(filter->mask, addr[n].u);
 
 165         /* For ALLMULTI just set the mask to all ones.
 
 166          * This overrides the mask populated above. */
 
 167         if ((uf.flags & TUN_FLT_ALLMULTI))
 
 168                 memset(filter->mask, ~0, sizeof(filter->mask));
 
 170         /* Now enable the filter */
 
 172         filter->count = nexact;
 
 174         /* Return the number of exact filters */
 
 182 /* Returns: 0 - drop, !=0 - accept */
 
 183 static int run_filter(struct tap_filter *filter, const struct sk_buff *skb)
 
 185         /* Cannot use eth_hdr(skb) here because skb_mac_hdr() is incorrect
 
 187         struct ethhdr *eh = (struct ethhdr *) skb->data;
 
 191         for (i = 0; i < filter->count; i++)
 
 192                 if (!compare_ether_addr(eh->h_dest, filter->addr[i]))
 
 195         /* Inexact match (multicast only) */
 
 196         if (is_multicast_ether_addr(eh->h_dest))
 
 197                 return addr_hash_test(filter->mask, eh->h_dest);
 
 203  * Checks whether the packet is accepted or not.
 
 204  * Returns: 0 - drop, !=0 - accept
 
 206 static int check_filter(struct tap_filter *filter, const struct sk_buff *skb)
 
 211         return run_filter(filter, skb);
 
 214 /* Network device part of the driver */
 
 216 static unsigned int tun_net_id;
 
 218         struct list_head dev_list;
 
 221 static const struct ethtool_ops tun_ethtool_ops;
 
 223 /* Net device open. */
 
 224 static int tun_net_open(struct net_device *dev)
 
 226         netif_start_queue(dev);
 
 230 /* Net device close. */
 
 231 static int tun_net_close(struct net_device *dev)
 
 233         netif_stop_queue(dev);
 
 237 /* Net device start xmit */
 
 238 static int tun_net_xmit(struct sk_buff *skb, struct net_device *dev)
 
 240         struct tun_struct *tun = netdev_priv(dev);
 
 242         DBG(KERN_INFO "%s: tun_net_xmit %d\n", tun->dev->name, skb->len);
 
 244         /* Drop packet if interface is not attached */
 
 248         /* Drop if the filter does not like it.
 
 249          * This is a noop if the filter is disabled.
 
 250          * Filter can be enabled only for the TAP devices. */
 
 251         if (!check_filter(&tun->txflt, skb))
 
 254         if (skb_queue_len(&tun->readq) >= dev->tx_queue_len) {
 
 255                 if (!(tun->flags & TUN_ONE_QUEUE)) {
 
 256                         /* Normal queueing mode. */
 
 257                         /* Packet scheduler handles dropping of further packets. */
 
 258                         netif_stop_queue(dev);
 
 260                         /* We won't see all dropped packets individually, so overrun
 
 261                          * error is more appropriate. */
 
 262                         dev->stats.tx_fifo_errors++;
 
 264                         /* Single queue mode.
 
 265                          * Driver handles dropping of all packets itself. */
 
 271         skb_queue_tail(&tun->readq, skb);
 
 272         dev->trans_start = jiffies;
 
 274         /* Notify and wake up reader process */
 
 275         if (tun->flags & TUN_FASYNC)
 
 276                 kill_fasync(&tun->fasync, SIGIO, POLL_IN);
 
 277         wake_up_interruptible(&tun->read_wait);
 
 281         dev->stats.tx_dropped++;
 
 286 static void tun_net_mclist(struct net_device *dev)
 
 289          * This callback is supposed to deal with mc filter in
 
 290          * _rx_ path and has nothing to do with the _tx_ path.
 
 291          * In rx path we always accept everything userspace gives us.
 
 297 #define MAX_MTU 65535
 
 300 tun_net_change_mtu(struct net_device *dev, int new_mtu)
 
 302         if (new_mtu < MIN_MTU || new_mtu + dev->hard_header_len > MAX_MTU)
 
 308 /* Initialize net device. */
 
 309 static void tun_net_init(struct net_device *dev)
 
 311         struct tun_struct *tun = netdev_priv(dev);
 
 313         switch (tun->flags & TUN_TYPE_MASK) {
 
 315                 /* Point-to-Point TUN Device */
 
 316                 dev->hard_header_len = 0;
 
 319                 dev->change_mtu = tun_net_change_mtu;
 
 321                 /* Zero header length */
 
 322                 dev->type = ARPHRD_NONE;
 
 323                 dev->flags = IFF_POINTOPOINT | IFF_NOARP | IFF_MULTICAST;
 
 324                 dev->tx_queue_len = TUN_READQ_SIZE;  /* We prefer our own queue length */
 
 328                 /* Ethernet TAP Device */
 
 330                 dev->change_mtu         = tun_net_change_mtu;
 
 331                 dev->set_multicast_list = tun_net_mclist;
 
 333                 random_ether_addr(dev->dev_addr);
 
 335                 dev->tx_queue_len = TUN_READQ_SIZE;  /* We prefer our own queue length */
 
 340 /* Character device part */
 
 343 static unsigned int tun_chr_poll(struct file *file, poll_table * wait)
 
 345         struct tun_struct *tun = file->private_data;
 
 346         unsigned int mask = POLLOUT | POLLWRNORM;
 
 351         DBG(KERN_INFO "%s: tun_chr_poll\n", tun->dev->name);
 
 353         poll_wait(file, &tun->read_wait, wait);
 
 355         if (!skb_queue_empty(&tun->readq))
 
 356                 mask |= POLLIN | POLLRDNORM;
 
 361 /* prepad is the amount to reserve at front.  len is length after that.
 
 362  * linear is a hint as to how much to copy (usually headers). */
 
 363 static struct sk_buff *tun_alloc_skb(size_t prepad, size_t len, size_t linear,
 
 369         skb = alloc_skb(prepad + len, gfp|__GFP_NOWARN);
 
 371                 skb_reserve(skb, prepad);
 
 376         /* Under a page?  Don't bother with paged skb. */
 
 377         if (prepad + len < PAGE_SIZE)
 
 380         /* Start with a normal skb, and add pages. */
 
 381         skb = alloc_skb(prepad + linear, gfp);
 
 385         skb_reserve(skb, prepad);
 
 386         skb_put(skb, linear);
 
 390         for (i = 0; i < MAX_SKB_FRAGS; i++) {
 
 391                 skb_frag_t *f = &skb_shinfo(skb)->frags[i];
 
 393                 f->page = alloc_page(gfp|__GFP_ZERO);
 
 400                 skb->data_len += PAGE_SIZE;
 
 401                 skb->len += PAGE_SIZE;
 
 402                 skb->truesize += PAGE_SIZE;
 
 403                 skb_shinfo(skb)->nr_frags++;
 
 405                 if (len < PAGE_SIZE) {
 
 412         /* Too large, or alloc fail? */
 
 421 /* Get packet from user space buffer */
 
 422 static __inline__ ssize_t tun_get_user(struct tun_struct *tun, struct iovec *iv, size_t count)
 
 424         struct tun_pi pi = { 0, __constant_htons(ETH_P_IP) };
 
 426         size_t len = count, align = 0;
 
 427         struct virtio_net_hdr gso = { 0 };
 
 429         if (!(tun->flags & TUN_NO_PI)) {
 
 430                 if ((len -= sizeof(pi)) > count)
 
 433                 if(memcpy_fromiovec((void *)&pi, iv, sizeof(pi)))
 
 437         if (tun->flags & TUN_VNET_HDR) {
 
 438                 if ((len -= sizeof(gso)) > count)
 
 441                 if (memcpy_fromiovec((void *)&gso, iv, sizeof(gso)))
 
 444                 if (gso.hdr_len > len)
 
 448         if ((tun->flags & TUN_TYPE_MASK) == TUN_TAP_DEV) {
 
 449                 align = NET_IP_ALIGN;
 
 450                 if (unlikely(len < ETH_HLEN))
 
 454         if (!(skb = tun_alloc_skb(align, len, gso.hdr_len, GFP_KERNEL))) {
 
 455                 tun->dev->stats.rx_dropped++;
 
 459         if (skb_copy_datagram_from_iovec(skb, 0, iv, len)) {
 
 460                 tun->dev->stats.rx_dropped++;
 
 465         if (gso.flags & VIRTIO_NET_HDR_F_NEEDS_CSUM) {
 
 466                 if (!skb_partial_csum_set(skb, gso.csum_start,
 
 468                         tun->dev->stats.rx_frame_errors++;
 
 472         } else if (tun->flags & TUN_NOCHECKSUM)
 
 473                 skb->ip_summed = CHECKSUM_UNNECESSARY;
 
 475         switch (tun->flags & TUN_TYPE_MASK) {
 
 477                 if (tun->flags & TUN_NO_PI) {
 
 478                         switch (skb->data[0] & 0xf0) {
 
 480                                 pi.proto = htons(ETH_P_IP);
 
 483                                 pi.proto = htons(ETH_P_IPV6);
 
 486                                 tun->dev->stats.rx_dropped++;
 
 492                 skb_reset_mac_header(skb);
 
 493                 skb->protocol = pi.proto;
 
 497                 skb->protocol = eth_type_trans(skb, tun->dev);
 
 501         if (gso.gso_type != VIRTIO_NET_HDR_GSO_NONE) {
 
 503                 switch (gso.gso_type & ~VIRTIO_NET_HDR_GSO_ECN) {
 
 504                 case VIRTIO_NET_HDR_GSO_TCPV4:
 
 505                         skb_shinfo(skb)->gso_type = SKB_GSO_TCPV4;
 
 507                 case VIRTIO_NET_HDR_GSO_TCPV6:
 
 508                         skb_shinfo(skb)->gso_type = SKB_GSO_TCPV6;
 
 511                         tun->dev->stats.rx_frame_errors++;
 
 516                 if (gso.gso_type & VIRTIO_NET_HDR_GSO_ECN)
 
 517                         skb_shinfo(skb)->gso_type |= SKB_GSO_TCP_ECN;
 
 519                 skb_shinfo(skb)->gso_size = gso.gso_size;
 
 520                 if (skb_shinfo(skb)->gso_size == 0) {
 
 521                         tun->dev->stats.rx_frame_errors++;
 
 526                 /* Header must be checked, and gso_segs computed. */
 
 527                 skb_shinfo(skb)->gso_type |= SKB_GSO_DODGY;
 
 528                 skb_shinfo(skb)->gso_segs = 0;
 
 532         tun->dev->last_rx = jiffies;
 
 534         tun->dev->stats.rx_packets++;
 
 535         tun->dev->stats.rx_bytes += len;
 
 540 static ssize_t tun_chr_aio_write(struct kiocb *iocb, const struct iovec *iv,
 
 541                               unsigned long count, loff_t pos)
 
 543         struct tun_struct *tun = iocb->ki_filp->private_data;
 
 548         DBG(KERN_INFO "%s: tun_chr_write %ld\n", tun->dev->name, count);
 
 550         return tun_get_user(tun, (struct iovec *) iv, iov_length(iv, count));
 
 553 /* Put packet to the user space buffer */
 
 554 static __inline__ ssize_t tun_put_user(struct tun_struct *tun,
 
 556                                        struct iovec *iv, int len)
 
 558         struct tun_pi pi = { 0, skb->protocol };
 
 561         if (!(tun->flags & TUN_NO_PI)) {
 
 562                 if ((len -= sizeof(pi)) < 0)
 
 565                 if (len < skb->len) {
 
 566                         /* Packet will be striped */
 
 567                         pi.flags |= TUN_PKT_STRIP;
 
 570                 if (memcpy_toiovec(iv, (void *) &pi, sizeof(pi)))
 
 575         if (tun->flags & TUN_VNET_HDR) {
 
 576                 struct virtio_net_hdr gso = { 0 }; /* no info leak */
 
 577                 if ((len -= sizeof(gso)) < 0)
 
 580                 if (skb_is_gso(skb)) {
 
 581                         struct skb_shared_info *sinfo = skb_shinfo(skb);
 
 583                         /* This is a hint as to how much should be linear. */
 
 584                         gso.hdr_len = skb_headlen(skb);
 
 585                         gso.gso_size = sinfo->gso_size;
 
 586                         if (sinfo->gso_type & SKB_GSO_TCPV4)
 
 587                                 gso.gso_type = VIRTIO_NET_HDR_GSO_TCPV4;
 
 588                         else if (sinfo->gso_type & SKB_GSO_TCPV6)
 
 589                                 gso.gso_type = VIRTIO_NET_HDR_GSO_TCPV6;
 
 592                         if (sinfo->gso_type & SKB_GSO_TCP_ECN)
 
 593                                 gso.gso_type |= VIRTIO_NET_HDR_GSO_ECN;
 
 595                         gso.gso_type = VIRTIO_NET_HDR_GSO_NONE;
 
 597                 if (skb->ip_summed == CHECKSUM_PARTIAL) {
 
 598                         gso.flags = VIRTIO_NET_HDR_F_NEEDS_CSUM;
 
 599                         gso.csum_start = skb->csum_start - skb_headroom(skb);
 
 600                         gso.csum_offset = skb->csum_offset;
 
 601                 } /* else everything is zero */
 
 603                 if (unlikely(memcpy_toiovec(iv, (void *)&gso, sizeof(gso))))
 
 605                 total += sizeof(gso);
 
 608         len = min_t(int, skb->len, len);
 
 610         skb_copy_datagram_iovec(skb, 0, iv, len);
 
 613         tun->dev->stats.tx_packets++;
 
 614         tun->dev->stats.tx_bytes += len;
 
 619 static ssize_t tun_chr_aio_read(struct kiocb *iocb, const struct iovec *iv,
 
 620                             unsigned long count, loff_t pos)
 
 622         struct file *file = iocb->ki_filp;
 
 623         struct tun_struct *tun = file->private_data;
 
 624         DECLARE_WAITQUEUE(wait, current);
 
 626         ssize_t len, ret = 0;
 
 631         DBG(KERN_INFO "%s: tun_chr_read\n", tun->dev->name);
 
 633         len = iov_length(iv, count);
 
 637         add_wait_queue(&tun->read_wait, &wait);
 
 639                 current->state = TASK_INTERRUPTIBLE;
 
 641                 /* Read frames from the queue */
 
 642                 if (!(skb=skb_dequeue(&tun->readq))) {
 
 643                         if (file->f_flags & O_NONBLOCK) {
 
 647                         if (signal_pending(current)) {
 
 652                         /* Nothing to read, let's sleep */
 
 656                 netif_wake_queue(tun->dev);
 
 658                 ret = tun_put_user(tun, skb, (struct iovec *) iv, len);
 
 663         current->state = TASK_RUNNING;
 
 664         remove_wait_queue(&tun->read_wait, &wait);
 
 669 static void tun_setup(struct net_device *dev)
 
 671         struct tun_struct *tun = netdev_priv(dev);
 
 673         skb_queue_head_init(&tun->readq);
 
 674         init_waitqueue_head(&tun->read_wait);
 
 679         dev->open = tun_net_open;
 
 680         dev->hard_start_xmit = tun_net_xmit;
 
 681         dev->stop = tun_net_close;
 
 682         dev->ethtool_ops = &tun_ethtool_ops;
 
 683         dev->destructor = free_netdev;
 
 684         dev->features |= NETIF_F_NETNS_LOCAL;
 
 687 static struct tun_struct *tun_get_by_name(struct tun_net *tn, const char *name)
 
 689         struct tun_struct *tun;
 
 692         list_for_each_entry(tun, &tn->dev_list, list) {
 
 693                 if (!strncmp(tun->dev->name, name, IFNAMSIZ))
 
 700 static int tun_set_iff(struct net *net, struct file *file, struct ifreq *ifr)
 
 703         struct tun_struct *tun;
 
 704         struct net_device *dev;
 
 707         tn = net_generic(net, tun_net_id);
 
 708         tun = tun_get_by_name(tn, ifr->ifr_name);
 
 713                 /* Check permissions */
 
 714                 if (((tun->owner != -1 &&
 
 715                       current->euid != tun->owner) ||
 
 717                       current->egid != tun->group)) &&
 
 718                      !capable(CAP_NET_ADMIN))
 
 721         else if (__dev_get_by_name(net, ifr->ifr_name))
 
 725                 unsigned long flags = 0;
 
 729                 if (!capable(CAP_NET_ADMIN))
 
 733                 if (ifr->ifr_flags & IFF_TUN) {
 
 735                         flags |= TUN_TUN_DEV;
 
 737                 } else if (ifr->ifr_flags & IFF_TAP) {
 
 739                         flags |= TUN_TAP_DEV;
 
 745                         name = ifr->ifr_name;
 
 747                 dev = alloc_netdev(sizeof(struct tun_struct), name,
 
 752                 dev_net_set(dev, net);
 
 753                 tun = netdev_priv(dev);
 
 756                 tun->txflt.count = 0;
 
 760                 if (strchr(dev->name, '%')) {
 
 761                         err = dev_alloc_name(dev, dev->name);
 
 766                 err = register_netdevice(tun->dev);
 
 770                 list_add(&tun->list, &tn->dev_list);
 
 773         DBG(KERN_INFO "%s: tun_set_iff\n", tun->dev->name);
 
 775         if (ifr->ifr_flags & IFF_NO_PI)
 
 776                 tun->flags |= TUN_NO_PI;
 
 778                 tun->flags &= ~TUN_NO_PI;
 
 780         if (ifr->ifr_flags & IFF_ONE_QUEUE)
 
 781                 tun->flags |= TUN_ONE_QUEUE;
 
 783                 tun->flags &= ~TUN_ONE_QUEUE;
 
 785         if (ifr->ifr_flags & IFF_VNET_HDR)
 
 786                 tun->flags |= TUN_VNET_HDR;
 
 788                 tun->flags &= ~TUN_VNET_HDR;
 
 790         file->private_data = tun;
 
 792         get_net(dev_net(tun->dev));
 
 794         /* Make sure persistent devices do not get stuck in
 
 797         if (netif_running(tun->dev))
 
 798                 netif_wake_queue(tun->dev);
 
 800         strcpy(ifr->ifr_name, tun->dev->name);
 
 809 static int tun_get_iff(struct net *net, struct file *file, struct ifreq *ifr)
 
 811         struct tun_struct *tun = file->private_data;
 
 816         DBG(KERN_INFO "%s: tun_get_iff\n", tun->dev->name);
 
 818         strcpy(ifr->ifr_name, tun->dev->name);
 
 822         if (ifr->ifr_flags & TUN_TUN_DEV)
 
 823                 ifr->ifr_flags |= IFF_TUN;
 
 825                 ifr->ifr_flags |= IFF_TAP;
 
 827         if (tun->flags & TUN_NO_PI)
 
 828                 ifr->ifr_flags |= IFF_NO_PI;
 
 830         if (tun->flags & TUN_ONE_QUEUE)
 
 831                 ifr->ifr_flags |= IFF_ONE_QUEUE;
 
 833         if (tun->flags & TUN_VNET_HDR)
 
 834                 ifr->ifr_flags |= IFF_VNET_HDR;
 
 839 /* This is like a cut-down ethtool ops, except done via tun fd so no
 
 841 static int set_offload(struct net_device *dev, unsigned long arg)
 
 843         unsigned int old_features, features;
 
 845         old_features = dev->features;
 
 846         /* Unset features, set them as we chew on the arg. */
 
 847         features = (old_features & ~(NETIF_F_HW_CSUM|NETIF_F_SG|NETIF_F_FRAGLIST
 
 848                                     |NETIF_F_TSO_ECN|NETIF_F_TSO|NETIF_F_TSO6));
 
 850         if (arg & TUN_F_CSUM) {
 
 851                 features |= NETIF_F_HW_CSUM|NETIF_F_SG|NETIF_F_FRAGLIST;
 
 854                 if (arg & (TUN_F_TSO4|TUN_F_TSO6)) {
 
 855                         if (arg & TUN_F_TSO_ECN) {
 
 856                                 features |= NETIF_F_TSO_ECN;
 
 857                                 arg &= ~TUN_F_TSO_ECN;
 
 859                         if (arg & TUN_F_TSO4)
 
 860                                 features |= NETIF_F_TSO;
 
 861                         if (arg & TUN_F_TSO6)
 
 862                                 features |= NETIF_F_TSO6;
 
 863                         arg &= ~(TUN_F_TSO4|TUN_F_TSO6);
 
 867         /* This gives the user a way to test for new features in future by
 
 868          * trying to set them. */
 
 872         dev->features = features;
 
 873         if (old_features != dev->features)
 
 874                 netdev_features_change(dev);
 
 879 static int tun_chr_ioctl(struct inode *inode, struct file *file,
 
 880                          unsigned int cmd, unsigned long arg)
 
 882         struct tun_struct *tun = file->private_data;
 
 883         void __user* argp = (void __user*)arg;
 
 886         DECLARE_MAC_BUF(mac);
 
 888         if (cmd == TUNSETIFF || _IOC_TYPE(cmd) == 0x89)
 
 889                 if (copy_from_user(&ifr, argp, sizeof ifr))
 
 892         if (cmd == TUNSETIFF && !tun) {
 
 895                 ifr.ifr_name[IFNAMSIZ-1] = '\0';
 
 898                 err = tun_set_iff(current->nsproxy->net_ns, file, &ifr);
 
 904                 if (copy_to_user(argp, &ifr, sizeof(ifr)))
 
 909         if (cmd == TUNGETFEATURES) {
 
 910                 /* Currently this just means: "what IFF flags are valid?".
 
 911                  * This is needed because we never checked for invalid flags on
 
 913                 return put_user(IFF_TUN | IFF_TAP | IFF_NO_PI | IFF_ONE_QUEUE |
 
 915                                 (unsigned int __user*)argp);
 
 921         DBG(KERN_INFO "%s: tun_chr_ioctl cmd %d\n", tun->dev->name, cmd);
 
 925                 ret = tun_get_iff(current->nsproxy->net_ns, file, &ifr);
 
 929                 if (copy_to_user(argp, &ifr, sizeof(ifr)))
 
 934                 /* Disable/Enable checksum */
 
 936                         tun->flags |= TUN_NOCHECKSUM;
 
 938                         tun->flags &= ~TUN_NOCHECKSUM;
 
 940                 DBG(KERN_INFO "%s: checksum %s\n",
 
 941                     tun->dev->name, arg ? "disabled" : "enabled");
 
 945                 /* Disable/Enable persist mode */
 
 947                         tun->flags |= TUN_PERSIST;
 
 949                         tun->flags &= ~TUN_PERSIST;
 
 951                 DBG(KERN_INFO "%s: persist %s\n",
 
 952                     tun->dev->name, arg ? "enabled" : "disabled");
 
 956                 /* Set owner of the device */
 
 957                 tun->owner = (uid_t) arg;
 
 959                 DBG(KERN_INFO "%s: owner set to %d\n", tun->dev->name, tun->owner);
 
 963                 /* Set group of the device */
 
 964                 tun->group= (gid_t) arg;
 
 966                 DBG(KERN_INFO "%s: group set to %d\n", tun->dev->name, tun->group);
 
 970                 /* Only allow setting the type when the interface is down */
 
 972                 if (tun->dev->flags & IFF_UP) {
 
 973                         DBG(KERN_INFO "%s: Linktype set failed because interface is up\n",
 
 977                         tun->dev->type = (int) arg;
 
 978                         DBG(KERN_INFO "%s: linktype set to %d\n", tun->dev->name, tun->dev->type);
 
 991                 ret = set_offload(tun->dev, arg);
 
 996                 /* Can be set only for TAPs */
 
 997                 if ((tun->flags & TUN_TYPE_MASK) != TUN_TAP_DEV)
 
1000                 ret = update_filter(&tun->txflt, (void __user *)arg);
 
1006                 memcpy(ifr.ifr_hwaddr.sa_data, tun->dev->dev_addr, ETH_ALEN);
 
1007                 ifr.ifr_hwaddr.sa_family = tun->dev->type;
 
1008                 if (copy_to_user(argp, &ifr, sizeof ifr))
 
1013                 /* Set hw address */
 
1014                 DBG(KERN_DEBUG "%s: set hw address: %s\n",
 
1015                         tun->dev->name, print_mac(mac, ifr.ifr_hwaddr.sa_data));
 
1018                 ret = dev_set_mac_address(tun->dev, &ifr.ifr_hwaddr);
 
1029 static int tun_chr_fasync(int fd, struct file *file, int on)
 
1031         struct tun_struct *tun = file->private_data;
 
1037         DBG(KERN_INFO "%s: tun_chr_fasync %d\n", tun->dev->name, on);
 
1040         if ((ret = fasync_helper(fd, file, on, &tun->fasync)) < 0)
 
1044                 ret = __f_setown(file, task_pid(current), PIDTYPE_PID, 0);
 
1047                 tun->flags |= TUN_FASYNC;
 
1049                 tun->flags &= ~TUN_FASYNC;
 
1056 static int tun_chr_open(struct inode *inode, struct file * file)
 
1058         cycle_kernel_lock();
 
1059         DBG1(KERN_INFO "tunX: tun_chr_open\n");
 
1060         file->private_data = NULL;
 
1064 static int tun_chr_close(struct inode *inode, struct file *file)
 
1066         struct tun_struct *tun = file->private_data;
 
1071         DBG(KERN_INFO "%s: tun_chr_close\n", tun->dev->name);
 
1073         tun_chr_fasync(-1, file, 0);
 
1077         /* Detach from net device */
 
1078         file->private_data = NULL;
 
1080         put_net(dev_net(tun->dev));
 
1082         /* Drop read queue */
 
1083         skb_queue_purge(&tun->readq);
 
1085         if (!(tun->flags & TUN_PERSIST)) {
 
1086                 list_del(&tun->list);
 
1087                 unregister_netdevice(tun->dev);
 
1095 static const struct file_operations tun_fops = {
 
1096         .owner  = THIS_MODULE,
 
1097         .llseek = no_llseek,
 
1098         .read  = do_sync_read,
 
1099         .aio_read  = tun_chr_aio_read,
 
1100         .write = do_sync_write,
 
1101         .aio_write = tun_chr_aio_write,
 
1102         .poll   = tun_chr_poll,
 
1103         .ioctl  = tun_chr_ioctl,
 
1104         .open   = tun_chr_open,
 
1105         .release = tun_chr_close,
 
1106         .fasync = tun_chr_fasync
 
1109 static struct miscdevice tun_miscdev = {
 
1115 /* ethtool interface */
 
1117 static int tun_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
 
1120         cmd->advertising        = 0;
 
1121         cmd->speed              = SPEED_10;
 
1122         cmd->duplex             = DUPLEX_FULL;
 
1123         cmd->port               = PORT_TP;
 
1124         cmd->phy_address        = 0;
 
1125         cmd->transceiver        = XCVR_INTERNAL;
 
1126         cmd->autoneg            = AUTONEG_DISABLE;
 
1132 static void tun_get_drvinfo(struct net_device *dev, struct ethtool_drvinfo *info)
 
1134         struct tun_struct *tun = netdev_priv(dev);
 
1136         strcpy(info->driver, DRV_NAME);
 
1137         strcpy(info->version, DRV_VERSION);
 
1138         strcpy(info->fw_version, "N/A");
 
1140         switch (tun->flags & TUN_TYPE_MASK) {
 
1142                 strcpy(info->bus_info, "tun");
 
1145                 strcpy(info->bus_info, "tap");
 
1150 static u32 tun_get_msglevel(struct net_device *dev)
 
1153         struct tun_struct *tun = netdev_priv(dev);
 
1160 static void tun_set_msglevel(struct net_device *dev, u32 value)
 
1163         struct tun_struct *tun = netdev_priv(dev);
 
1168 static u32 tun_get_link(struct net_device *dev)
 
1170         struct tun_struct *tun = netdev_priv(dev);
 
1171         return tun->attached;
 
1174 static u32 tun_get_rx_csum(struct net_device *dev)
 
1176         struct tun_struct *tun = netdev_priv(dev);
 
1177         return (tun->flags & TUN_NOCHECKSUM) == 0;
 
1180 static int tun_set_rx_csum(struct net_device *dev, u32 data)
 
1182         struct tun_struct *tun = netdev_priv(dev);
 
1184                 tun->flags &= ~TUN_NOCHECKSUM;
 
1186                 tun->flags |= TUN_NOCHECKSUM;
 
1190 static const struct ethtool_ops tun_ethtool_ops = {
 
1191         .get_settings   = tun_get_settings,
 
1192         .get_drvinfo    = tun_get_drvinfo,
 
1193         .get_msglevel   = tun_get_msglevel,
 
1194         .set_msglevel   = tun_set_msglevel,
 
1195         .get_link       = tun_get_link,
 
1196         .get_rx_csum    = tun_get_rx_csum,
 
1197         .set_rx_csum    = tun_set_rx_csum
 
1200 static int tun_init_net(struct net *net)
 
1204         tn = kmalloc(sizeof(*tn), GFP_KERNEL);
 
1208         INIT_LIST_HEAD(&tn->dev_list);
 
1210         if (net_assign_generic(net, tun_net_id, tn)) {
 
1218 static void tun_exit_net(struct net *net)
 
1221         struct tun_struct *tun, *nxt;
 
1223         tn = net_generic(net, tun_net_id);
 
1226         list_for_each_entry_safe(tun, nxt, &tn->dev_list, list) {
 
1227                 DBG(KERN_INFO "%s cleaned up\n", tun->dev->name);
 
1228                 unregister_netdevice(tun->dev);
 
1235 static struct pernet_operations tun_net_ops = {
 
1236         .init = tun_init_net,
 
1237         .exit = tun_exit_net,
 
1240 static int __init tun_init(void)
 
1244         printk(KERN_INFO "tun: %s, %s\n", DRV_DESCRIPTION, DRV_VERSION);
 
1245         printk(KERN_INFO "tun: %s\n", DRV_COPYRIGHT);
 
1247         ret = register_pernet_gen_device(&tun_net_id, &tun_net_ops);
 
1249                 printk(KERN_ERR "tun: Can't register pernet ops\n");
 
1253         ret = misc_register(&tun_miscdev);
 
1255                 printk(KERN_ERR "tun: Can't register misc device %d\n", TUN_MINOR);
 
1261         unregister_pernet_gen_device(tun_net_id, &tun_net_ops);
 
1266 static void tun_cleanup(void)
 
1268         misc_deregister(&tun_miscdev);
 
1269         unregister_pernet_gen_device(tun_net_id, &tun_net_ops);
 
1272 module_init(tun_init);
 
1273 module_exit(tun_cleanup);
 
1274 MODULE_DESCRIPTION(DRV_DESCRIPTION);
 
1275 MODULE_AUTHOR(DRV_COPYRIGHT);
 
1276 MODULE_LICENSE("GPL");
 
1277 MODULE_ALIAS_MISCDEV(TUN_MINOR);