📄 netdevic.h
字号:
#ifndef _COMPAT_NETDEVICE_H#define _COMPAT_NETDEVICE_H#include <linux/version.h>#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,1,25))#define net_device_stats enet_statistics#define skb_tx_check(dev, skb) \ do { if (skb == NULL) { dev_tint(dev); return 0; } \ if (skb->len <= 0) return 0; } while (0)#define add_rx_bytes(stats, n) do { int x; x = (n); } while (0)#define add_tx_bytes(stats, n) do { int x; x = (n); } while (0)#else#define skb_tx_check(dev, skb) do { } while (0)#define add_rx_bytes(stats, n) do { (stats)->rx_bytes += n; } while (0)#define add_tx_bytes(stats, n) do { (stats)->tx_bytes += n; } while (0)#endif#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,1,86))#define DEV_KFREE_SKB(skb) dev_kfree_skb(skb, FREE_WRITE)#else#define DEV_KFREE_SKB(skb) dev_kfree_skb(skb)#endif#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,3,14))#define net_device device#endif#include_next <linux/netdevice.h>#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,3,43))#define netif_stop_queue(dev) set_bit(0, (void *)&(dev)->tbusy)#define netif_start_queue(dev) clear_bit(0, (void *)&(dev)->tbusy)#define netif_wake_queue(dev) \ do { netif_start_queue(dev); mark_bh(NET_BH); } while (0)#define netif_device_attach(dev) \ do { (dev)->start = 1; netif_start_queue(dev); } while (0)#define netif_device_detach(dev) \ do { (dev)->start = 0; netif_stop_queue(dev); } while (0)#define netif_device_present(dev) ((dev)->start)#define netif_running(dev) ((dev)->start)#define netif_mark_up(dev) do { (dev)->start = 1; } while (0)#define netif_mark_down(dev) do { (dev)->start = 0; } while (0)#define netif_carrier_on(dev) do { dev->flags |= IFF_RUNNING; } while (0)#define netif_carrier_off(dev) do { dev->flags &= ~IFF_RUNNING; } while (0)#define netif_queue_stopped(dev) ((dev)->tbusy)#define tx_timeout_check(dev, tx_timeout) \ do { if (test_and_set_bit(0, (void *)&(dev)->tbusy) != 0) { \ if (jiffies - (dev)->trans_start < TX_TIMEOUT) return 1; \ tx_timeout(dev); \ } } while (0)#define dev_kfree_skb_irq(skb) DEV_KFREE_SKB(skb)#else#define netif_mark_up(dev) do { } while (0)#define netif_mark_down(dev) do { } while (0)#define tx_timeout_check(d,h) netif_stop_queue(d)#endif#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,3,99))#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,2,0))/* A nasty hack: we only need to set up dev->init on 2.0.* kernels, and this is a convenient place to bury it */#define init_dev_name(dev, node) \ do { static int __dummy(struct net_device *dev) { return 0; } \ dev->init = &__dummy; (dev)->name = (node).dev_name; \ } while (0)#else#define init_dev_name(dev, node) (dev)->name = (node).dev_name#endif#define copy_dev_name(node, dev) do { } while (0)#else#define init_dev_name(dev, node) do { } while (0)#define copy_dev_name(node, dev) strcpy((node).dev_name, (dev)->name)#endif#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,4,3))static inline struct net_device *alloc_etherdev(int sz){ struct net_device *dev; sz += sizeof(*dev) + 31; if (!(dev = kmalloc(sz, GFP_KERNEL))) return NULL; memset(dev, 0, sz); if (sz) dev->priv = (void *)(((long)dev + sizeof(*dev) + 31) & ~31); ether_setup(dev); return dev;}#endif#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,4,0))#define netif_xmit_lock(dev) do { } while (0)#define netif_xmit_unlock(dev) do { } while (0)#else#define netif_xmit_lock(dev) spin_lock_bh(&dev->xmit_lock)#define netif_xmit_unlock(dev) spin_unlock_bh(&dev->xmit_lock)#endif#endif /* _COMPAT_NETDEVICE_H */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -