*    Modifications for 2.3.99-pre5 kernel.
  */
 
+#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
+
 #define DRV_NAME       "tun"
 #define DRV_VERSION    "1.6"
 #define DRV_DESCRIPTION        "Universal TUN/TAP device driver"
 #ifdef TUN_DEBUG
 static int debug;
 
-#define DBG  if(tun->debug)printk
-#define DBG1 if(debug==2)printk
+#define tun_debug(level, tun, fmt, args...)                    \
+do {                                                           \
+       if (tun->debug)                                         \
+               netdev_printk(level, tun->dev, fmt, ##args);    \
+} while (0)
+#define DBG1(level, fmt, args...)                              \
+do {                                                           \
+       if (debug == 2)                                         \
+               printk(level fmt, ##args);                      \
+} while (0)
 #else
-#define DBG( a... )
-#define DBG1( a... )
+#define tun_debug(level, tun, fmt, args...)                    \
+do {                                                           \
+       if (0)                                                  \
+               netdev_printk(level, tun->dev, fmt, ##args);    \
+} while (0)
+#define DBG1(level, fmt, args...)                              \
+do {                                                           \
+       if (0)                                                  \
+               printk(level fmt, ##args);                      \
+} while (0)
 #endif
 
 #define FLT_EXACT_COUNT 8
                tun_detach(tfile->tun);
 }
 
-/* TAP filterting */
+/* TAP filtering */
 static void addr_hash_set(u32 *mask, const u8 *addr)
 {
        int n = ether_crc(ETH_ALEN, addr) >> 26;
 {
        struct tun_struct *tun = netdev_priv(dev);
 
-       DBG(KERN_INFO "%s: tun_net_xmit %d\n", tun->dev->name, skb->len);
+       tun_debug(KERN_INFO, tun, "tun_net_xmit %d\n", skb->len);
 
        /* Drop packet if interface is not attached */
        if (!tun->tfile)
 
        sk = tun->socket.sk;
 
-       DBG(KERN_INFO "%s: tun_chr_poll\n", tun->dev->name);
+       tun_debug(KERN_INFO, tun, "tun_chr_poll\n");
 
        poll_wait(file, &tun->wq.wait, wait);
 
        if (!tun)
                return -EBADFD;
 
-       DBG(KERN_INFO "%s: tun_chr_write %ld\n", tun->dev->name, count);
+       tun_debug(KERN_INFO, tun, "tun_chr_write %ld\n", count);
 
        result = tun_get_user(tun, iv, iov_length(iv, count),
                              file->f_flags & O_NONBLOCK);
                        else if (sinfo->gso_type & SKB_GSO_UDP)
                                gso.gso_type = VIRTIO_NET_HDR_GSO_UDP;
                        else {
-                               printk(KERN_ERR "tun: unexpected GSO type: "
+                               pr_err("unexpected GSO type: "
                                       "0x%x, gso_size %d, hdr_len %d\n",
                                       sinfo->gso_type, gso.gso_size,
                                       gso.hdr_len);
        struct sk_buff *skb;
        ssize_t ret = 0;
 
-       DBG(KERN_INFO "%s: tun_chr_read\n", tun->dev->name);
+       tun_debug(KERN_INFO, tun, "tun_chr_read\n");
 
        add_wait_queue(&tun->wq.wait, &wait);
        while (len) {
                if (device_create_file(&tun->dev->dev, &dev_attr_tun_flags) ||
                    device_create_file(&tun->dev->dev, &dev_attr_owner) ||
                    device_create_file(&tun->dev->dev, &dev_attr_group))
-                       printk(KERN_ERR "Failed to create tun sysfs files\n");
+                       pr_err("Failed to create tun sysfs files\n");
 
                sk->sk_destruct = tun_sock_destruct;
 
                        goto failed;
        }
 
-       DBG(KERN_INFO "%s: tun_set_iff\n", tun->dev->name);
+       tun_debug(KERN_INFO, tun, "tun_set_iff\n");
 
        if (ifr->ifr_flags & IFF_NO_PI)
                tun->flags |= TUN_NO_PI;
 static int tun_get_iff(struct net *net, struct tun_struct *tun,
                       struct ifreq *ifr)
 {
-       DBG(KERN_INFO "%s: tun_get_iff\n", tun->dev->name);
+       tun_debug(KERN_INFO, tun, "tun_get_iff\n");
 
        strcpy(ifr->ifr_name, tun->dev->name);
 
        if (!tun)
                goto unlock;
 
-       DBG(KERN_INFO "%s: tun_chr_ioctl cmd %d\n", tun->dev->name, cmd);
+       tun_debug(KERN_INFO, tun, "tun_chr_ioctl cmd %d\n", cmd);
 
        ret = 0;
        switch (cmd) {
                else
                        tun->flags &= ~TUN_NOCHECKSUM;
 
-               DBG(KERN_INFO "%s: checksum %s\n",
-                   tun->dev->name, arg ? "disabled" : "enabled");
+               tun_debug(KERN_INFO, tun, "checksum %s\n",
+                         arg ? "disabled" : "enabled");
                break;
 
        case TUNSETPERSIST:
                else
                        tun->flags &= ~TUN_PERSIST;
 
-               DBG(KERN_INFO "%s: persist %s\n",
-                   tun->dev->name, arg ? "enabled" : "disabled");
+               tun_debug(KERN_INFO, tun, "persist %s\n",
+                         arg ? "enabled" : "disabled");
                break;
 
        case TUNSETOWNER:
                /* Set owner of the device */
                tun->owner = (uid_t) arg;
 
-               DBG(KERN_INFO "%s: owner set to %d\n", tun->dev->name, tun->owner);
+               tun_debug(KERN_INFO, tun, "owner set to %d\n", tun->owner);
                break;
 
        case TUNSETGROUP:
                /* Set group of the device */
                tun->group= (gid_t) arg;
 
-               DBG(KERN_INFO "%s: group set to %d\n", tun->dev->name, tun->group);
+               tun_debug(KERN_INFO, tun, "group set to %d\n", tun->group);
                break;
 
        case TUNSETLINK:
                /* Only allow setting the type when the interface is down */
                if (tun->dev->flags & IFF_UP) {
-                       DBG(KERN_INFO "%s: Linktype set failed because interface is up\n",
-                               tun->dev->name);
+                       tun_debug(KERN_INFO, tun,
+                                 "Linktype set failed because interface is up\n");
                        ret = -EBUSY;
                } else {
                        tun->dev->type = (int) arg;
-                       DBG(KERN_INFO "%s: linktype set to %d\n", tun->dev->name, tun->dev->type);
+                       tun_debug(KERN_INFO, tun, "linktype set to %d\n",
+                                 tun->dev->type);
                        ret = 0;
                }
                break;
 
        case SIOCSIFHWADDR:
                /* Set hw address */
-               DBG(KERN_DEBUG "%s: set hw address: %pM\n",
-                       tun->dev->name, ifr.ifr_hwaddr.sa_data);
+               tun_debug(KERN_DEBUG, tun, "set hw address: %pM\n",
+                         ifr.ifr_hwaddr.sa_data);
 
                ret = dev_set_mac_address(tun->dev, &ifr.ifr_hwaddr);
                break;
        if (!tun)
                return -EBADFD;
 
-       DBG(KERN_INFO "%s: tun_chr_fasync %d\n", tun->dev->name, on);
+       tun_debug(KERN_INFO, tun, "tun_chr_fasync %d\n", on);
 
        if ((ret = fasync_helper(fd, file, on, &tun->fasync)) < 0)
                goto out;
 {
        struct tun_file *tfile;
 
-       DBG1(KERN_INFO "tunX: tun_chr_open\n");
+       DBG1(KERN_INFO, "tunX: tun_chr_open\n");
 
        tfile = kmalloc(sizeof(*tfile), GFP_KERNEL);
        if (!tfile)
        if (tun) {
                struct net_device *dev = tun->dev;
 
-               DBG(KERN_INFO "%s: tun_chr_close\n", dev->name);
+               tun_debug(KERN_INFO, tun, "tun_chr_close\n");
 
                __tun_detach(tun);
 
 {
        int ret = 0;
 
-       printk(KERN_INFO "tun: %s, %s\n", DRV_DESCRIPTION, DRV_VERSION);
-       printk(KERN_INFO "tun: %s\n", DRV_COPYRIGHT);
+       pr_info("%s, %s\n", DRV_DESCRIPTION, DRV_VERSION);
+       pr_info("%s\n", DRV_COPYRIGHT);
 
        ret = rtnl_link_register(&tun_link_ops);
        if (ret) {
-               printk(KERN_ERR "tun: Can't register link_ops\n");
+               pr_err("Can't register link_ops\n");
                goto err_linkops;
        }
 
        ret = misc_register(&tun_miscdev);
        if (ret) {
-               printk(KERN_ERR "tun: Can't register misc device %d\n", TUN_MINOR);
+               pr_err("Can't register misc device %d\n", TUN_MINOR);
                goto err_misc;
        }
        return  0;