📄 kcompat.h
字号:
/******************************************************************************* Intel PRO/1000 Linux driver Copyright(c) 1999 - 2008 Intel Corporation. This program is free software; you can redistribute it and/or modify it under the terms and conditions of the GNU General Public License, version 2, as published by the Free Software Foundation. This program is distributed in the hope it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA. The full GNU General Public License is included in this distribution in the file called "COPYING". Contact Information: Linux NICS <linux.nics@intel.com> e1000-devel Mailing List <e1000-devel@lists.sourceforge.net> Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497*******************************************************************************/#ifndef _KCOMPAT_H_#define _KCOMPAT_H_#include <linux/version.h>#include <linux/init.h>#include <linux/types.h>#include <linux/errno.h>#include <linux/module.h>#include <linux/pci.h>#include <linux/netdevice.h>#include <linux/etherdevice.h>#include <linux/skbuff.h>#include <linux/ioport.h>#include <linux/slab.h>#include <linux/list.h>#include <linux/delay.h>#include <linux/sched.h>#include <linux/in.h>#include <linux/ip.h>#include <linux/udp.h>#include <linux/mii.h>#include <asm/io.h>/* NAPI enable/disable flags here */#ifdef DRIVER_E1000E#define CONFIG_E1000E_NAPI#define NAPI#endif#ifdef _E1000_H_#ifdef CONFIG_E1000_NAPI#define NAPI#endif#ifdef E1000_NAPI#undef NAPI#define NAPI#endif#ifdef E1000E_NAPI#undef NAPI#define NAPI#endif#ifdef E1000_NO_NAPI#undef NAPI#endif#ifdef E1000E_NO_NAPI#undef NAPI#endif#endif#ifdef DRIVER_E1000E#define adapter_struct e1000_adapter#define CONFIG_E1000E_MSIX#endif/* and finally set defines so that the code sees the changes */#ifdef NAPI#ifndef CONFIG_E1000_NAPI#define CONFIG_E1000_NAPI#endif#ifndef CONFIG_E1000E_NAPI#define CONFIG_E1000E_NAPI#endif#else#undef CONFIG_E1000_NAPI#undef CONFIG_E1000E_NAPI#undef CONFIG_IXGB_NAPI#endif/* packet split disable/enable */#ifdef DISABLE_PACKET_SPLIT#undef CONFIG_E1000_DISABLE_PACKET_SPLIT#define CONFIG_E1000_DISABLE_PACKET_SPLIT#undef CONFIG_IGB_DISABLE_PACKET_SPLIT#define CONFIG_IGB_DISABLE_PACKET_SPLIT#endif/* MSI compatibility code for all kernels and drivers */#ifdef DISABLE_PCI_MSI#undef CONFIG_PCI_MSI#endif#ifndef CONFIG_PCI_MSI#if ( LINUX_VERSION_CODE < KERNEL_VERSION(2,6,8) )struct msix_entry { u16 vector; /* kernel uses to write allocated vector */ u16 entry; /* driver uses to specify entry, OS writes */};#endif#define pci_enable_msi(a) -ENOTSUPP#define pci_disable_msi(a) do {} while (0)#define pci_enable_msix(a, b, c) -ENOTSUPP#define pci_disable_msix(a) do {} while (0)#define msi_remove_pci_irq_vectors(a) do {} while (0)#endif /* CONFIG_PCI_MSI */#ifdef DISABLE_PM#undef CONFIG_PM#endif#ifdef DISABLE_NET_POLL_CONTROLLER#undef CONFIG_NET_POLL_CONTROLLER#endif#ifndef PMSG_SUSPEND#define PMSG_SUSPEND 3#endif/* generic boolean compatibility */#undef TRUE#undef FALSE#define TRUE true#define FALSE false#ifdef GCC_VERSION#if ( GCC_VERSION < 3000 )#define _Bool char#endif#endif#ifndef bool#define bool _Bool#define true 1#define false 0#endif#ifndef module_param#define module_param(v,t,p) MODULE_PARM(v, "i");#endif#ifndef DMA_64BIT_MASK#define DMA_64BIT_MASK 0xffffffffffffffffULL#endif#ifndef DMA_32BIT_MASK#define DMA_32BIT_MASK 0x00000000ffffffffULL#endif#ifndef PCI_CAP_ID_EXP#define PCI_CAP_ID_EXP 0x10#endif#ifndef mmiowb#ifdef CONFIG_IA64#define mmiowb() asm volatile ("mf.a" ::: "memory")#else#define mmiowb()#endif#endif#ifndef IRQ_HANDLED#define irqreturn_t void#define IRQ_HANDLED#define IRQ_NONE#endif#ifndef SET_NETDEV_DEV#define SET_NETDEV_DEV(net, pdev)#endif#ifndef HAVE_FREE_NETDEV#define free_netdev(x) kfree(x)#endif#ifdef HAVE_POLL_CONTROLLER#define CONFIG_NET_POLL_CONTROLLER#endif#ifndef NETDEV_TX_OK#define NETDEV_TX_OK 0#endif#ifndef NETDEV_TX_BUSY#define NETDEV_TX_BUSY 1#endif#ifndef NETDEV_TX_LOCKED#define NETDEV_TX_LOCKED -1#endif#ifndef SKB_DATAREF_SHIFT/* if we do not have the infrastructure to detect if skb_header is cloned just return false in all cases */#define skb_header_cloned(x) 0#endif#ifndef NETIF_F_GSO#define gso_size tso_size#define gso_segs tso_segs#endif#ifndef CHECKSUM_PARTIAL#define CHECKSUM_PARTIAL CHECKSUM_HW#define CHECKSUM_COMPLETE CHECKSUM_HW#endif#ifndef __read_mostly#define __read_mostly#endif#ifndef HAVE_NETIF_MSG#define HAVE_NETIF_MSG 1enum { NETIF_MSG_DRV = 0x0001, NETIF_MSG_PROBE = 0x0002, NETIF_MSG_LINK = 0x0004, NETIF_MSG_TIMER = 0x0008, NETIF_MSG_IFDOWN = 0x0010, NETIF_MSG_IFUP = 0x0020, NETIF_MSG_RX_ERR = 0x0040, NETIF_MSG_TX_ERR = 0x0080, NETIF_MSG_TX_QUEUED = 0x0100, NETIF_MSG_INTR = 0x0200, NETIF_MSG_TX_DONE = 0x0400, NETIF_MSG_RX_STATUS = 0x0800, NETIF_MSG_PKTDATA = 0x1000, NETIF_MSG_HW = 0x2000, NETIF_MSG_WOL = 0x4000,};#else#define NETIF_MSG_HW 0x2000#define NETIF_MSG_WOL 0x4000#endif /* HAVE_NETIF_MSG */#ifndef MII_RESV1#define MII_RESV1 0x17 /* Reserved... */#endif#ifndef unlikely#define unlikely(_x) _x#define likely(_x) _x#endif#ifndef WARN_ON#define WARN_ON(x)#endif#ifndef PCI_DEVICE#define PCI_DEVICE(vend,dev) \ .vendor = (vend), .device = (dev), \ .subvendor = PCI_ANY_ID, .subdevice = PCI_ANY_ID#endif#ifndef num_online_cpus#define num_online_cpus() smp_num_cpus#endif#ifndef _LINUX_RANDOM_H#include <linux/random.h>#endif#ifndef DECLARE_BITMAP#ifndef BITS_TO_LONGS#define BITS_TO_LONGS(bits) (((bits)+BITS_PER_LONG-1)/BITS_PER_LONG)#endif#define DECLARE_BITMAP(name,bits) long name[BITS_TO_LONGS(bits)]#endif#ifndef VLAN_HLEN#define VLAN_HLEN 4#endif#ifndef VLAN_ETH_HLEN#define VLAN_ETH_HLEN 18#endif#ifndef VLAN_ETH_FRAME_LEN#define VLAN_ETH_FRAME_LEN 1518#endif#ifndef DCA_GET_TAG_TWO_ARGS#define dca3_get_tag(a,b) dca_get_tag(b)#endif/*****************************************************************************//* Installations with ethtool version without eeprom, adapter id, or statistics * support */#ifndef ETH_GSTRING_LEN#define ETH_GSTRING_LEN 32#endif#ifndef ETHTOOL_GSTATS#define ETHTOOL_GSTATS 0x1d#undef ethtool_drvinfo#define ethtool_drvinfo k_ethtool_drvinfostruct k_ethtool_drvinfo { u32 cmd; char driver[32]; char version[32]; char fw_version[32]; char bus_info[32]; char reserved1[32]; char reserved2[16]; u32 n_stats; u32 testinfo_len; u32 eedump_len; u32 regdump_len;};struct ethtool_stats { u32 cmd; u32 n_stats; u64 data[0];};#endif /* ETHTOOL_GSTATS */#ifndef ETHTOOL_PHYS_ID#define ETHTOOL_PHYS_ID 0x1c#endif /* ETHTOOL_PHYS_ID */#ifndef ETHTOOL_GSTRINGS#define ETHTOOL_GSTRINGS 0x1benum ethtool_stringset { ETH_SS_TEST = 0, ETH_SS_STATS,};struct ethtool_gstrings { u32 cmd; /* ETHTOOL_GSTRINGS */ u32 string_set; /* string set id e.c. ETH_SS_TEST, etc*/ u32 len; /* number of strings in the string set */ u8 data[0];};#endif /* ETHTOOL_GSTRINGS */#ifndef ETHTOOL_TEST#define ETHTOOL_TEST 0x1aenum ethtool_test_flags { ETH_TEST_FL_OFFLINE = (1 << 0), ETH_TEST_FL_FAILED = (1 << 1),};struct ethtool_test { u32 cmd; u32 flags; u32 reserved; u32 len; u64 data[0];};#endif /* ETHTOOL_TEST */#ifndef ETHTOOL_GEEPROM#define ETHTOOL_GEEPROM 0xb#undef ETHTOOL_GREGSstruct ethtool_eeprom { u32 cmd; u32 magic; u32 offset; u32 len; u8 data[0];};struct ethtool_value { u32 cmd; u32 data;};#endif /* ETHTOOL_GEEPROM */#ifndef ETHTOOL_GLINK#define ETHTOOL_GLINK 0xa#endif /* ETHTOOL_GLINK */#ifndef ETHTOOL_GREGS#define ETHTOOL_GREGS 0x00000004 /* Get NIC registers */#define ethtool_regs _kc_ethtool_regs/* for passing big chunks of data */struct _kc_ethtool_regs { u32 cmd; u32 version; /* driver-specific, indicates different chips/revs */ u32 len; /* bytes */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -