devices/r8169-3.2-orig.c
author Knud Baastrup <kba@deif.com>
Tue, 14 Apr 2015 10:12:55 -0400
changeset 2625 e25af8bd3957
parent 2403 5cbd10256e12
permissions -rw-r--r--
Eoe mac address now derived from unique mac.
The EoE MAC address is now derived from the NIC part of the first global
unique MAC address of the linked list of available network interfaces or
otherwise the MAC address used by the EtherCAT master. The EoE MAC address
will get the format 02:NIC:NIC:NIC:RP:RP where NIC comes from the unique MAC
address (if available) and RP is the ring position of the EoE slave.
2403
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     1
/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     2
 * r8169.c: RealTek 8169/8168/8101 ethernet driver.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     3
 *
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     4
 * Copyright (c) 2002 ShuChen <shuchen@realtek.com.tw>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     5
 * Copyright (c) 2003 - 2007 Francois Romieu <romieu@fr.zoreil.com>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     6
 * Copyright (c) a lot of people too. Please respect their work.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     7
 *
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     8
 * See MAINTAINERS file for support contact information.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     9
 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    10
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    11
#include <linux/module.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    12
#include <linux/moduleparam.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    13
#include <linux/pci.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    14
#include <linux/netdevice.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    15
#include <linux/etherdevice.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    16
#include <linux/delay.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    17
#include <linux/ethtool.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    18
#include <linux/mii.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    19
#include <linux/if_vlan.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    20
#include <linux/crc32.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    21
#include <linux/in.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    22
#include <linux/ip.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    23
#include <linux/tcp.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    24
#include <linux/init.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    25
#include <linux/interrupt.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    26
#include <linux/dma-mapping.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    27
#include <linux/pm_runtime.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    28
#include <linux/firmware.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    29
#include <linux/pci-aspm.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    30
#include <linux/prefetch.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    31
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    32
#include <asm/system.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    33
#include <asm/io.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    34
#include <asm/irq.h>
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    35
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    36
#define RTL8169_VERSION "2.3LK-NAPI"
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    37
#define MODULENAME "r8169"
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    38
#define PFX MODULENAME ": "
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    39
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    40
#define FIRMWARE_8168D_1	"rtl_nic/rtl8168d-1.fw"
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    41
#define FIRMWARE_8168D_2	"rtl_nic/rtl8168d-2.fw"
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    42
#define FIRMWARE_8168E_1	"rtl_nic/rtl8168e-1.fw"
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    43
#define FIRMWARE_8168E_2	"rtl_nic/rtl8168e-2.fw"
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    44
#define FIRMWARE_8168E_3	"rtl_nic/rtl8168e-3.fw"
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    45
#define FIRMWARE_8168F_1	"rtl_nic/rtl8168f-1.fw"
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    46
#define FIRMWARE_8168F_2	"rtl_nic/rtl8168f-2.fw"
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    47
#define FIRMWARE_8105E_1	"rtl_nic/rtl8105e-1.fw"
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    48
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    49
#ifdef RTL8169_DEBUG
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    50
#define assert(expr) \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    51
	if (!(expr)) {					\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    52
		printk( "Assertion failed! %s,%s,%s,line=%d\n",	\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    53
		#expr,__FILE__,__func__,__LINE__);		\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    54
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    55
#define dprintk(fmt, args...) \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    56
	do { printk(KERN_DEBUG PFX fmt, ## args); } while (0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    57
#else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    58
#define assert(expr) do {} while (0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    59
#define dprintk(fmt, args...)	do {} while (0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    60
#endif /* RTL8169_DEBUG */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    61
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    62
#define R8169_MSG_DEFAULT \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    63
	(NETIF_MSG_DRV | NETIF_MSG_PROBE | NETIF_MSG_IFUP | NETIF_MSG_IFDOWN)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    64
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    65
#define TX_BUFFS_AVAIL(tp) \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    66
	(tp->dirty_tx + NUM_TX_DESC - tp->cur_tx - 1)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    67
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    68
/* Maximum number of multicast addresses to filter (vs. Rx-all-multicast).
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    69
   The RTL chips use a 64 element hash table based on the Ethernet CRC. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    70
static const int multicast_filter_limit = 32;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    71
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    72
/* MAC address length */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    73
#define MAC_ADDR_LEN	6
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    74
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    75
#define MAX_READ_REQUEST_SHIFT	12
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    76
#define TX_DMA_BURST	6	/* Maximum PCI burst, '6' is 1024 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    77
#define SafeMtu		0x1c20	/* ... actually life sucks beyond ~7k */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    78
#define InterFrameGap	0x03	/* 3 means InterFrameGap = the shortest one */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    79
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    80
#define R8169_REGS_SIZE		256
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    81
#define R8169_NAPI_WEIGHT	64
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    82
#define NUM_TX_DESC	64	/* Number of Tx descriptor registers */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    83
#define NUM_RX_DESC	256	/* Number of Rx descriptor registers */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    84
#define RX_BUF_SIZE	1536	/* Rx Buffer size */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    85
#define R8169_TX_RING_BYTES	(NUM_TX_DESC * sizeof(struct TxDesc))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    86
#define R8169_RX_RING_BYTES	(NUM_RX_DESC * sizeof(struct RxDesc))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    87
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    88
#define RTL8169_TX_TIMEOUT	(6*HZ)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    89
#define RTL8169_PHY_TIMEOUT	(10*HZ)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    90
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    91
#define RTL_EEPROM_SIG		cpu_to_le32(0x8129)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    92
#define RTL_EEPROM_SIG_MASK	cpu_to_le32(0xffff)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    93
#define RTL_EEPROM_SIG_ADDR	0x0000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    94
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    95
/* write/read MMIO register */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    96
#define RTL_W8(reg, val8)	writeb ((val8), ioaddr + (reg))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    97
#define RTL_W16(reg, val16)	writew ((val16), ioaddr + (reg))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    98
#define RTL_W32(reg, val32)	writel ((val32), ioaddr + (reg))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    99
#define RTL_R8(reg)		readb (ioaddr + (reg))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   100
#define RTL_R16(reg)		readw (ioaddr + (reg))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   101
#define RTL_R32(reg)		readl (ioaddr + (reg))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   102
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   103
enum mac_version {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   104
	RTL_GIGA_MAC_VER_01 = 0,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   105
	RTL_GIGA_MAC_VER_02,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   106
	RTL_GIGA_MAC_VER_03,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   107
	RTL_GIGA_MAC_VER_04,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   108
	RTL_GIGA_MAC_VER_05,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   109
	RTL_GIGA_MAC_VER_06,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   110
	RTL_GIGA_MAC_VER_07,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   111
	RTL_GIGA_MAC_VER_08,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   112
	RTL_GIGA_MAC_VER_09,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   113
	RTL_GIGA_MAC_VER_10,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   114
	RTL_GIGA_MAC_VER_11,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   115
	RTL_GIGA_MAC_VER_12,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   116
	RTL_GIGA_MAC_VER_13,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   117
	RTL_GIGA_MAC_VER_14,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   118
	RTL_GIGA_MAC_VER_15,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   119
	RTL_GIGA_MAC_VER_16,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   120
	RTL_GIGA_MAC_VER_17,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   121
	RTL_GIGA_MAC_VER_18,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   122
	RTL_GIGA_MAC_VER_19,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   123
	RTL_GIGA_MAC_VER_20,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   124
	RTL_GIGA_MAC_VER_21,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   125
	RTL_GIGA_MAC_VER_22,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   126
	RTL_GIGA_MAC_VER_23,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   127
	RTL_GIGA_MAC_VER_24,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   128
	RTL_GIGA_MAC_VER_25,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   129
	RTL_GIGA_MAC_VER_26,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   130
	RTL_GIGA_MAC_VER_27,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   131
	RTL_GIGA_MAC_VER_28,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   132
	RTL_GIGA_MAC_VER_29,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   133
	RTL_GIGA_MAC_VER_30,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   134
	RTL_GIGA_MAC_VER_31,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   135
	RTL_GIGA_MAC_VER_32,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   136
	RTL_GIGA_MAC_VER_33,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   137
	RTL_GIGA_MAC_VER_34,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   138
	RTL_GIGA_MAC_VER_35,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   139
	RTL_GIGA_MAC_VER_36,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   140
	RTL_GIGA_MAC_NONE   = 0xff,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   141
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   142
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   143
enum rtl_tx_desc_version {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   144
	RTL_TD_0	= 0,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   145
	RTL_TD_1	= 1,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   146
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   147
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   148
#define JUMBO_1K	ETH_DATA_LEN
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   149
#define JUMBO_4K	(4*1024 - ETH_HLEN - 2)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   150
#define JUMBO_6K	(6*1024 - ETH_HLEN - 2)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   151
#define JUMBO_7K	(7*1024 - ETH_HLEN - 2)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   152
#define JUMBO_9K	(9*1024 - ETH_HLEN - 2)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   153
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   154
#define _R(NAME,TD,FW,SZ,B) {	\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   155
	.name = NAME,		\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   156
	.txd_version = TD,	\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   157
	.fw_name = FW,		\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   158
	.jumbo_max = SZ,	\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   159
	.jumbo_tx_csum = B	\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   160
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   161
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   162
static const struct {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   163
	const char *name;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   164
	enum rtl_tx_desc_version txd_version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   165
	const char *fw_name;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   166
	u16 jumbo_max;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   167
	bool jumbo_tx_csum;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   168
} rtl_chip_infos[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   169
	/* PCI devices. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   170
	[RTL_GIGA_MAC_VER_01] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   171
		_R("RTL8169",		RTL_TD_0, NULL, JUMBO_7K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   172
	[RTL_GIGA_MAC_VER_02] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   173
		_R("RTL8169s",		RTL_TD_0, NULL, JUMBO_7K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   174
	[RTL_GIGA_MAC_VER_03] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   175
		_R("RTL8110s",		RTL_TD_0, NULL, JUMBO_7K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   176
	[RTL_GIGA_MAC_VER_04] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   177
		_R("RTL8169sb/8110sb",	RTL_TD_0, NULL, JUMBO_7K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   178
	[RTL_GIGA_MAC_VER_05] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   179
		_R("RTL8169sc/8110sc",	RTL_TD_0, NULL, JUMBO_7K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   180
	[RTL_GIGA_MAC_VER_06] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   181
		_R("RTL8169sc/8110sc",	RTL_TD_0, NULL, JUMBO_7K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   182
	/* PCI-E devices. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   183
	[RTL_GIGA_MAC_VER_07] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   184
		_R("RTL8102e",		RTL_TD_1, NULL, JUMBO_1K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   185
	[RTL_GIGA_MAC_VER_08] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   186
		_R("RTL8102e",		RTL_TD_1, NULL, JUMBO_1K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   187
	[RTL_GIGA_MAC_VER_09] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   188
		_R("RTL8102e",		RTL_TD_1, NULL, JUMBO_1K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   189
	[RTL_GIGA_MAC_VER_10] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   190
		_R("RTL8101e",		RTL_TD_0, NULL, JUMBO_1K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   191
	[RTL_GIGA_MAC_VER_11] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   192
		_R("RTL8168b/8111b",	RTL_TD_0, NULL, JUMBO_4K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   193
	[RTL_GIGA_MAC_VER_12] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   194
		_R("RTL8168b/8111b",	RTL_TD_0, NULL, JUMBO_4K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   195
	[RTL_GIGA_MAC_VER_13] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   196
		_R("RTL8101e",		RTL_TD_0, NULL, JUMBO_1K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   197
	[RTL_GIGA_MAC_VER_14] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   198
		_R("RTL8100e",		RTL_TD_0, NULL, JUMBO_1K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   199
	[RTL_GIGA_MAC_VER_15] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   200
		_R("RTL8100e",		RTL_TD_0, NULL, JUMBO_1K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   201
	[RTL_GIGA_MAC_VER_16] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   202
		_R("RTL8101e",		RTL_TD_0, NULL, JUMBO_1K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   203
	[RTL_GIGA_MAC_VER_17] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   204
		_R("RTL8168b/8111b",	RTL_TD_1, NULL, JUMBO_4K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   205
	[RTL_GIGA_MAC_VER_18] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   206
		_R("RTL8168cp/8111cp",	RTL_TD_1, NULL, JUMBO_6K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   207
	[RTL_GIGA_MAC_VER_19] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   208
		_R("RTL8168c/8111c",	RTL_TD_1, NULL, JUMBO_6K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   209
	[RTL_GIGA_MAC_VER_20] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   210
		_R("RTL8168c/8111c",	RTL_TD_1, NULL, JUMBO_6K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   211
	[RTL_GIGA_MAC_VER_21] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   212
		_R("RTL8168c/8111c",	RTL_TD_1, NULL, JUMBO_6K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   213
	[RTL_GIGA_MAC_VER_22] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   214
		_R("RTL8168c/8111c",	RTL_TD_1, NULL, JUMBO_6K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   215
	[RTL_GIGA_MAC_VER_23] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   216
		_R("RTL8168cp/8111cp",	RTL_TD_1, NULL, JUMBO_6K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   217
	[RTL_GIGA_MAC_VER_24] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   218
		_R("RTL8168cp/8111cp",	RTL_TD_1, NULL, JUMBO_6K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   219
	[RTL_GIGA_MAC_VER_25] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   220
		_R("RTL8168d/8111d",	RTL_TD_1, FIRMWARE_8168D_1,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   221
							JUMBO_9K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   222
	[RTL_GIGA_MAC_VER_26] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   223
		_R("RTL8168d/8111d",	RTL_TD_1, FIRMWARE_8168D_2,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   224
							JUMBO_9K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   225
	[RTL_GIGA_MAC_VER_27] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   226
		_R("RTL8168dp/8111dp",	RTL_TD_1, NULL, JUMBO_9K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   227
	[RTL_GIGA_MAC_VER_28] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   228
		_R("RTL8168dp/8111dp",	RTL_TD_1, NULL, JUMBO_9K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   229
	[RTL_GIGA_MAC_VER_29] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   230
		_R("RTL8105e",		RTL_TD_1, FIRMWARE_8105E_1,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   231
							JUMBO_1K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   232
	[RTL_GIGA_MAC_VER_30] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   233
		_R("RTL8105e",		RTL_TD_1, FIRMWARE_8105E_1,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   234
							JUMBO_1K, true),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   235
	[RTL_GIGA_MAC_VER_31] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   236
		_R("RTL8168dp/8111dp",	RTL_TD_1, NULL, JUMBO_9K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   237
	[RTL_GIGA_MAC_VER_32] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   238
		_R("RTL8168e/8111e",	RTL_TD_1, FIRMWARE_8168E_1,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   239
							JUMBO_9K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   240
	[RTL_GIGA_MAC_VER_33] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   241
		_R("RTL8168e/8111e",	RTL_TD_1, FIRMWARE_8168E_2,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   242
							JUMBO_9K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   243
	[RTL_GIGA_MAC_VER_34] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   244
		_R("RTL8168evl/8111evl",RTL_TD_1, FIRMWARE_8168E_3,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   245
							JUMBO_9K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   246
	[RTL_GIGA_MAC_VER_35] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   247
		_R("RTL8168f/8111f",	RTL_TD_1, FIRMWARE_8168F_1,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   248
							JUMBO_9K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   249
	[RTL_GIGA_MAC_VER_36] =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   250
		_R("RTL8168f/8111f",	RTL_TD_1, FIRMWARE_8168F_2,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   251
							JUMBO_9K, false),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   252
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   253
#undef _R
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   254
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   255
enum cfg_version {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   256
	RTL_CFG_0 = 0x00,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   257
	RTL_CFG_1,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   258
	RTL_CFG_2
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   259
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   260
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   261
static void rtl_hw_start_8169(struct net_device *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   262
static void rtl_hw_start_8168(struct net_device *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   263
static void rtl_hw_start_8101(struct net_device *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   264
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   265
static DEFINE_PCI_DEVICE_TABLE(rtl8169_pci_tbl) = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   266
	{ PCI_DEVICE(PCI_VENDOR_ID_REALTEK,	0x8129), 0, 0, RTL_CFG_0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   267
	{ PCI_DEVICE(PCI_VENDOR_ID_REALTEK,	0x8136), 0, 0, RTL_CFG_2 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   268
	{ PCI_DEVICE(PCI_VENDOR_ID_REALTEK,	0x8167), 0, 0, RTL_CFG_0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   269
	{ PCI_DEVICE(PCI_VENDOR_ID_REALTEK,	0x8168), 0, 0, RTL_CFG_1 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   270
	{ PCI_DEVICE(PCI_VENDOR_ID_REALTEK,	0x8169), 0, 0, RTL_CFG_0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   271
	{ PCI_DEVICE(PCI_VENDOR_ID_DLINK,	0x4300), 0, 0, RTL_CFG_0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   272
	{ PCI_DEVICE(PCI_VENDOR_ID_DLINK,	0x4302), 0, 0, RTL_CFG_0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   273
	{ PCI_DEVICE(PCI_VENDOR_ID_AT,		0xc107), 0, 0, RTL_CFG_0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   274
	{ PCI_DEVICE(0x16ec,			0x0116), 0, 0, RTL_CFG_0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   275
	{ PCI_VENDOR_ID_LINKSYS,		0x1032,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   276
		PCI_ANY_ID, 0x0024, 0, 0, RTL_CFG_0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   277
	{ 0x0001,				0x8168,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   278
		PCI_ANY_ID, 0x2410, 0, 0, RTL_CFG_2 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   279
	{0,},
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   280
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   281
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   282
MODULE_DEVICE_TABLE(pci, rtl8169_pci_tbl);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   283
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   284
static int rx_buf_sz = 16383;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   285
static int use_dac;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   286
static struct {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   287
	u32 msg_enable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   288
} debug = { -1 };
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   289
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   290
enum rtl_registers {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   291
	MAC0		= 0,	/* Ethernet hardware address. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   292
	MAC4		= 4,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   293
	MAR0		= 8,	/* Multicast filter. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   294
	CounterAddrLow		= 0x10,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   295
	CounterAddrHigh		= 0x14,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   296
	TxDescStartAddrLow	= 0x20,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   297
	TxDescStartAddrHigh	= 0x24,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   298
	TxHDescStartAddrLow	= 0x28,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   299
	TxHDescStartAddrHigh	= 0x2c,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   300
	FLASH		= 0x30,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   301
	ERSR		= 0x36,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   302
	ChipCmd		= 0x37,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   303
	TxPoll		= 0x38,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   304
	IntrMask	= 0x3c,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   305
	IntrStatus	= 0x3e,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   306
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   307
	TxConfig	= 0x40,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   308
#define	TXCFG_AUTO_FIFO			(1 << 7)	/* 8111e-vl */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   309
#define	TXCFG_EMPTY			(1 << 11)	/* 8111e-vl */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   310
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   311
	RxConfig	= 0x44,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   312
#define	RX128_INT_EN			(1 << 15)	/* 8111c and later */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   313
#define	RX_MULTI_EN			(1 << 14)	/* 8111c only */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   314
#define	RXCFG_FIFO_SHIFT		13
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   315
					/* No threshold before first PCI xfer */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   316
#define	RX_FIFO_THRESH			(7 << RXCFG_FIFO_SHIFT)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   317
#define	RXCFG_DMA_SHIFT			8
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   318
					/* Unlimited maximum PCI burst. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   319
#define	RX_DMA_BURST			(7 << RXCFG_DMA_SHIFT)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   320
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   321
	RxMissed	= 0x4c,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   322
	Cfg9346		= 0x50,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   323
	Config0		= 0x51,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   324
	Config1		= 0x52,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   325
	Config2		= 0x53,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   326
	Config3		= 0x54,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   327
	Config4		= 0x55,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   328
	Config5		= 0x56,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   329
	MultiIntr	= 0x5c,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   330
	PHYAR		= 0x60,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   331
	PHYstatus	= 0x6c,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   332
	RxMaxSize	= 0xda,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   333
	CPlusCmd	= 0xe0,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   334
	IntrMitigate	= 0xe2,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   335
	RxDescAddrLow	= 0xe4,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   336
	RxDescAddrHigh	= 0xe8,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   337
	EarlyTxThres	= 0xec,	/* 8169. Unit of 32 bytes. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   338
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   339
#define NoEarlyTx	0x3f	/* Max value : no early transmit. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   340
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   341
	MaxTxPacketSize	= 0xec,	/* 8101/8168. Unit of 128 bytes. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   342
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   343
#define TxPacketMax	(8064 >> 7)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   344
#define EarlySize	0x27
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   345
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   346
	FuncEvent	= 0xf0,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   347
	FuncEventMask	= 0xf4,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   348
	FuncPresetState	= 0xf8,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   349
	FuncForceEvent	= 0xfc,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   350
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   351
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   352
enum rtl8110_registers {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   353
	TBICSR			= 0x64,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   354
	TBI_ANAR		= 0x68,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   355
	TBI_LPAR		= 0x6a,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   356
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   357
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   358
enum rtl8168_8101_registers {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   359
	CSIDR			= 0x64,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   360
	CSIAR			= 0x68,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   361
#define	CSIAR_FLAG			0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   362
#define	CSIAR_WRITE_CMD			0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   363
#define	CSIAR_BYTE_ENABLE		0x0f
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   364
#define	CSIAR_BYTE_ENABLE_SHIFT		12
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   365
#define	CSIAR_ADDR_MASK			0x0fff
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   366
	PMCH			= 0x6f,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   367
	EPHYAR			= 0x80,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   368
#define	EPHYAR_FLAG			0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   369
#define	EPHYAR_WRITE_CMD		0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   370
#define	EPHYAR_REG_MASK			0x1f
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   371
#define	EPHYAR_REG_SHIFT		16
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   372
#define	EPHYAR_DATA_MASK		0xffff
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   373
	DLLPR			= 0xd0,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   374
#define	PFM_EN				(1 << 6)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   375
	DBG_REG			= 0xd1,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   376
#define	FIX_NAK_1			(1 << 4)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   377
#define	FIX_NAK_2			(1 << 3)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   378
	TWSI			= 0xd2,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   379
	MCU			= 0xd3,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   380
#define	NOW_IS_OOB			(1 << 7)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   381
#define	EN_NDP				(1 << 3)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   382
#define	EN_OOB_RESET			(1 << 2)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   383
	EFUSEAR			= 0xdc,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   384
#define	EFUSEAR_FLAG			0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   385
#define	EFUSEAR_WRITE_CMD		0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   386
#define	EFUSEAR_READ_CMD		0x00000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   387
#define	EFUSEAR_REG_MASK		0x03ff
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   388
#define	EFUSEAR_REG_SHIFT		8
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   389
#define	EFUSEAR_DATA_MASK		0xff
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   390
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   391
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   392
enum rtl8168_registers {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   393
	LED_FREQ		= 0x1a,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   394
	EEE_LED			= 0x1b,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   395
	ERIDR			= 0x70,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   396
	ERIAR			= 0x74,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   397
#define ERIAR_FLAG			0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   398
#define ERIAR_WRITE_CMD			0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   399
#define ERIAR_READ_CMD			0x00000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   400
#define ERIAR_ADDR_BYTE_ALIGN		4
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   401
#define ERIAR_TYPE_SHIFT		16
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   402
#define ERIAR_EXGMAC			(0x00 << ERIAR_TYPE_SHIFT)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   403
#define ERIAR_MSIX			(0x01 << ERIAR_TYPE_SHIFT)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   404
#define ERIAR_ASF			(0x02 << ERIAR_TYPE_SHIFT)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   405
#define ERIAR_MASK_SHIFT		12
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   406
#define ERIAR_MASK_0001			(0x1 << ERIAR_MASK_SHIFT)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   407
#define ERIAR_MASK_0011			(0x3 << ERIAR_MASK_SHIFT)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   408
#define ERIAR_MASK_1111			(0xf << ERIAR_MASK_SHIFT)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   409
	EPHY_RXER_NUM		= 0x7c,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   410
	OCPDR			= 0xb0,	/* OCP GPHY access */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   411
#define OCPDR_WRITE_CMD			0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   412
#define OCPDR_READ_CMD			0x00000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   413
#define OCPDR_REG_MASK			0x7f
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   414
#define OCPDR_GPHY_REG_SHIFT		16
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   415
#define OCPDR_DATA_MASK			0xffff
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   416
	OCPAR			= 0xb4,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   417
#define OCPAR_FLAG			0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   418
#define OCPAR_GPHY_WRITE_CMD		0x8000f060
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   419
#define OCPAR_GPHY_READ_CMD		0x0000f060
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   420
	RDSAR1			= 0xd0,	/* 8168c only. Undocumented on 8168dp */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   421
	MISC			= 0xf0,	/* 8168e only. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   422
#define TXPLA_RST			(1 << 29)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   423
#define PWM_EN				(1 << 22)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   424
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   425
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   426
enum rtl_register_content {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   427
	/* InterruptStatusBits */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   428
	SYSErr		= 0x8000,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   429
	PCSTimeout	= 0x4000,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   430
	SWInt		= 0x0100,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   431
	TxDescUnavail	= 0x0080,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   432
	RxFIFOOver	= 0x0040,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   433
	LinkChg		= 0x0020,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   434
	RxOverflow	= 0x0010,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   435
	TxErr		= 0x0008,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   436
	TxOK		= 0x0004,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   437
	RxErr		= 0x0002,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   438
	RxOK		= 0x0001,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   439
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   440
	/* RxStatusDesc */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   441
	RxBOVF	= (1 << 24),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   442
	RxFOVF	= (1 << 23),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   443
	RxRWT	= (1 << 22),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   444
	RxRES	= (1 << 21),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   445
	RxRUNT	= (1 << 20),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   446
	RxCRC	= (1 << 19),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   447
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   448
	/* ChipCmdBits */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   449
	StopReq		= 0x80,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   450
	CmdReset	= 0x10,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   451
	CmdRxEnb	= 0x08,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   452
	CmdTxEnb	= 0x04,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   453
	RxBufEmpty	= 0x01,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   454
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   455
	/* TXPoll register p.5 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   456
	HPQ		= 0x80,		/* Poll cmd on the high prio queue */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   457
	NPQ		= 0x40,		/* Poll cmd on the low prio queue */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   458
	FSWInt		= 0x01,		/* Forced software interrupt */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   459
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   460
	/* Cfg9346Bits */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   461
	Cfg9346_Lock	= 0x00,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   462
	Cfg9346_Unlock	= 0xc0,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   463
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   464
	/* rx_mode_bits */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   465
	AcceptErr	= 0x20,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   466
	AcceptRunt	= 0x10,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   467
	AcceptBroadcast	= 0x08,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   468
	AcceptMulticast	= 0x04,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   469
	AcceptMyPhys	= 0x02,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   470
	AcceptAllPhys	= 0x01,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   471
#define RX_CONFIG_ACCEPT_MASK		0x3f
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   472
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   473
	/* TxConfigBits */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   474
	TxInterFrameGapShift = 24,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   475
	TxDMAShift = 8,	/* DMA burst value (0-7) is shift this many bits */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   476
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   477
	/* Config1 register p.24 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   478
	LEDS1		= (1 << 7),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   479
	LEDS0		= (1 << 6),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   480
	Speed_down	= (1 << 4),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   481
	MEMMAP		= (1 << 3),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   482
	IOMAP		= (1 << 2),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   483
	VPD		= (1 << 1),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   484
	PMEnable	= (1 << 0),	/* Power Management Enable */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   485
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   486
	/* Config2 register p. 25 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   487
	MSIEnable	= (1 << 5),	/* 8169 only. Reserved in the 8168. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   488
	PCI_Clock_66MHz = 0x01,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   489
	PCI_Clock_33MHz = 0x00,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   490
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   491
	/* Config3 register p.25 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   492
	MagicPacket	= (1 << 5),	/* Wake up when receives a Magic Packet */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   493
	LinkUp		= (1 << 4),	/* Wake up when the cable connection is re-established */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   494
	Jumbo_En0	= (1 << 2),	/* 8168 only. Reserved in the 8168b */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   495
	Beacon_en	= (1 << 0),	/* 8168 only. Reserved in the 8168b */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   496
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   497
	/* Config4 register */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   498
	Jumbo_En1	= (1 << 1),	/* 8168 only. Reserved in the 8168b */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   499
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   500
	/* Config5 register p.27 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   501
	BWF		= (1 << 6),	/* Accept Broadcast wakeup frame */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   502
	MWF		= (1 << 5),	/* Accept Multicast wakeup frame */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   503
	UWF		= (1 << 4),	/* Accept Unicast wakeup frame */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   504
	Spi_en		= (1 << 3),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   505
	LanWake		= (1 << 1),	/* LanWake enable/disable */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   506
	PMEStatus	= (1 << 0),	/* PME status can be reset by PCI RST# */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   507
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   508
	/* TBICSR p.28 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   509
	TBIReset	= 0x80000000,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   510
	TBILoopback	= 0x40000000,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   511
	TBINwEnable	= 0x20000000,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   512
	TBINwRestart	= 0x10000000,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   513
	TBILinkOk	= 0x02000000,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   514
	TBINwComplete	= 0x01000000,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   515
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   516
	/* CPlusCmd p.31 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   517
	EnableBist	= (1 << 15),	// 8168 8101
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   518
	Mac_dbgo_oe	= (1 << 14),	// 8168 8101
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   519
	Normal_mode	= (1 << 13),	// unused
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   520
	Force_half_dup	= (1 << 12),	// 8168 8101
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   521
	Force_rxflow_en	= (1 << 11),	// 8168 8101
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   522
	Force_txflow_en	= (1 << 10),	// 8168 8101
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   523
	Cxpl_dbg_sel	= (1 << 9),	// 8168 8101
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   524
	ASF		= (1 << 8),	// 8168 8101
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   525
	PktCntrDisable	= (1 << 7),	// 8168 8101
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   526
	Mac_dbgo_sel	= 0x001c,	// 8168
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   527
	RxVlan		= (1 << 6),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   528
	RxChkSum	= (1 << 5),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   529
	PCIDAC		= (1 << 4),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   530
	PCIMulRW	= (1 << 3),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   531
	INTT_0		= 0x0000,	// 8168
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   532
	INTT_1		= 0x0001,	// 8168
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   533
	INTT_2		= 0x0002,	// 8168
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   534
	INTT_3		= 0x0003,	// 8168
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   535
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   536
	/* rtl8169_PHYstatus */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   537
	TBI_Enable	= 0x80,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   538
	TxFlowCtrl	= 0x40,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   539
	RxFlowCtrl	= 0x20,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   540
	_1000bpsF	= 0x10,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   541
	_100bps		= 0x08,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   542
	_10bps		= 0x04,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   543
	LinkStatus	= 0x02,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   544
	FullDup		= 0x01,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   545
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   546
	/* _TBICSRBit */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   547
	TBILinkOK	= 0x02000000,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   548
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   549
	/* DumpCounterCommand */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   550
	CounterDump	= 0x8,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   551
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   552
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   553
enum rtl_desc_bit {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   554
	/* First doubleword. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   555
	DescOwn		= (1 << 31), /* Descriptor is owned by NIC */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   556
	RingEnd		= (1 << 30), /* End of descriptor ring */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   557
	FirstFrag	= (1 << 29), /* First segment of a packet */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   558
	LastFrag	= (1 << 28), /* Final segment of a packet */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   559
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   560
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   561
/* Generic case. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   562
enum rtl_tx_desc_bit {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   563
	/* First doubleword. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   564
	TD_LSO		= (1 << 27),		/* Large Send Offload */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   565
#define TD_MSS_MAX			0x07ffu	/* MSS value */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   566
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   567
	/* Second doubleword. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   568
	TxVlanTag	= (1 << 17),		/* Add VLAN tag */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   569
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   570
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   571
/* 8169, 8168b and 810x except 8102e. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   572
enum rtl_tx_desc_bit_0 {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   573
	/* First doubleword. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   574
#define TD0_MSS_SHIFT			16	/* MSS position (11 bits) */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   575
	TD0_TCP_CS	= (1 << 16),		/* Calculate TCP/IP checksum */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   576
	TD0_UDP_CS	= (1 << 17),		/* Calculate UDP/IP checksum */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   577
	TD0_IP_CS	= (1 << 18),		/* Calculate IP checksum */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   578
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   579
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   580
/* 8102e, 8168c and beyond. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   581
enum rtl_tx_desc_bit_1 {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   582
	/* Second doubleword. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   583
#define TD1_MSS_SHIFT			18	/* MSS position (11 bits) */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   584
	TD1_IP_CS	= (1 << 29),		/* Calculate IP checksum */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   585
	TD1_TCP_CS	= (1 << 30),		/* Calculate TCP/IP checksum */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   586
	TD1_UDP_CS	= (1 << 31),		/* Calculate UDP/IP checksum */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   587
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   588
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   589
static const struct rtl_tx_desc_info {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   590
	struct {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   591
		u32 udp;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   592
		u32 tcp;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   593
	} checksum;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   594
	u16 mss_shift;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   595
	u16 opts_offset;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   596
} tx_desc_info [] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   597
	[RTL_TD_0] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   598
		.checksum = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   599
			.udp	= TD0_IP_CS | TD0_UDP_CS,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   600
			.tcp	= TD0_IP_CS | TD0_TCP_CS
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   601
		},
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   602
		.mss_shift	= TD0_MSS_SHIFT,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   603
		.opts_offset	= 0
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   604
	},
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   605
	[RTL_TD_1] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   606
		.checksum = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   607
			.udp	= TD1_IP_CS | TD1_UDP_CS,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   608
			.tcp	= TD1_IP_CS | TD1_TCP_CS
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   609
		},
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   610
		.mss_shift	= TD1_MSS_SHIFT,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   611
		.opts_offset	= 1
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   612
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   613
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   614
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   615
enum rtl_rx_desc_bit {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   616
	/* Rx private */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   617
	PID1		= (1 << 18), /* Protocol ID bit 1/2 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   618
	PID0		= (1 << 17), /* Protocol ID bit 2/2 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   619
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   620
#define RxProtoUDP	(PID1)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   621
#define RxProtoTCP	(PID0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   622
#define RxProtoIP	(PID1 | PID0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   623
#define RxProtoMask	RxProtoIP
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   624
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   625
	IPFail		= (1 << 16), /* IP checksum failed */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   626
	UDPFail		= (1 << 15), /* UDP/IP checksum failed */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   627
	TCPFail		= (1 << 14), /* TCP/IP checksum failed */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   628
	RxVlanTag	= (1 << 16), /* VLAN tag available */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   629
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   630
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   631
#define RsvdMask	0x3fffc000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   632
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   633
struct TxDesc {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   634
	__le32 opts1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   635
	__le32 opts2;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   636
	__le64 addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   637
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   638
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   639
struct RxDesc {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   640
	__le32 opts1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   641
	__le32 opts2;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   642
	__le64 addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   643
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   644
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   645
struct ring_info {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   646
	struct sk_buff	*skb;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   647
	u32		len;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   648
	u8		__pad[sizeof(void *) - sizeof(u32)];
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   649
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   650
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   651
enum features {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   652
	RTL_FEATURE_WOL		= (1 << 0),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   653
	RTL_FEATURE_MSI		= (1 << 1),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   654
	RTL_FEATURE_GMII	= (1 << 2),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   655
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   656
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   657
struct rtl8169_counters {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   658
	__le64	tx_packets;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   659
	__le64	rx_packets;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   660
	__le64	tx_errors;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   661
	__le32	rx_errors;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   662
	__le16	rx_missed;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   663
	__le16	align_errors;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   664
	__le32	tx_one_collision;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   665
	__le32	tx_multi_collision;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   666
	__le64	rx_unicast;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   667
	__le64	rx_broadcast;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   668
	__le32	rx_multicast;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   669
	__le16	tx_aborted;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   670
	__le16	tx_underun;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   671
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   672
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   673
struct rtl8169_private {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   674
	void __iomem *mmio_addr;	/* memory map physical address */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   675
	struct pci_dev *pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   676
	struct net_device *dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   677
	struct napi_struct napi;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   678
	spinlock_t lock;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   679
	u32 msg_enable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   680
	u16 txd_version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   681
	u16 mac_version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   682
	u32 cur_rx; /* Index into the Rx descriptor buffer of next Rx pkt. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   683
	u32 cur_tx; /* Index into the Tx descriptor buffer of next Rx pkt. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   684
	u32 dirty_rx;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   685
	u32 dirty_tx;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   686
	struct TxDesc *TxDescArray;	/* 256-aligned Tx descriptor ring */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   687
	struct RxDesc *RxDescArray;	/* 256-aligned Rx descriptor ring */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   688
	dma_addr_t TxPhyAddr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   689
	dma_addr_t RxPhyAddr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   690
	void *Rx_databuff[NUM_RX_DESC];	/* Rx data buffers */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   691
	struct ring_info tx_skb[NUM_TX_DESC];	/* Tx data buffers */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   692
	struct timer_list timer;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   693
	u16 cp_cmd;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   694
	u16 intr_event;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   695
	u16 napi_event;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   696
	u16 intr_mask;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   697
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   698
	struct mdio_ops {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   699
		void (*write)(void __iomem *, int, int);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   700
		int (*read)(void __iomem *, int);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   701
	} mdio_ops;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   702
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   703
	struct pll_power_ops {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   704
		void (*down)(struct rtl8169_private *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   705
		void (*up)(struct rtl8169_private *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   706
	} pll_power_ops;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   707
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   708
	struct jumbo_ops {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   709
		void (*enable)(struct rtl8169_private *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   710
		void (*disable)(struct rtl8169_private *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   711
	} jumbo_ops;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   712
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   713
	int (*set_speed)(struct net_device *, u8 aneg, u16 sp, u8 dpx, u32 adv);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   714
	int (*get_settings)(struct net_device *, struct ethtool_cmd *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   715
	void (*phy_reset_enable)(struct rtl8169_private *tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   716
	void (*hw_start)(struct net_device *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   717
	unsigned int (*phy_reset_pending)(struct rtl8169_private *tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   718
	unsigned int (*link_ok)(void __iomem *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   719
	int (*do_ioctl)(struct rtl8169_private *tp, struct mii_ioctl_data *data, int cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   720
	struct delayed_work task;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   721
	unsigned features;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   722
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   723
	struct mii_if_info mii;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   724
	struct rtl8169_counters counters;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   725
	u32 saved_wolopts;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   726
	u32 opts1_mask;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   727
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   728
	struct rtl_fw {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   729
		const struct firmware *fw;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   730
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   731
#define RTL_VER_SIZE		32
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   732
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   733
		char version[RTL_VER_SIZE];
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   734
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   735
		struct rtl_fw_phy_action {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   736
			__le32 *code;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   737
			size_t size;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   738
		} phy_action;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   739
	} *rtl_fw;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   740
#define RTL_FIRMWARE_UNKNOWN	ERR_PTR(-EAGAIN)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   741
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   742
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   743
MODULE_AUTHOR("Realtek and the Linux r8169 crew <netdev@vger.kernel.org>");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   744
MODULE_DESCRIPTION("RealTek RTL-8169 Gigabit Ethernet driver");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   745
module_param(use_dac, int, 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   746
MODULE_PARM_DESC(use_dac, "Enable PCI DAC. Unsafe on 32 bit PCI slot.");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   747
module_param_named(debug, debug.msg_enable, int, 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   748
MODULE_PARM_DESC(debug, "Debug verbosity level (0=none, ..., 16=all)");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   749
MODULE_LICENSE("GPL");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   750
MODULE_VERSION(RTL8169_VERSION);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   751
MODULE_FIRMWARE(FIRMWARE_8168D_1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   752
MODULE_FIRMWARE(FIRMWARE_8168D_2);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   753
MODULE_FIRMWARE(FIRMWARE_8168E_1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   754
MODULE_FIRMWARE(FIRMWARE_8168E_2);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   755
MODULE_FIRMWARE(FIRMWARE_8168E_3);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   756
MODULE_FIRMWARE(FIRMWARE_8105E_1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   757
MODULE_FIRMWARE(FIRMWARE_8168F_1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   758
MODULE_FIRMWARE(FIRMWARE_8168F_2);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   759
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   760
static int rtl8169_open(struct net_device *dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   761
static netdev_tx_t rtl8169_start_xmit(struct sk_buff *skb,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   762
				      struct net_device *dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   763
static irqreturn_t rtl8169_interrupt(int irq, void *dev_instance);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   764
static int rtl8169_init_ring(struct net_device *dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   765
static void rtl_hw_start(struct net_device *dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   766
static int rtl8169_close(struct net_device *dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   767
static void rtl_set_rx_mode(struct net_device *dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   768
static void rtl8169_tx_timeout(struct net_device *dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   769
static struct net_device_stats *rtl8169_get_stats(struct net_device *dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   770
static int rtl8169_rx_interrupt(struct net_device *, struct rtl8169_private *,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   771
				void __iomem *, u32 budget);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   772
static int rtl8169_change_mtu(struct net_device *dev, int new_mtu);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   773
static void rtl8169_down(struct net_device *dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   774
static void rtl8169_rx_clear(struct rtl8169_private *tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   775
static int rtl8169_poll(struct napi_struct *napi, int budget);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   776
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   777
static void rtl_tx_performance_tweak(struct pci_dev *pdev, u16 force)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   778
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   779
	int cap = pci_pcie_cap(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   780
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   781
	if (cap) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   782
		u16 ctl;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   783
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   784
		pci_read_config_word(pdev, cap + PCI_EXP_DEVCTL, &ctl);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   785
		ctl = (ctl & ~PCI_EXP_DEVCTL_READRQ) | force;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   786
		pci_write_config_word(pdev, cap + PCI_EXP_DEVCTL, ctl);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   787
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   788
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   789
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   790
static u32 ocp_read(struct rtl8169_private *tp, u8 mask, u16 reg)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   791
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   792
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   793
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   794
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   795
	RTL_W32(OCPAR, ((u32)mask & 0x0f) << 12 | (reg & 0x0fff));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   796
	for (i = 0; i < 20; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   797
		udelay(100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   798
		if (RTL_R32(OCPAR) & OCPAR_FLAG)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   799
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   800
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   801
	return RTL_R32(OCPDR);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   802
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   803
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   804
static void ocp_write(struct rtl8169_private *tp, u8 mask, u16 reg, u32 data)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   805
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   806
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   807
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   808
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   809
	RTL_W32(OCPDR, data);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   810
	RTL_W32(OCPAR, OCPAR_FLAG | ((u32)mask & 0x0f) << 12 | (reg & 0x0fff));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   811
	for (i = 0; i < 20; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   812
		udelay(100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   813
		if ((RTL_R32(OCPAR) & OCPAR_FLAG) == 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   814
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   815
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   816
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   817
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   818
static void rtl8168_oob_notify(struct rtl8169_private *tp, u8 cmd)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   819
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   820
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   821
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   822
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   823
	RTL_W8(ERIDR, cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   824
	RTL_W32(ERIAR, 0x800010e8);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   825
	msleep(2);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   826
	for (i = 0; i < 5; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   827
		udelay(100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   828
		if (!(RTL_R32(ERIAR) & ERIAR_FLAG))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   829
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   830
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   831
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   832
	ocp_write(tp, 0x1, 0x30, 0x00000001);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   833
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   834
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   835
#define OOB_CMD_RESET		0x00
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   836
#define OOB_CMD_DRIVER_START	0x05
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   837
#define OOB_CMD_DRIVER_STOP	0x06
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   838
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   839
static u16 rtl8168_get_ocp_reg(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   840
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   841
	return (tp->mac_version == RTL_GIGA_MAC_VER_31) ? 0xb8 : 0x10;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   842
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   843
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   844
static void rtl8168_driver_start(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   845
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   846
	u16 reg;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   847
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   848
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   849
	rtl8168_oob_notify(tp, OOB_CMD_DRIVER_START);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   850
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   851
	reg = rtl8168_get_ocp_reg(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   852
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   853
	for (i = 0; i < 10; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   854
		msleep(10);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   855
		if (ocp_read(tp, 0x0f, reg) & 0x00000800)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   856
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   857
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   858
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   859
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   860
static void rtl8168_driver_stop(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   861
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   862
	u16 reg;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   863
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   864
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   865
	rtl8168_oob_notify(tp, OOB_CMD_DRIVER_STOP);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   866
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   867
	reg = rtl8168_get_ocp_reg(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   868
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   869
	for (i = 0; i < 10; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   870
		msleep(10);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   871
		if ((ocp_read(tp, 0x0f, reg) & 0x00000800) == 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   872
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   873
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   874
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   875
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   876
static int r8168dp_check_dash(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   877
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   878
	u16 reg = rtl8168_get_ocp_reg(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   879
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   880
	return (ocp_read(tp, 0x0f, reg) & 0x00008000) ? 1 : 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   881
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   882
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   883
static void r8169_mdio_write(void __iomem *ioaddr, int reg_addr, int value)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   884
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   885
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   886
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   887
	RTL_W32(PHYAR, 0x80000000 | (reg_addr & 0x1f) << 16 | (value & 0xffff));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   888
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   889
	for (i = 20; i > 0; i--) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   890
		/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   891
		 * Check if the RTL8169 has completed writing to the specified
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   892
		 * MII register.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   893
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   894
		if (!(RTL_R32(PHYAR) & 0x80000000))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   895
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   896
		udelay(25);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   897
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   898
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   899
	 * According to hardware specs a 20us delay is required after write
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   900
	 * complete indication, but before sending next command.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   901
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   902
	udelay(20);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   903
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   904
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   905
static int r8169_mdio_read(void __iomem *ioaddr, int reg_addr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   906
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   907
	int i, value = -1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   908
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   909
	RTL_W32(PHYAR, 0x0 | (reg_addr & 0x1f) << 16);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   910
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   911
	for (i = 20; i > 0; i--) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   912
		/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   913
		 * Check if the RTL8169 has completed retrieving data from
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   914
		 * the specified MII register.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   915
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   916
		if (RTL_R32(PHYAR) & 0x80000000) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   917
			value = RTL_R32(PHYAR) & 0xffff;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   918
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   919
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   920
		udelay(25);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   921
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   922
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   923
	 * According to hardware specs a 20us delay is required after read
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   924
	 * complete indication, but before sending next command.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   925
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   926
	udelay(20);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   927
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   928
	return value;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   929
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   930
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   931
static void r8168dp_1_mdio_access(void __iomem *ioaddr, int reg_addr, u32 data)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   932
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   933
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   934
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   935
	RTL_W32(OCPDR, data |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   936
		((reg_addr & OCPDR_REG_MASK) << OCPDR_GPHY_REG_SHIFT));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   937
	RTL_W32(OCPAR, OCPAR_GPHY_WRITE_CMD);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   938
	RTL_W32(EPHY_RXER_NUM, 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   939
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   940
	for (i = 0; i < 100; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   941
		mdelay(1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   942
		if (!(RTL_R32(OCPAR) & OCPAR_FLAG))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   943
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   944
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   945
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   946
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   947
static void r8168dp_1_mdio_write(void __iomem *ioaddr, int reg_addr, int value)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   948
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   949
	r8168dp_1_mdio_access(ioaddr, reg_addr, OCPDR_WRITE_CMD |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   950
		(value & OCPDR_DATA_MASK));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   951
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   952
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   953
static int r8168dp_1_mdio_read(void __iomem *ioaddr, int reg_addr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   954
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   955
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   956
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   957
	r8168dp_1_mdio_access(ioaddr, reg_addr, OCPDR_READ_CMD);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   958
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   959
	mdelay(1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   960
	RTL_W32(OCPAR, OCPAR_GPHY_READ_CMD);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   961
	RTL_W32(EPHY_RXER_NUM, 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   962
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   963
	for (i = 0; i < 100; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   964
		mdelay(1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   965
		if (RTL_R32(OCPAR) & OCPAR_FLAG)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   966
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   967
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   968
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   969
	return RTL_R32(OCPDR) & OCPDR_DATA_MASK;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   970
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   971
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   972
#define R8168DP_1_MDIO_ACCESS_BIT	0x00020000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   973
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   974
static void r8168dp_2_mdio_start(void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   975
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   976
	RTL_W32(0xd0, RTL_R32(0xd0) & ~R8168DP_1_MDIO_ACCESS_BIT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   977
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   978
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   979
static void r8168dp_2_mdio_stop(void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   980
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   981
	RTL_W32(0xd0, RTL_R32(0xd0) | R8168DP_1_MDIO_ACCESS_BIT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   982
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   983
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   984
static void r8168dp_2_mdio_write(void __iomem *ioaddr, int reg_addr, int value)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   985
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   986
	r8168dp_2_mdio_start(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   987
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   988
	r8169_mdio_write(ioaddr, reg_addr, value);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   989
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   990
	r8168dp_2_mdio_stop(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   991
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   992
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   993
static int r8168dp_2_mdio_read(void __iomem *ioaddr, int reg_addr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   994
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   995
	int value;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   996
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   997
	r8168dp_2_mdio_start(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   998
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   999
	value = r8169_mdio_read(ioaddr, reg_addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1001
	r8168dp_2_mdio_stop(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1002
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1003
	return value;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1004
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1005
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1006
static void rtl_writephy(struct rtl8169_private *tp, int location, u32 val)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1007
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1008
	tp->mdio_ops.write(tp->mmio_addr, location, val);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1009
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1010
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1011
static int rtl_readphy(struct rtl8169_private *tp, int location)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1012
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1013
	return tp->mdio_ops.read(tp->mmio_addr, location);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1014
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1015
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1016
static void rtl_patchphy(struct rtl8169_private *tp, int reg_addr, int value)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1017
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1018
	rtl_writephy(tp, reg_addr, rtl_readphy(tp, reg_addr) | value);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1019
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1020
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1021
static void rtl_w1w0_phy(struct rtl8169_private *tp, int reg_addr, int p, int m)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1022
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1023
	int val;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1024
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1025
	val = rtl_readphy(tp, reg_addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1026
	rtl_writephy(tp, reg_addr, (val | p) & ~m);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1027
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1028
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1029
static void rtl_mdio_write(struct net_device *dev, int phy_id, int location,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1030
			   int val)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1031
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1032
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1033
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1034
	rtl_writephy(tp, location, val);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1035
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1036
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1037
static int rtl_mdio_read(struct net_device *dev, int phy_id, int location)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1038
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1039
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1040
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1041
	return rtl_readphy(tp, location);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1042
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1043
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1044
static void rtl_ephy_write(void __iomem *ioaddr, int reg_addr, int value)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1045
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1046
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1047
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1048
	RTL_W32(EPHYAR, EPHYAR_WRITE_CMD | (value & EPHYAR_DATA_MASK) |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1049
		(reg_addr & EPHYAR_REG_MASK) << EPHYAR_REG_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1050
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1051
	for (i = 0; i < 100; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1052
		if (!(RTL_R32(EPHYAR) & EPHYAR_FLAG))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1053
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1054
		udelay(10);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1055
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1056
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1057
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1058
static u16 rtl_ephy_read(void __iomem *ioaddr, int reg_addr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1059
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1060
	u16 value = 0xffff;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1061
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1062
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1063
	RTL_W32(EPHYAR, (reg_addr & EPHYAR_REG_MASK) << EPHYAR_REG_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1064
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1065
	for (i = 0; i < 100; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1066
		if (RTL_R32(EPHYAR) & EPHYAR_FLAG) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1067
			value = RTL_R32(EPHYAR) & EPHYAR_DATA_MASK;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1068
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1069
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1070
		udelay(10);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1071
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1072
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1073
	return value;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1074
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1075
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1076
static void rtl_csi_write(void __iomem *ioaddr, int addr, int value)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1077
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1078
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1079
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1080
	RTL_W32(CSIDR, value);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1081
	RTL_W32(CSIAR, CSIAR_WRITE_CMD | (addr & CSIAR_ADDR_MASK) |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1082
		CSIAR_BYTE_ENABLE << CSIAR_BYTE_ENABLE_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1083
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1084
	for (i = 0; i < 100; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1085
		if (!(RTL_R32(CSIAR) & CSIAR_FLAG))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1086
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1087
		udelay(10);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1088
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1089
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1090
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1091
static u32 rtl_csi_read(void __iomem *ioaddr, int addr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1092
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1093
	u32 value = ~0x00;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1094
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1095
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1096
	RTL_W32(CSIAR, (addr & CSIAR_ADDR_MASK) |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1097
		CSIAR_BYTE_ENABLE << CSIAR_BYTE_ENABLE_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1098
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1099
	for (i = 0; i < 100; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1100
		if (RTL_R32(CSIAR) & CSIAR_FLAG) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1101
			value = RTL_R32(CSIDR);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1102
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1103
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1104
		udelay(10);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1105
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1106
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1107
	return value;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1108
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1109
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1110
static
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1111
void rtl_eri_write(void __iomem *ioaddr, int addr, u32 mask, u32 val, int type)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1112
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1113
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1114
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1115
	BUG_ON((addr & 3) || (mask == 0));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1116
	RTL_W32(ERIDR, val);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1117
	RTL_W32(ERIAR, ERIAR_WRITE_CMD | type | mask | addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1118
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1119
	for (i = 0; i < 100; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1120
		if (!(RTL_R32(ERIAR) & ERIAR_FLAG))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1121
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1122
		udelay(100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1123
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1124
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1125
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1126
static u32 rtl_eri_read(void __iomem *ioaddr, int addr, int type)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1127
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1128
	u32 value = ~0x00;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1129
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1130
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1131
	RTL_W32(ERIAR, ERIAR_READ_CMD | type | ERIAR_MASK_1111 | addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1132
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1133
	for (i = 0; i < 100; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1134
		if (RTL_R32(ERIAR) & ERIAR_FLAG) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1135
			value = RTL_R32(ERIDR);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1136
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1137
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1138
		udelay(100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1139
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1140
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1141
	return value;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1142
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1143
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1144
static void
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1145
rtl_w1w0_eri(void __iomem *ioaddr, int addr, u32 mask, u32 p, u32 m, int type)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1146
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1147
	u32 val;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1148
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1149
	val = rtl_eri_read(ioaddr, addr, type);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1150
	rtl_eri_write(ioaddr, addr, mask, (val & ~m) | p, type);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1151
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1152
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1153
struct exgmac_reg {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1154
	u16 addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1155
	u16 mask;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1156
	u32 val;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1157
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1158
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1159
static void rtl_write_exgmac_batch(void __iomem *ioaddr,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1160
				   const struct exgmac_reg *r, int len)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1161
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1162
	while (len-- > 0) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1163
		rtl_eri_write(ioaddr, r->addr, r->mask, r->val, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1164
		r++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1165
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1166
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1167
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1168
static u8 rtl8168d_efuse_read(void __iomem *ioaddr, int reg_addr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1169
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1170
	u8 value = 0xff;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1171
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1172
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1173
	RTL_W32(EFUSEAR, (reg_addr & EFUSEAR_REG_MASK) << EFUSEAR_REG_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1174
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1175
	for (i = 0; i < 300; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1176
		if (RTL_R32(EFUSEAR) & EFUSEAR_FLAG) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1177
			value = RTL_R32(EFUSEAR) & EFUSEAR_DATA_MASK;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1178
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1179
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1180
		udelay(100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1181
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1182
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1183
	return value;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1184
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1185
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1186
static void rtl8169_irq_mask_and_ack(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1187
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1188
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1189
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1190
	RTL_W16(IntrMask, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1191
	RTL_W16(IntrStatus, tp->intr_event);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1192
	RTL_R8(ChipCmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1193
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1194
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1195
static unsigned int rtl8169_tbi_reset_pending(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1196
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1197
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1198
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1199
	return RTL_R32(TBICSR) & TBIReset;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1200
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1201
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1202
static unsigned int rtl8169_xmii_reset_pending(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1203
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1204
	return rtl_readphy(tp, MII_BMCR) & BMCR_RESET;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1205
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1206
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1207
static unsigned int rtl8169_tbi_link_ok(void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1208
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1209
	return RTL_R32(TBICSR) & TBILinkOk;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1210
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1211
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1212
static unsigned int rtl8169_xmii_link_ok(void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1213
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1214
	return RTL_R8(PHYstatus) & LinkStatus;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1215
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1216
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1217
static void rtl8169_tbi_reset_enable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1218
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1219
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1220
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1221
	RTL_W32(TBICSR, RTL_R32(TBICSR) | TBIReset);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1222
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1223
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1224
static void rtl8169_xmii_reset_enable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1225
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1226
	unsigned int val;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1227
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1228
	val = rtl_readphy(tp, MII_BMCR) | BMCR_RESET;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1229
	rtl_writephy(tp, MII_BMCR, val & 0xffff);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1230
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1231
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1232
static void rtl_link_chg_patch(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1233
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1234
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1235
	struct net_device *dev = tp->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1236
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1237
	if (!netif_running(dev))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1238
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1239
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1240
	if (tp->mac_version == RTL_GIGA_MAC_VER_34) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1241
		if (RTL_R8(PHYstatus) & _1000bpsF) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1242
			rtl_eri_write(ioaddr, 0x1bc, ERIAR_MASK_1111,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1243
				      0x00000011, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1244
			rtl_eri_write(ioaddr, 0x1dc, ERIAR_MASK_1111,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1245
				      0x00000005, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1246
		} else if (RTL_R8(PHYstatus) & _100bps) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1247
			rtl_eri_write(ioaddr, 0x1bc, ERIAR_MASK_1111,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1248
				      0x0000001f, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1249
			rtl_eri_write(ioaddr, 0x1dc, ERIAR_MASK_1111,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1250
				      0x00000005, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1251
		} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1252
			rtl_eri_write(ioaddr, 0x1bc, ERIAR_MASK_1111,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1253
				      0x0000001f, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1254
			rtl_eri_write(ioaddr, 0x1dc, ERIAR_MASK_1111,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1255
				      0x0000003f, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1256
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1257
		/* Reset packet filter */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1258
		rtl_w1w0_eri(ioaddr, 0xdc, ERIAR_MASK_0001, 0x00, 0x01,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1259
			     ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1260
		rtl_w1w0_eri(ioaddr, 0xdc, ERIAR_MASK_0001, 0x01, 0x00,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1261
			     ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1262
	} else if (tp->mac_version == RTL_GIGA_MAC_VER_35 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1263
		   tp->mac_version == RTL_GIGA_MAC_VER_36) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1264
		if (RTL_R8(PHYstatus) & _1000bpsF) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1265
			rtl_eri_write(ioaddr, 0x1bc, ERIAR_MASK_1111,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1266
				      0x00000011, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1267
			rtl_eri_write(ioaddr, 0x1dc, ERIAR_MASK_1111,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1268
				      0x00000005, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1269
		} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1270
			rtl_eri_write(ioaddr, 0x1bc, ERIAR_MASK_1111,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1271
				      0x0000001f, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1272
			rtl_eri_write(ioaddr, 0x1dc, ERIAR_MASK_1111,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1273
				      0x0000003f, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1274
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1275
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1276
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1277
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1278
static void __rtl8169_check_link_status(struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1279
					struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1280
					void __iomem *ioaddr, bool pm)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1281
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1282
	unsigned long flags;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1283
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1284
	spin_lock_irqsave(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1285
	if (tp->link_ok(ioaddr)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1286
		rtl_link_chg_patch(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1287
		/* This is to cancel a scheduled suspend if there's one. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1288
		if (pm)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1289
			pm_request_resume(&tp->pci_dev->dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1290
		netif_carrier_on(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1291
		if (net_ratelimit())
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1292
			netif_info(tp, ifup, dev, "link up\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1293
	} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1294
		netif_carrier_off(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1295
		netif_info(tp, ifdown, dev, "link down\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1296
		if (pm)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1297
			pm_schedule_suspend(&tp->pci_dev->dev, 5000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1298
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1299
	spin_unlock_irqrestore(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1300
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1301
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1302
static void rtl8169_check_link_status(struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1303
				      struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1304
				      void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1305
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1306
	__rtl8169_check_link_status(dev, tp, ioaddr, false);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1307
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1308
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1309
#define WAKE_ANY (WAKE_PHY | WAKE_MAGIC | WAKE_UCAST | WAKE_BCAST | WAKE_MCAST)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1310
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1311
static u32 __rtl8169_get_wol(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1312
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1313
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1314
	u8 options;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1315
	u32 wolopts = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1316
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1317
	options = RTL_R8(Config1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1318
	if (!(options & PMEnable))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1319
		return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1320
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1321
	options = RTL_R8(Config3);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1322
	if (options & LinkUp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1323
		wolopts |= WAKE_PHY;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1324
	if (options & MagicPacket)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1325
		wolopts |= WAKE_MAGIC;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1326
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1327
	options = RTL_R8(Config5);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1328
	if (options & UWF)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1329
		wolopts |= WAKE_UCAST;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1330
	if (options & BWF)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1331
		wolopts |= WAKE_BCAST;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1332
	if (options & MWF)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1333
		wolopts |= WAKE_MCAST;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1334
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1335
	return wolopts;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1336
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1337
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1338
static void rtl8169_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1339
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1340
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1341
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1342
	spin_lock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1343
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1344
	wol->supported = WAKE_ANY;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1345
	wol->wolopts = __rtl8169_get_wol(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1346
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1347
	spin_unlock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1348
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1349
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1350
static void __rtl8169_set_wol(struct rtl8169_private *tp, u32 wolopts)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1351
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1352
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1353
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1354
	static const struct {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1355
		u32 opt;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1356
		u16 reg;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1357
		u8  mask;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1358
	} cfg[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1359
		{ WAKE_ANY,   Config1, PMEnable },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1360
		{ WAKE_PHY,   Config3, LinkUp },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1361
		{ WAKE_MAGIC, Config3, MagicPacket },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1362
		{ WAKE_UCAST, Config5, UWF },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1363
		{ WAKE_BCAST, Config5, BWF },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1364
		{ WAKE_MCAST, Config5, MWF },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1365
		{ WAKE_ANY,   Config5, LanWake }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1366
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1367
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1368
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1369
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1370
	for (i = 0; i < ARRAY_SIZE(cfg); i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1371
		u8 options = RTL_R8(cfg[i].reg) & ~cfg[i].mask;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1372
		if (wolopts & cfg[i].opt)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1373
			options |= cfg[i].mask;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1374
		RTL_W8(cfg[i].reg, options);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1375
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1376
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1377
	RTL_W8(Cfg9346, Cfg9346_Lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1378
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1379
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1380
static int rtl8169_set_wol(struct net_device *dev, struct ethtool_wolinfo *wol)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1381
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1382
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1383
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1384
	spin_lock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1385
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1386
	if (wol->wolopts)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1387
		tp->features |= RTL_FEATURE_WOL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1388
	else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1389
		tp->features &= ~RTL_FEATURE_WOL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1390
	__rtl8169_set_wol(tp, wol->wolopts);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1391
	spin_unlock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1392
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1393
	device_set_wakeup_enable(&tp->pci_dev->dev, wol->wolopts);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1394
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1395
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1396
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1397
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1398
static const char *rtl_lookup_firmware_name(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1399
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1400
	return rtl_chip_infos[tp->mac_version].fw_name;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1401
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1402
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1403
static void rtl8169_get_drvinfo(struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1404
				struct ethtool_drvinfo *info)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1405
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1406
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1407
	struct rtl_fw *rtl_fw = tp->rtl_fw;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1408
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1409
	strlcpy(info->driver, MODULENAME, sizeof(info->driver));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1410
	strlcpy(info->version, RTL8169_VERSION, sizeof(info->version));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1411
	strlcpy(info->bus_info, pci_name(tp->pci_dev), sizeof(info->bus_info));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1412
	BUILD_BUG_ON(sizeof(info->fw_version) < sizeof(rtl_fw->version));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1413
	strlcpy(info->fw_version, IS_ERR_OR_NULL(rtl_fw) ? "N/A" :
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1414
	       rtl_fw->version, sizeof(info->fw_version));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1415
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1416
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1417
static int rtl8169_get_regs_len(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1418
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1419
	return R8169_REGS_SIZE;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1420
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1421
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1422
static int rtl8169_set_speed_tbi(struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1423
				 u8 autoneg, u16 speed, u8 duplex, u32 ignored)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1424
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1425
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1426
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1427
	int ret = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1428
	u32 reg;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1429
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1430
	reg = RTL_R32(TBICSR);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1431
	if ((autoneg == AUTONEG_DISABLE) && (speed == SPEED_1000) &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1432
	    (duplex == DUPLEX_FULL)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1433
		RTL_W32(TBICSR, reg & ~(TBINwEnable | TBINwRestart));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1434
	} else if (autoneg == AUTONEG_ENABLE)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1435
		RTL_W32(TBICSR, reg | TBINwEnable | TBINwRestart);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1436
	else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1437
		netif_warn(tp, link, dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1438
			   "incorrect speed setting refused in TBI mode\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1439
		ret = -EOPNOTSUPP;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1440
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1441
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1442
	return ret;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1443
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1444
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1445
static int rtl8169_set_speed_xmii(struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1446
				  u8 autoneg, u16 speed, u8 duplex, u32 adv)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1447
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1448
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1449
	int giga_ctrl, bmcr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1450
	int rc = -EINVAL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1451
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1452
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1453
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1454
	if (autoneg == AUTONEG_ENABLE) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1455
		int auto_nego;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1456
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1457
		auto_nego = rtl_readphy(tp, MII_ADVERTISE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1458
		auto_nego &= ~(ADVERTISE_10HALF | ADVERTISE_10FULL |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1459
				ADVERTISE_100HALF | ADVERTISE_100FULL);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1460
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1461
		if (adv & ADVERTISED_10baseT_Half)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1462
			auto_nego |= ADVERTISE_10HALF;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1463
		if (adv & ADVERTISED_10baseT_Full)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1464
			auto_nego |= ADVERTISE_10FULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1465
		if (adv & ADVERTISED_100baseT_Half)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1466
			auto_nego |= ADVERTISE_100HALF;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1467
		if (adv & ADVERTISED_100baseT_Full)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1468
			auto_nego |= ADVERTISE_100FULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1469
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1470
		auto_nego |= ADVERTISE_PAUSE_CAP | ADVERTISE_PAUSE_ASYM;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1471
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1472
		giga_ctrl = rtl_readphy(tp, MII_CTRL1000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1473
		giga_ctrl &= ~(ADVERTISE_1000FULL | ADVERTISE_1000HALF);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1474
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1475
		/* The 8100e/8101e/8102e do Fast Ethernet only. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1476
		if (tp->mii.supports_gmii) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1477
			if (adv & ADVERTISED_1000baseT_Half)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1478
				giga_ctrl |= ADVERTISE_1000HALF;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1479
			if (adv & ADVERTISED_1000baseT_Full)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1480
				giga_ctrl |= ADVERTISE_1000FULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1481
		} else if (adv & (ADVERTISED_1000baseT_Half |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1482
				  ADVERTISED_1000baseT_Full)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1483
			netif_info(tp, link, dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1484
				   "PHY does not support 1000Mbps\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1485
			goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1486
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1487
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1488
		bmcr = BMCR_ANENABLE | BMCR_ANRESTART;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1489
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1490
		rtl_writephy(tp, MII_ADVERTISE, auto_nego);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1491
		rtl_writephy(tp, MII_CTRL1000, giga_ctrl);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1492
	} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1493
		giga_ctrl = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1494
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1495
		if (speed == SPEED_10)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1496
			bmcr = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1497
		else if (speed == SPEED_100)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1498
			bmcr = BMCR_SPEED100;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1499
		else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1500
			goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1501
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1502
		if (duplex == DUPLEX_FULL)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1503
			bmcr |= BMCR_FULLDPLX;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1504
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1505
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1506
	rtl_writephy(tp, MII_BMCR, bmcr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1507
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1508
	if (tp->mac_version == RTL_GIGA_MAC_VER_02 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1509
	    tp->mac_version == RTL_GIGA_MAC_VER_03) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1510
		if ((speed == SPEED_100) && (autoneg != AUTONEG_ENABLE)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1511
			rtl_writephy(tp, 0x17, 0x2138);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1512
			rtl_writephy(tp, 0x0e, 0x0260);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1513
		} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1514
			rtl_writephy(tp, 0x17, 0x2108);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1515
			rtl_writephy(tp, 0x0e, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1516
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1517
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1518
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1519
	rc = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1520
out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1521
	return rc;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1522
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1523
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1524
static int rtl8169_set_speed(struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1525
			     u8 autoneg, u16 speed, u8 duplex, u32 advertising)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1526
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1527
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1528
	int ret;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1529
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1530
	ret = tp->set_speed(dev, autoneg, speed, duplex, advertising);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1531
	if (ret < 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1532
		goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1533
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1534
	if (netif_running(dev) && (autoneg == AUTONEG_ENABLE) &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1535
	    (advertising & ADVERTISED_1000baseT_Full)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1536
		mod_timer(&tp->timer, jiffies + RTL8169_PHY_TIMEOUT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1537
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1538
out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1539
	return ret;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1540
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1541
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1542
static int rtl8169_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1543
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1544
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1545
	unsigned long flags;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1546
	int ret;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1547
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1548
	del_timer_sync(&tp->timer);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1549
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1550
	spin_lock_irqsave(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1551
	ret = rtl8169_set_speed(dev, cmd->autoneg, ethtool_cmd_speed(cmd),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1552
				cmd->duplex, cmd->advertising);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1553
	spin_unlock_irqrestore(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1554
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1555
	return ret;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1556
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1557
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1558
static u32 rtl8169_fix_features(struct net_device *dev, u32 features)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1559
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1560
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1561
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1562
	if (dev->mtu > TD_MSS_MAX)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1563
		features &= ~NETIF_F_ALL_TSO;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1564
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1565
	if (dev->mtu > JUMBO_1K &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1566
	    !rtl_chip_infos[tp->mac_version].jumbo_tx_csum)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1567
		features &= ~NETIF_F_IP_CSUM;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1568
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1569
	return features;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1570
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1571
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1572
static int rtl8169_set_features(struct net_device *dev, u32 features)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1573
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1574
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1575
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1576
	unsigned long flags;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1577
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1578
	spin_lock_irqsave(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1579
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1580
	if (features & NETIF_F_RXCSUM)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1581
		tp->cp_cmd |= RxChkSum;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1582
	else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1583
		tp->cp_cmd &= ~RxChkSum;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1584
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1585
	if (dev->features & NETIF_F_HW_VLAN_RX)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1586
		tp->cp_cmd |= RxVlan;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1587
	else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1588
		tp->cp_cmd &= ~RxVlan;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1589
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1590
	RTL_W16(CPlusCmd, tp->cp_cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1591
	RTL_R16(CPlusCmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1592
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1593
	spin_unlock_irqrestore(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1594
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1595
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1596
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1597
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1598
static inline u32 rtl8169_tx_vlan_tag(struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1599
				      struct sk_buff *skb)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1600
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1601
	return (vlan_tx_tag_present(skb)) ?
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1602
		TxVlanTag | swab16(vlan_tx_tag_get(skb)) : 0x00;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1603
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1604
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1605
static void rtl8169_rx_vlan_tag(struct RxDesc *desc, struct sk_buff *skb)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1606
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1607
	u32 opts2 = le32_to_cpu(desc->opts2);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1608
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1609
	if (opts2 & RxVlanTag)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1610
		__vlan_hwaccel_put_tag(skb, swab16(opts2 & 0xffff));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1611
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1612
	desc->opts2 = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1613
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1614
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1615
static int rtl8169_gset_tbi(struct net_device *dev, struct ethtool_cmd *cmd)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1616
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1617
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1618
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1619
	u32 status;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1620
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1621
	cmd->supported =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1622
		SUPPORTED_1000baseT_Full | SUPPORTED_Autoneg | SUPPORTED_FIBRE;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1623
	cmd->port = PORT_FIBRE;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1624
	cmd->transceiver = XCVR_INTERNAL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1625
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1626
	status = RTL_R32(TBICSR);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1627
	cmd->advertising = (status & TBINwEnable) ?  ADVERTISED_Autoneg : 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1628
	cmd->autoneg = !!(status & TBINwEnable);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1629
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1630
	ethtool_cmd_speed_set(cmd, SPEED_1000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1631
	cmd->duplex = DUPLEX_FULL; /* Always set */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1632
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1633
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1634
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1635
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1636
static int rtl8169_gset_xmii(struct net_device *dev, struct ethtool_cmd *cmd)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1637
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1638
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1639
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1640
	return mii_ethtool_gset(&tp->mii, cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1641
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1642
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1643
static int rtl8169_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1644
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1645
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1646
	unsigned long flags;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1647
	int rc;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1648
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1649
	spin_lock_irqsave(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1650
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1651
	rc = tp->get_settings(dev, cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1652
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1653
	spin_unlock_irqrestore(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1654
	return rc;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1655
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1656
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1657
static void rtl8169_get_regs(struct net_device *dev, struct ethtool_regs *regs,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1658
			     void *p)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1659
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1660
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1661
	unsigned long flags;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1662
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1663
	if (regs->len > R8169_REGS_SIZE)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1664
		regs->len = R8169_REGS_SIZE;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1665
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1666
	spin_lock_irqsave(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1667
	memcpy_fromio(p, tp->mmio_addr, regs->len);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1668
	spin_unlock_irqrestore(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1669
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1670
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1671
static u32 rtl8169_get_msglevel(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1672
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1673
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1674
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1675
	return tp->msg_enable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1676
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1677
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1678
static void rtl8169_set_msglevel(struct net_device *dev, u32 value)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1679
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1680
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1681
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1682
	tp->msg_enable = value;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1683
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1684
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1685
static const char rtl8169_gstrings[][ETH_GSTRING_LEN] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1686
	"tx_packets",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1687
	"rx_packets",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1688
	"tx_errors",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1689
	"rx_errors",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1690
	"rx_missed",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1691
	"align_errors",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1692
	"tx_single_collisions",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1693
	"tx_multi_collisions",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1694
	"unicast",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1695
	"broadcast",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1696
	"multicast",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1697
	"tx_aborted",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1698
	"tx_underrun",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1699
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1700
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1701
static int rtl8169_get_sset_count(struct net_device *dev, int sset)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1702
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1703
	switch (sset) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1704
	case ETH_SS_STATS:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1705
		return ARRAY_SIZE(rtl8169_gstrings);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1706
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1707
		return -EOPNOTSUPP;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1708
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1709
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1710
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1711
static void rtl8169_update_counters(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1712
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1713
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1714
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1715
	struct device *d = &tp->pci_dev->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1716
	struct rtl8169_counters *counters;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1717
	dma_addr_t paddr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1718
	u32 cmd;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1719
	int wait = 1000;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1720
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1721
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1722
	 * Some chips are unable to dump tally counters when the receiver
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1723
	 * is disabled.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1724
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1725
	if ((RTL_R8(ChipCmd) & CmdRxEnb) == 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1726
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1727
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1728
	counters = dma_alloc_coherent(d, sizeof(*counters), &paddr, GFP_KERNEL);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1729
	if (!counters)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1730
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1731
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1732
	RTL_W32(CounterAddrHigh, (u64)paddr >> 32);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1733
	cmd = (u64)paddr & DMA_BIT_MASK(32);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1734
	RTL_W32(CounterAddrLow, cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1735
	RTL_W32(CounterAddrLow, cmd | CounterDump);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1736
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1737
	while (wait--) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1738
		if ((RTL_R32(CounterAddrLow) & CounterDump) == 0) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1739
			memcpy(&tp->counters, counters, sizeof(*counters));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1740
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1741
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1742
		udelay(10);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1743
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1744
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1745
	RTL_W32(CounterAddrLow, 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1746
	RTL_W32(CounterAddrHigh, 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1747
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1748
	dma_free_coherent(d, sizeof(*counters), counters, paddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1749
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1750
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1751
static void rtl8169_get_ethtool_stats(struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1752
				      struct ethtool_stats *stats, u64 *data)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1753
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1754
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1755
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1756
	ASSERT_RTNL();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1757
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1758
	rtl8169_update_counters(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1759
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1760
	data[0] = le64_to_cpu(tp->counters.tx_packets);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1761
	data[1] = le64_to_cpu(tp->counters.rx_packets);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1762
	data[2] = le64_to_cpu(tp->counters.tx_errors);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1763
	data[3] = le32_to_cpu(tp->counters.rx_errors);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1764
	data[4] = le16_to_cpu(tp->counters.rx_missed);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1765
	data[5] = le16_to_cpu(tp->counters.align_errors);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1766
	data[6] = le32_to_cpu(tp->counters.tx_one_collision);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1767
	data[7] = le32_to_cpu(tp->counters.tx_multi_collision);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1768
	data[8] = le64_to_cpu(tp->counters.rx_unicast);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1769
	data[9] = le64_to_cpu(tp->counters.rx_broadcast);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1770
	data[10] = le32_to_cpu(tp->counters.rx_multicast);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1771
	data[11] = le16_to_cpu(tp->counters.tx_aborted);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1772
	data[12] = le16_to_cpu(tp->counters.tx_underun);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1773
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1774
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1775
static void rtl8169_get_strings(struct net_device *dev, u32 stringset, u8 *data)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1776
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1777
	switch(stringset) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1778
	case ETH_SS_STATS:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1779
		memcpy(data, *rtl8169_gstrings, sizeof(rtl8169_gstrings));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1780
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1781
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1782
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1783
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1784
static const struct ethtool_ops rtl8169_ethtool_ops = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1785
	.get_drvinfo		= rtl8169_get_drvinfo,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1786
	.get_regs_len		= rtl8169_get_regs_len,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1787
	.get_link		= ethtool_op_get_link,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1788
	.get_settings		= rtl8169_get_settings,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1789
	.set_settings		= rtl8169_set_settings,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1790
	.get_msglevel		= rtl8169_get_msglevel,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1791
	.set_msglevel		= rtl8169_set_msglevel,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1792
	.get_regs		= rtl8169_get_regs,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1793
	.get_wol		= rtl8169_get_wol,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1794
	.set_wol		= rtl8169_set_wol,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1795
	.get_strings		= rtl8169_get_strings,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1796
	.get_sset_count		= rtl8169_get_sset_count,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1797
	.get_ethtool_stats	= rtl8169_get_ethtool_stats,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1798
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1799
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1800
static void rtl8169_get_mac_version(struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1801
				    struct net_device *dev, u8 default_version)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1802
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1803
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1804
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1805
	 * The driver currently handles the 8168Bf and the 8168Be identically
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1806
	 * but they can be identified more specifically through the test below
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1807
	 * if needed:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1808
	 *
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1809
	 * (RTL_R32(TxConfig) & 0x700000) == 0x500000 ? 8168Bf : 8168Be
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1810
	 *
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1811
	 * Same thing for the 8101Eb and the 8101Ec:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1812
	 *
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1813
	 * (RTL_R32(TxConfig) & 0x700000) == 0x200000 ? 8101Eb : 8101Ec
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1814
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1815
	static const struct rtl_mac_info {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1816
		u32 mask;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1817
		u32 val;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1818
		int mac_version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1819
	} mac_info[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1820
		/* 8168F family. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1821
		{ 0x7cf00000, 0x48100000,	RTL_GIGA_MAC_VER_36 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1822
		{ 0x7cf00000, 0x48000000,	RTL_GIGA_MAC_VER_35 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1823
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1824
		/* 8168E family. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1825
		{ 0x7c800000, 0x2c800000,	RTL_GIGA_MAC_VER_34 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1826
		{ 0x7cf00000, 0x2c200000,	RTL_GIGA_MAC_VER_33 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1827
		{ 0x7cf00000, 0x2c100000,	RTL_GIGA_MAC_VER_32 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1828
		{ 0x7c800000, 0x2c000000,	RTL_GIGA_MAC_VER_33 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1829
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1830
		/* 8168D family. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1831
		{ 0x7cf00000, 0x28300000,	RTL_GIGA_MAC_VER_26 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1832
		{ 0x7cf00000, 0x28100000,	RTL_GIGA_MAC_VER_25 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1833
		{ 0x7c800000, 0x28000000,	RTL_GIGA_MAC_VER_26 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1834
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1835
		/* 8168DP family. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1836
		{ 0x7cf00000, 0x28800000,	RTL_GIGA_MAC_VER_27 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1837
		{ 0x7cf00000, 0x28a00000,	RTL_GIGA_MAC_VER_28 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1838
		{ 0x7cf00000, 0x28b00000,	RTL_GIGA_MAC_VER_31 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1839
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1840
		/* 8168C family. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1841
		{ 0x7cf00000, 0x3cb00000,	RTL_GIGA_MAC_VER_24 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1842
		{ 0x7cf00000, 0x3c900000,	RTL_GIGA_MAC_VER_23 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1843
		{ 0x7cf00000, 0x3c800000,	RTL_GIGA_MAC_VER_18 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1844
		{ 0x7c800000, 0x3c800000,	RTL_GIGA_MAC_VER_24 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1845
		{ 0x7cf00000, 0x3c000000,	RTL_GIGA_MAC_VER_19 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1846
		{ 0x7cf00000, 0x3c200000,	RTL_GIGA_MAC_VER_20 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1847
		{ 0x7cf00000, 0x3c300000,	RTL_GIGA_MAC_VER_21 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1848
		{ 0x7cf00000, 0x3c400000,	RTL_GIGA_MAC_VER_22 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1849
		{ 0x7c800000, 0x3c000000,	RTL_GIGA_MAC_VER_22 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1850
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1851
		/* 8168B family. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1852
		{ 0x7cf00000, 0x38000000,	RTL_GIGA_MAC_VER_12 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1853
		{ 0x7cf00000, 0x38500000,	RTL_GIGA_MAC_VER_17 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1854
		{ 0x7c800000, 0x38000000,	RTL_GIGA_MAC_VER_17 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1855
		{ 0x7c800000, 0x30000000,	RTL_GIGA_MAC_VER_11 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1856
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1857
		/* 8101 family. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1858
		{ 0x7cf00000, 0x40b00000,	RTL_GIGA_MAC_VER_30 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1859
		{ 0x7cf00000, 0x40a00000,	RTL_GIGA_MAC_VER_30 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1860
		{ 0x7cf00000, 0x40900000,	RTL_GIGA_MAC_VER_29 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1861
		{ 0x7c800000, 0x40800000,	RTL_GIGA_MAC_VER_30 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1862
		{ 0x7cf00000, 0x34a00000,	RTL_GIGA_MAC_VER_09 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1863
		{ 0x7cf00000, 0x24a00000,	RTL_GIGA_MAC_VER_09 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1864
		{ 0x7cf00000, 0x34900000,	RTL_GIGA_MAC_VER_08 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1865
		{ 0x7cf00000, 0x24900000,	RTL_GIGA_MAC_VER_08 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1866
		{ 0x7cf00000, 0x34800000,	RTL_GIGA_MAC_VER_07 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1867
		{ 0x7cf00000, 0x24800000,	RTL_GIGA_MAC_VER_07 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1868
		{ 0x7cf00000, 0x34000000,	RTL_GIGA_MAC_VER_13 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1869
		{ 0x7cf00000, 0x34300000,	RTL_GIGA_MAC_VER_10 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1870
		{ 0x7cf00000, 0x34200000,	RTL_GIGA_MAC_VER_16 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1871
		{ 0x7c800000, 0x34800000,	RTL_GIGA_MAC_VER_09 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1872
		{ 0x7c800000, 0x24800000,	RTL_GIGA_MAC_VER_09 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1873
		{ 0x7c800000, 0x34000000,	RTL_GIGA_MAC_VER_16 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1874
		/* FIXME: where did these entries come from ? -- FR */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1875
		{ 0xfc800000, 0x38800000,	RTL_GIGA_MAC_VER_15 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1876
		{ 0xfc800000, 0x30800000,	RTL_GIGA_MAC_VER_14 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1877
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1878
		/* 8110 family. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1879
		{ 0xfc800000, 0x98000000,	RTL_GIGA_MAC_VER_06 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1880
		{ 0xfc800000, 0x18000000,	RTL_GIGA_MAC_VER_05 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1881
		{ 0xfc800000, 0x10000000,	RTL_GIGA_MAC_VER_04 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1882
		{ 0xfc800000, 0x04000000,	RTL_GIGA_MAC_VER_03 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1883
		{ 0xfc800000, 0x00800000,	RTL_GIGA_MAC_VER_02 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1884
		{ 0xfc800000, 0x00000000,	RTL_GIGA_MAC_VER_01 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1885
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1886
		/* Catch-all */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1887
		{ 0x00000000, 0x00000000,	RTL_GIGA_MAC_NONE   }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1888
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1889
	const struct rtl_mac_info *p = mac_info;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1890
	u32 reg;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1891
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1892
	reg = RTL_R32(TxConfig);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1893
	while ((reg & p->mask) != p->val)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1894
		p++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1895
	tp->mac_version = p->mac_version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1896
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1897
	if (tp->mac_version == RTL_GIGA_MAC_NONE) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1898
		netif_notice(tp, probe, dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1899
			     "unknown MAC, using family default\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1900
		tp->mac_version = default_version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1901
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1902
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1903
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1904
static void rtl8169_print_mac_version(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1905
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1906
	dprintk("mac_version = 0x%02x\n", tp->mac_version);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1907
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1908
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1909
struct phy_reg {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1910
	u16 reg;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1911
	u16 val;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1912
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1913
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1914
static void rtl_writephy_batch(struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1915
			       const struct phy_reg *regs, int len)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1916
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1917
	while (len-- > 0) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1918
		rtl_writephy(tp, regs->reg, regs->val);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1919
		regs++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1920
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1921
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1922
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1923
#define PHY_READ		0x00000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1924
#define PHY_DATA_OR		0x10000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1925
#define PHY_DATA_AND		0x20000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1926
#define PHY_BJMPN		0x30000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1927
#define PHY_READ_EFUSE		0x40000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1928
#define PHY_READ_MAC_BYTE	0x50000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1929
#define PHY_WRITE_MAC_BYTE	0x60000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1930
#define PHY_CLEAR_READCOUNT	0x70000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1931
#define PHY_WRITE		0x80000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1932
#define PHY_READCOUNT_EQ_SKIP	0x90000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1933
#define PHY_COMP_EQ_SKIPN	0xa0000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1934
#define PHY_COMP_NEQ_SKIPN	0xb0000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1935
#define PHY_WRITE_PREVIOUS	0xc0000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1936
#define PHY_SKIPN		0xd0000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1937
#define PHY_DELAY_MS		0xe0000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1938
#define PHY_WRITE_ERI_WORD	0xf0000000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1939
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1940
struct fw_info {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1941
	u32	magic;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1942
	char	version[RTL_VER_SIZE];
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1943
	__le32	fw_start;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1944
	__le32	fw_len;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1945
	u8	chksum;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1946
} __packed;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1947
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1948
#define FW_OPCODE_SIZE	sizeof(typeof(*((struct rtl_fw_phy_action *)0)->code))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1949
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1950
static bool rtl_fw_format_ok(struct rtl8169_private *tp, struct rtl_fw *rtl_fw)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1951
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1952
	const struct firmware *fw = rtl_fw->fw;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1953
	struct fw_info *fw_info = (struct fw_info *)fw->data;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1954
	struct rtl_fw_phy_action *pa = &rtl_fw->phy_action;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1955
	char *version = rtl_fw->version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1956
	bool rc = false;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1957
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1958
	if (fw->size < FW_OPCODE_SIZE)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1959
		goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1960
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1961
	if (!fw_info->magic) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1962
		size_t i, size, start;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1963
		u8 checksum = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1964
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1965
		if (fw->size < sizeof(*fw_info))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1966
			goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1967
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1968
		for (i = 0; i < fw->size; i++)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1969
			checksum += fw->data[i];
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1970
		if (checksum != 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1971
			goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1972
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1973
		start = le32_to_cpu(fw_info->fw_start);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1974
		if (start > fw->size)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1975
			goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1976
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1977
		size = le32_to_cpu(fw_info->fw_len);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1978
		if (size > (fw->size - start) / FW_OPCODE_SIZE)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1979
			goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1980
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1981
		memcpy(version, fw_info->version, RTL_VER_SIZE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1982
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1983
		pa->code = (__le32 *)(fw->data + start);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1984
		pa->size = size;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1985
	} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1986
		if (fw->size % FW_OPCODE_SIZE)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1987
			goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1988
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1989
		strlcpy(version, rtl_lookup_firmware_name(tp), RTL_VER_SIZE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1990
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1991
		pa->code = (__le32 *)fw->data;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1992
		pa->size = fw->size / FW_OPCODE_SIZE;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1993
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1994
	version[RTL_VER_SIZE - 1] = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1995
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1996
	rc = true;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1997
out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1998
	return rc;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1999
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2000
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2001
static bool rtl_fw_data_ok(struct rtl8169_private *tp, struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2002
			   struct rtl_fw_phy_action *pa)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2003
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2004
	bool rc = false;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2005
	size_t index;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2006
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2007
	for (index = 0; index < pa->size; index++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2008
		u32 action = le32_to_cpu(pa->code[index]);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2009
		u32 regno = (action & 0x0fff0000) >> 16;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2010
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2011
		switch(action & 0xf0000000) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2012
		case PHY_READ:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2013
		case PHY_DATA_OR:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2014
		case PHY_DATA_AND:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2015
		case PHY_READ_EFUSE:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2016
		case PHY_CLEAR_READCOUNT:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2017
		case PHY_WRITE:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2018
		case PHY_WRITE_PREVIOUS:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2019
		case PHY_DELAY_MS:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2020
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2021
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2022
		case PHY_BJMPN:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2023
			if (regno > index) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2024
				netif_err(tp, ifup, tp->dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2025
					  "Out of range of firmware\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2026
				goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2027
			}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2028
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2029
		case PHY_READCOUNT_EQ_SKIP:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2030
			if (index + 2 >= pa->size) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2031
				netif_err(tp, ifup, tp->dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2032
					  "Out of range of firmware\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2033
				goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2034
			}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2035
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2036
		case PHY_COMP_EQ_SKIPN:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2037
		case PHY_COMP_NEQ_SKIPN:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2038
		case PHY_SKIPN:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2039
			if (index + 1 + regno >= pa->size) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2040
				netif_err(tp, ifup, tp->dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2041
					  "Out of range of firmware\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2042
				goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2043
			}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2044
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2045
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2046
		case PHY_READ_MAC_BYTE:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2047
		case PHY_WRITE_MAC_BYTE:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2048
		case PHY_WRITE_ERI_WORD:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2049
		default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2050
			netif_err(tp, ifup, tp->dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2051
				  "Invalid action 0x%08x\n", action);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2052
			goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2053
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2054
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2055
	rc = true;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2056
out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2057
	return rc;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2058
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2059
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2060
static int rtl_check_firmware(struct rtl8169_private *tp, struct rtl_fw *rtl_fw)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2061
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2062
	struct net_device *dev = tp->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2063
	int rc = -EINVAL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2064
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2065
	if (!rtl_fw_format_ok(tp, rtl_fw)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2066
		netif_err(tp, ifup, dev, "invalid firwmare\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2067
		goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2068
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2069
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2070
	if (rtl_fw_data_ok(tp, dev, &rtl_fw->phy_action))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2071
		rc = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2072
out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2073
	return rc;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2074
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2075
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2076
static void rtl_phy_write_fw(struct rtl8169_private *tp, struct rtl_fw *rtl_fw)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2077
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2078
	struct rtl_fw_phy_action *pa = &rtl_fw->phy_action;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2079
	u32 predata, count;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2080
	size_t index;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2081
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2082
	predata = count = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2083
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2084
	for (index = 0; index < pa->size; ) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2085
		u32 action = le32_to_cpu(pa->code[index]);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2086
		u32 data = action & 0x0000ffff;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2087
		u32 regno = (action & 0x0fff0000) >> 16;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2088
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2089
		if (!action)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2090
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2091
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2092
		switch(action & 0xf0000000) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2093
		case PHY_READ:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2094
			predata = rtl_readphy(tp, regno);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2095
			count++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2096
			index++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2097
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2098
		case PHY_DATA_OR:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2099
			predata |= data;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2100
			index++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2101
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2102
		case PHY_DATA_AND:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2103
			predata &= data;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2104
			index++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2105
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2106
		case PHY_BJMPN:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2107
			index -= regno;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2108
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2109
		case PHY_READ_EFUSE:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2110
			predata = rtl8168d_efuse_read(tp->mmio_addr, regno);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2111
			index++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2112
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2113
		case PHY_CLEAR_READCOUNT:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2114
			count = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2115
			index++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2116
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2117
		case PHY_WRITE:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2118
			rtl_writephy(tp, regno, data);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2119
			index++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2120
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2121
		case PHY_READCOUNT_EQ_SKIP:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2122
			index += (count == data) ? 2 : 1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2123
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2124
		case PHY_COMP_EQ_SKIPN:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2125
			if (predata == data)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2126
				index += regno;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2127
			index++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2128
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2129
		case PHY_COMP_NEQ_SKIPN:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2130
			if (predata != data)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2131
				index += regno;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2132
			index++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2133
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2134
		case PHY_WRITE_PREVIOUS:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2135
			rtl_writephy(tp, regno, predata);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2136
			index++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2137
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2138
		case PHY_SKIPN:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2139
			index += regno + 1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2140
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2141
		case PHY_DELAY_MS:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2142
			mdelay(data);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2143
			index++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2144
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2145
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2146
		case PHY_READ_MAC_BYTE:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2147
		case PHY_WRITE_MAC_BYTE:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2148
		case PHY_WRITE_ERI_WORD:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2149
		default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2150
			BUG();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2151
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2152
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2153
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2154
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2155
static void rtl_release_firmware(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2156
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2157
	if (!IS_ERR_OR_NULL(tp->rtl_fw)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2158
		release_firmware(tp->rtl_fw->fw);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2159
		kfree(tp->rtl_fw);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2160
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2161
	tp->rtl_fw = RTL_FIRMWARE_UNKNOWN;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2162
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2163
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2164
static void rtl_apply_firmware(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2165
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2166
	struct rtl_fw *rtl_fw = tp->rtl_fw;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2167
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2168
	/* TODO: release firmware once rtl_phy_write_fw signals failures. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2169
	if (!IS_ERR_OR_NULL(rtl_fw))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2170
		rtl_phy_write_fw(tp, rtl_fw);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2171
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2172
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2173
static void rtl_apply_firmware_cond(struct rtl8169_private *tp, u8 reg, u16 val)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2174
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2175
	if (rtl_readphy(tp, reg) != val)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2176
		netif_warn(tp, hw, tp->dev, "chipset not ready for firmware\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2177
	else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2178
		rtl_apply_firmware(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2179
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2180
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2181
static void rtl8169s_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2182
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2183
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2184
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2185
		{ 0x06, 0x006e },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2186
		{ 0x08, 0x0708 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2187
		{ 0x15, 0x4000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2188
		{ 0x18, 0x65c7 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2189
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2190
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2191
		{ 0x03, 0x00a1 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2192
		{ 0x02, 0x0008 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2193
		{ 0x01, 0x0120 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2194
		{ 0x00, 0x1000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2195
		{ 0x04, 0x0800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2196
		{ 0x04, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2197
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2198
		{ 0x03, 0xff41 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2199
		{ 0x02, 0xdf60 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2200
		{ 0x01, 0x0140 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2201
		{ 0x00, 0x0077 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2202
		{ 0x04, 0x7800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2203
		{ 0x04, 0x7000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2204
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2205
		{ 0x03, 0x802f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2206
		{ 0x02, 0x4f02 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2207
		{ 0x01, 0x0409 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2208
		{ 0x00, 0xf0f9 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2209
		{ 0x04, 0x9800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2210
		{ 0x04, 0x9000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2211
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2212
		{ 0x03, 0xdf01 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2213
		{ 0x02, 0xdf20 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2214
		{ 0x01, 0xff95 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2215
		{ 0x00, 0xba00 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2216
		{ 0x04, 0xa800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2217
		{ 0x04, 0xa000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2218
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2219
		{ 0x03, 0xff41 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2220
		{ 0x02, 0xdf20 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2221
		{ 0x01, 0x0140 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2222
		{ 0x00, 0x00bb },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2223
		{ 0x04, 0xb800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2224
		{ 0x04, 0xb000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2225
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2226
		{ 0x03, 0xdf41 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2227
		{ 0x02, 0xdc60 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2228
		{ 0x01, 0x6340 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2229
		{ 0x00, 0x007d },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2230
		{ 0x04, 0xd800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2231
		{ 0x04, 0xd000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2232
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2233
		{ 0x03, 0xdf01 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2234
		{ 0x02, 0xdf20 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2235
		{ 0x01, 0x100a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2236
		{ 0x00, 0xa0ff },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2237
		{ 0x04, 0xf800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2238
		{ 0x04, 0xf000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2239
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2240
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2241
		{ 0x0b, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2242
		{ 0x00, 0x9200 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2243
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2244
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2245
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2246
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2247
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2248
static void rtl8169sb_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2249
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2250
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2251
		{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2252
		{ 0x01, 0x90d0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2253
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2254
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2255
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2256
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2257
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2258
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2259
static void rtl8169scd_hw_phy_config_quirk(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2260
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2261
	struct pci_dev *pdev = tp->pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2262
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2263
	if ((pdev->subsystem_vendor != PCI_VENDOR_ID_GIGABYTE) ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2264
	    (pdev->subsystem_device != 0xe000))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2265
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2266
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2267
	rtl_writephy(tp, 0x1f, 0x0001);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2268
	rtl_writephy(tp, 0x10, 0xf01b);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2269
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2270
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2271
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2272
static void rtl8169scd_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2273
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2274
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2275
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2276
		{ 0x04, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2277
		{ 0x03, 0x00a1 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2278
		{ 0x02, 0x0008 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2279
		{ 0x01, 0x0120 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2280
		{ 0x00, 0x1000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2281
		{ 0x04, 0x0800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2282
		{ 0x04, 0x9000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2283
		{ 0x03, 0x802f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2284
		{ 0x02, 0x4f02 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2285
		{ 0x01, 0x0409 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2286
		{ 0x00, 0xf099 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2287
		{ 0x04, 0x9800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2288
		{ 0x04, 0xa000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2289
		{ 0x03, 0xdf01 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2290
		{ 0x02, 0xdf20 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2291
		{ 0x01, 0xff95 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2292
		{ 0x00, 0xba00 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2293
		{ 0x04, 0xa800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2294
		{ 0x04, 0xf000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2295
		{ 0x03, 0xdf01 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2296
		{ 0x02, 0xdf20 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2297
		{ 0x01, 0x101a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2298
		{ 0x00, 0xa0ff },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2299
		{ 0x04, 0xf800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2300
		{ 0x04, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2301
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2302
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2303
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2304
		{ 0x10, 0xf41b },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2305
		{ 0x14, 0xfb54 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2306
		{ 0x18, 0xf5c7 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2307
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2308
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2309
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2310
		{ 0x17, 0x0cc0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2311
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2312
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2313
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2314
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2315
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2316
	rtl8169scd_hw_phy_config_quirk(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2317
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2318
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2319
static void rtl8169sce_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2320
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2321
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2322
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2323
		{ 0x04, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2324
		{ 0x03, 0x00a1 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2325
		{ 0x02, 0x0008 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2326
		{ 0x01, 0x0120 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2327
		{ 0x00, 0x1000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2328
		{ 0x04, 0x0800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2329
		{ 0x04, 0x9000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2330
		{ 0x03, 0x802f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2331
		{ 0x02, 0x4f02 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2332
		{ 0x01, 0x0409 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2333
		{ 0x00, 0xf099 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2334
		{ 0x04, 0x9800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2335
		{ 0x04, 0xa000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2336
		{ 0x03, 0xdf01 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2337
		{ 0x02, 0xdf20 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2338
		{ 0x01, 0xff95 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2339
		{ 0x00, 0xba00 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2340
		{ 0x04, 0xa800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2341
		{ 0x04, 0xf000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2342
		{ 0x03, 0xdf01 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2343
		{ 0x02, 0xdf20 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2344
		{ 0x01, 0x101a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2345
		{ 0x00, 0xa0ff },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2346
		{ 0x04, 0xf800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2347
		{ 0x04, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2348
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2349
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2350
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2351
		{ 0x0b, 0x8480 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2352
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2353
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2354
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2355
		{ 0x18, 0x67c7 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2356
		{ 0x04, 0x2000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2357
		{ 0x03, 0x002f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2358
		{ 0x02, 0x4360 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2359
		{ 0x01, 0x0109 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2360
		{ 0x00, 0x3022 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2361
		{ 0x04, 0x2800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2362
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2363
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2364
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2365
		{ 0x17, 0x0cc0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2366
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2367
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2368
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2369
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2370
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2371
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2372
static void rtl8168bb_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2373
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2374
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2375
		{ 0x10, 0xf41b },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2376
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2377
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2378
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2379
	rtl_writephy(tp, 0x1f, 0x0001);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2380
	rtl_patchphy(tp, 0x16, 1 << 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2381
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2382
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2383
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2384
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2385
static void rtl8168bef_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2386
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2387
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2388
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2389
		{ 0x10, 0xf41b },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2390
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2391
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2392
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2393
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2394
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2395
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2396
static void rtl8168cp_1_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2397
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2398
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2399
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2400
		{ 0x1d, 0x0f00 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2401
		{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2402
		{ 0x0c, 0x1ec8 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2403
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2404
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2405
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2406
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2407
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2408
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2409
static void rtl8168cp_2_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2410
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2411
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2412
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2413
		{ 0x1d, 0x3d98 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2414
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2415
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2416
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2417
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2418
	rtl_patchphy(tp, 0x14, 1 << 5);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2419
	rtl_patchphy(tp, 0x0d, 1 << 5);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2420
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2421
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2422
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2423
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2424
static void rtl8168c_1_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2425
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2426
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2427
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2428
		{ 0x12, 0x2300 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2429
		{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2430
		{ 0x00, 0x88d4 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2431
		{ 0x01, 0x82b1 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2432
		{ 0x03, 0x7002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2433
		{ 0x08, 0x9e30 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2434
		{ 0x09, 0x01f0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2435
		{ 0x0a, 0x5500 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2436
		{ 0x0c, 0x00c8 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2437
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2438
		{ 0x12, 0xc096 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2439
		{ 0x16, 0x000a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2440
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2441
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2442
		{ 0x09, 0x2000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2443
		{ 0x09, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2444
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2445
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2446
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2447
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2448
	rtl_patchphy(tp, 0x14, 1 << 5);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2449
	rtl_patchphy(tp, 0x0d, 1 << 5);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2450
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2451
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2452
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2453
static void rtl8168c_2_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2454
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2455
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2456
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2457
		{ 0x12, 0x2300 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2458
		{ 0x03, 0x802f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2459
		{ 0x02, 0x4f02 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2460
		{ 0x01, 0x0409 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2461
		{ 0x00, 0xf099 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2462
		{ 0x04, 0x9800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2463
		{ 0x04, 0x9000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2464
		{ 0x1d, 0x3d98 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2465
		{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2466
		{ 0x0c, 0x7eb8 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2467
		{ 0x06, 0x0761 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2468
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2469
		{ 0x16, 0x0f0a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2470
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2471
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2472
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2473
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2474
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2475
	rtl_patchphy(tp, 0x16, 1 << 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2476
	rtl_patchphy(tp, 0x14, 1 << 5);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2477
	rtl_patchphy(tp, 0x0d, 1 << 5);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2478
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2479
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2480
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2481
static void rtl8168c_3_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2482
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2483
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2484
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2485
		{ 0x12, 0x2300 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2486
		{ 0x1d, 0x3d98 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2487
		{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2488
		{ 0x0c, 0x7eb8 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2489
		{ 0x06, 0x5461 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2490
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2491
		{ 0x16, 0x0f0a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2492
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2493
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2494
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2495
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2496
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2497
	rtl_patchphy(tp, 0x16, 1 << 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2498
	rtl_patchphy(tp, 0x14, 1 << 5);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2499
	rtl_patchphy(tp, 0x0d, 1 << 5);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2500
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2501
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2502
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2503
static void rtl8168c_4_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2504
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2505
	rtl8168c_3_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2506
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2507
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2508
static void rtl8168d_1_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2509
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2510
	static const struct phy_reg phy_reg_init_0[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2511
		/* Channel Estimation */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2512
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2513
		{ 0x06, 0x4064 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2514
		{ 0x07, 0x2863 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2515
		{ 0x08, 0x059c },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2516
		{ 0x09, 0x26b4 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2517
		{ 0x0a, 0x6a19 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2518
		{ 0x0b, 0xdcc8 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2519
		{ 0x10, 0xf06d },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2520
		{ 0x14, 0x7f68 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2521
		{ 0x18, 0x7fd9 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2522
		{ 0x1c, 0xf0ff },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2523
		{ 0x1d, 0x3d9c },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2524
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2525
		{ 0x12, 0xf49f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2526
		{ 0x13, 0x070b },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2527
		{ 0x1a, 0x05ad },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2528
		{ 0x14, 0x94c0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2529
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2530
		/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2531
		 * Tx Error Issue
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2532
		 * Enhance line driver power
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2533
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2534
		{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2535
		{ 0x06, 0x5561 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2536
		{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2537
		{ 0x05, 0x8332 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2538
		{ 0x06, 0x5561 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2539
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2540
		/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2541
		 * Can not link to 1Gbps with bad cable
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2542
		 * Decrease SNR threshold form 21.07dB to 19.04dB
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2543
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2544
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2545
		{ 0x17, 0x0cc0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2546
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2547
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2548
		{ 0x0d, 0xf880 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2549
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2550
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2551
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2552
	rtl_writephy_batch(tp, phy_reg_init_0, ARRAY_SIZE(phy_reg_init_0));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2553
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2554
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2555
	 * Rx Error Issue
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2556
	 * Fine Tune Switching regulator parameter
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2557
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2558
	rtl_writephy(tp, 0x1f, 0x0002);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2559
	rtl_w1w0_phy(tp, 0x0b, 0x0010, 0x00ef);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2560
	rtl_w1w0_phy(tp, 0x0c, 0xa200, 0x5d00);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2561
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2562
	if (rtl8168d_efuse_read(ioaddr, 0x01) == 0xb1) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2563
		static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2564
			{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2565
			{ 0x05, 0x669a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2566
			{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2567
			{ 0x05, 0x8330 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2568
			{ 0x06, 0x669a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2569
			{ 0x1f, 0x0002 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2570
		};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2571
		int val;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2572
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2573
		rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2574
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2575
		val = rtl_readphy(tp, 0x0d);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2576
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2577
		if ((val & 0x00ff) != 0x006c) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2578
			static const u32 set[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2579
				0x0065, 0x0066, 0x0067, 0x0068,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2580
				0x0069, 0x006a, 0x006b, 0x006c
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2581
			};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2582
			int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2583
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2584
			rtl_writephy(tp, 0x1f, 0x0002);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2585
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2586
			val &= 0xff00;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2587
			for (i = 0; i < ARRAY_SIZE(set); i++)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2588
				rtl_writephy(tp, 0x0d, val | set[i]);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2589
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2590
	} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2591
		static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2592
			{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2593
			{ 0x05, 0x6662 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2594
			{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2595
			{ 0x05, 0x8330 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2596
			{ 0x06, 0x6662 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2597
		};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2598
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2599
		rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2600
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2601
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2602
	/* RSET couple improve */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2603
	rtl_writephy(tp, 0x1f, 0x0002);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2604
	rtl_patchphy(tp, 0x0d, 0x0300);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2605
	rtl_patchphy(tp, 0x0f, 0x0010);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2606
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2607
	/* Fine tune PLL performance */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2608
	rtl_writephy(tp, 0x1f, 0x0002);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2609
	rtl_w1w0_phy(tp, 0x02, 0x0100, 0x0600);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2610
	rtl_w1w0_phy(tp, 0x03, 0x0000, 0xe000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2611
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2612
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2613
	rtl_writephy(tp, 0x05, 0x001b);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2614
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2615
	rtl_apply_firmware_cond(tp, MII_EXPANSION, 0xbf00);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2616
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2617
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2618
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2619
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2620
static void rtl8168d_2_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2621
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2622
	static const struct phy_reg phy_reg_init_0[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2623
		/* Channel Estimation */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2624
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2625
		{ 0x06, 0x4064 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2626
		{ 0x07, 0x2863 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2627
		{ 0x08, 0x059c },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2628
		{ 0x09, 0x26b4 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2629
		{ 0x0a, 0x6a19 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2630
		{ 0x0b, 0xdcc8 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2631
		{ 0x10, 0xf06d },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2632
		{ 0x14, 0x7f68 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2633
		{ 0x18, 0x7fd9 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2634
		{ 0x1c, 0xf0ff },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2635
		{ 0x1d, 0x3d9c },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2636
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2637
		{ 0x12, 0xf49f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2638
		{ 0x13, 0x070b },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2639
		{ 0x1a, 0x05ad },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2640
		{ 0x14, 0x94c0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2641
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2642
		/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2643
		 * Tx Error Issue
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2644
		 * Enhance line driver power
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2645
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2646
		{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2647
		{ 0x06, 0x5561 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2648
		{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2649
		{ 0x05, 0x8332 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2650
		{ 0x06, 0x5561 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2651
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2652
		/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2653
		 * Can not link to 1Gbps with bad cable
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2654
		 * Decrease SNR threshold form 21.07dB to 19.04dB
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2655
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2656
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2657
		{ 0x17, 0x0cc0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2658
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2659
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2660
		{ 0x0d, 0xf880 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2661
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2662
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2663
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2664
	rtl_writephy_batch(tp, phy_reg_init_0, ARRAY_SIZE(phy_reg_init_0));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2665
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2666
	if (rtl8168d_efuse_read(ioaddr, 0x01) == 0xb1) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2667
		static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2668
			{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2669
			{ 0x05, 0x669a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2670
			{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2671
			{ 0x05, 0x8330 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2672
			{ 0x06, 0x669a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2673
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2674
			{ 0x1f, 0x0002 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2675
		};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2676
		int val;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2677
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2678
		rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2679
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2680
		val = rtl_readphy(tp, 0x0d);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2681
		if ((val & 0x00ff) != 0x006c) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2682
			static const u32 set[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2683
				0x0065, 0x0066, 0x0067, 0x0068,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2684
				0x0069, 0x006a, 0x006b, 0x006c
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2685
			};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2686
			int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2687
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2688
			rtl_writephy(tp, 0x1f, 0x0002);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2689
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2690
			val &= 0xff00;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2691
			for (i = 0; i < ARRAY_SIZE(set); i++)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2692
				rtl_writephy(tp, 0x0d, val | set[i]);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2693
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2694
	} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2695
		static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2696
			{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2697
			{ 0x05, 0x2642 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2698
			{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2699
			{ 0x05, 0x8330 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2700
			{ 0x06, 0x2642 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2701
		};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2702
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2703
		rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2704
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2705
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2706
	/* Fine tune PLL performance */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2707
	rtl_writephy(tp, 0x1f, 0x0002);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2708
	rtl_w1w0_phy(tp, 0x02, 0x0100, 0x0600);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2709
	rtl_w1w0_phy(tp, 0x03, 0x0000, 0xe000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2710
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2711
	/* Switching regulator Slew rate */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2712
	rtl_writephy(tp, 0x1f, 0x0002);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2713
	rtl_patchphy(tp, 0x0f, 0x0017);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2714
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2715
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2716
	rtl_writephy(tp, 0x05, 0x001b);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2717
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2718
	rtl_apply_firmware_cond(tp, MII_EXPANSION, 0xb300);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2719
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2720
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2721
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2722
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2723
static void rtl8168d_3_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2724
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2725
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2726
		{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2727
		{ 0x10, 0x0008 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2728
		{ 0x0d, 0x006c },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2729
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2730
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2731
		{ 0x0d, 0xf880 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2732
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2733
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2734
		{ 0x17, 0x0cc0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2735
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2736
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2737
		{ 0x0b, 0xa4d8 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2738
		{ 0x09, 0x281c },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2739
		{ 0x07, 0x2883 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2740
		{ 0x0a, 0x6b35 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2741
		{ 0x1d, 0x3da4 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2742
		{ 0x1c, 0xeffd },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2743
		{ 0x14, 0x7f52 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2744
		{ 0x18, 0x7fc6 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2745
		{ 0x08, 0x0601 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2746
		{ 0x06, 0x4063 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2747
		{ 0x10, 0xf074 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2748
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2749
		{ 0x13, 0x0789 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2750
		{ 0x12, 0xf4bd },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2751
		{ 0x1a, 0x04fd },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2752
		{ 0x14, 0x84b0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2753
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2754
		{ 0x00, 0x9200 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2755
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2756
		{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2757
		{ 0x01, 0x0340 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2758
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2759
		{ 0x04, 0x4000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2760
		{ 0x03, 0x1d21 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2761
		{ 0x02, 0x0c32 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2762
		{ 0x01, 0x0200 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2763
		{ 0x00, 0x5554 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2764
		{ 0x04, 0x4800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2765
		{ 0x04, 0x4000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2766
		{ 0x04, 0xf000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2767
		{ 0x03, 0xdf01 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2768
		{ 0x02, 0xdf20 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2769
		{ 0x01, 0x101a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2770
		{ 0x00, 0xa0ff },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2771
		{ 0x04, 0xf800 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2772
		{ 0x04, 0xf000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2773
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2774
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2775
		{ 0x1f, 0x0007 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2776
		{ 0x1e, 0x0023 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2777
		{ 0x16, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2778
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2779
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2780
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2781
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2782
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2783
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2784
static void rtl8168d_4_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2785
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2786
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2787
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2788
		{ 0x17, 0x0cc0 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2789
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2790
		{ 0x1f, 0x0007 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2791
		{ 0x1e, 0x002d },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2792
		{ 0x18, 0x0040 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2793
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2794
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2795
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2796
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2797
	rtl_patchphy(tp, 0x0d, 1 << 5);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2798
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2799
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2800
static void rtl8168e_1_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2801
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2802
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2803
		/* Enable Delay cap */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2804
		{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2805
		{ 0x05, 0x8b80 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2806
		{ 0x06, 0xc896 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2807
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2808
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2809
		/* Channel estimation fine tune */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2810
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2811
		{ 0x0b, 0x6c20 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2812
		{ 0x07, 0x2872 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2813
		{ 0x1c, 0xefff },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2814
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2815
		{ 0x14, 0x6420 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2816
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2817
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2818
		/* Update PFM & 10M TX idle timer */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2819
		{ 0x1f, 0x0007 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2820
		{ 0x1e, 0x002f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2821
		{ 0x15, 0x1919 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2822
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2823
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2824
		{ 0x1f, 0x0007 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2825
		{ 0x1e, 0x00ac },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2826
		{ 0x18, 0x0006 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2827
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2828
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2829
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2830
	rtl_apply_firmware(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2831
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2832
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2833
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2834
	/* DCO enable for 10M IDLE Power */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2835
	rtl_writephy(tp, 0x1f, 0x0007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2836
	rtl_writephy(tp, 0x1e, 0x0023);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2837
	rtl_w1w0_phy(tp, 0x17, 0x0006, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2838
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2839
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2840
	/* For impedance matching */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2841
	rtl_writephy(tp, 0x1f, 0x0002);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2842
	rtl_w1w0_phy(tp, 0x08, 0x8000, 0x7f00);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2843
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2844
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2845
	/* PHY auto speed down */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2846
	rtl_writephy(tp, 0x1f, 0x0007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2847
	rtl_writephy(tp, 0x1e, 0x002d);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2848
	rtl_w1w0_phy(tp, 0x18, 0x0050, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2849
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2850
	rtl_w1w0_phy(tp, 0x14, 0x8000, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2851
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2852
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2853
	rtl_writephy(tp, 0x05, 0x8b86);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2854
	rtl_w1w0_phy(tp, 0x06, 0x0001, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2855
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2856
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2857
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2858
	rtl_writephy(tp, 0x05, 0x8b85);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2859
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x2000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2860
	rtl_writephy(tp, 0x1f, 0x0007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2861
	rtl_writephy(tp, 0x1e, 0x0020);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2862
	rtl_w1w0_phy(tp, 0x15, 0x0000, 0x1100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2863
	rtl_writephy(tp, 0x1f, 0x0006);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2864
	rtl_writephy(tp, 0x00, 0x5a00);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2865
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2866
	rtl_writephy(tp, 0x0d, 0x0007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2867
	rtl_writephy(tp, 0x0e, 0x003c);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2868
	rtl_writephy(tp, 0x0d, 0x4007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2869
	rtl_writephy(tp, 0x0e, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2870
	rtl_writephy(tp, 0x0d, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2871
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2872
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2873
static void rtl8168e_2_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2874
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2875
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2876
		/* Enable Delay cap */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2877
		{ 0x1f, 0x0004 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2878
		{ 0x1f, 0x0007 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2879
		{ 0x1e, 0x00ac },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2880
		{ 0x18, 0x0006 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2881
		{ 0x1f, 0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2882
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2883
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2884
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2885
		/* Channel estimation fine tune */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2886
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2887
		{ 0x09, 0xa20f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2888
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2889
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2890
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2891
		/* Green Setting */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2892
		{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2893
		{ 0x05, 0x8b5b },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2894
		{ 0x06, 0x9222 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2895
		{ 0x05, 0x8b6d },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2896
		{ 0x06, 0x8000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2897
		{ 0x05, 0x8b76 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2898
		{ 0x06, 0x8000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2899
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2900
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2901
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2902
	rtl_apply_firmware(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2903
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2904
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2905
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2906
	/* For 4-corner performance improve */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2907
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2908
	rtl_writephy(tp, 0x05, 0x8b80);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2909
	rtl_w1w0_phy(tp, 0x17, 0x0006, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2910
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2911
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2912
	/* PHY auto speed down */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2913
	rtl_writephy(tp, 0x1f, 0x0004);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2914
	rtl_writephy(tp, 0x1f, 0x0007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2915
	rtl_writephy(tp, 0x1e, 0x002d);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2916
	rtl_w1w0_phy(tp, 0x18, 0x0010, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2917
	rtl_writephy(tp, 0x1f, 0x0002);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2918
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2919
	rtl_w1w0_phy(tp, 0x14, 0x8000, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2920
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2921
	/* improve 10M EEE waveform */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2922
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2923
	rtl_writephy(tp, 0x05, 0x8b86);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2924
	rtl_w1w0_phy(tp, 0x06, 0x0001, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2925
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2926
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2927
	/* Improve 2-pair detection performance */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2928
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2929
	rtl_writephy(tp, 0x05, 0x8b85);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2930
	rtl_w1w0_phy(tp, 0x06, 0x4000, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2931
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2932
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2933
	/* EEE setting */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2934
	rtl_w1w0_eri(tp->mmio_addr, 0x1b0, ERIAR_MASK_1111, 0x0000, 0x0003,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2935
		     ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2936
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2937
	rtl_writephy(tp, 0x05, 0x8b85);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2938
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x2000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2939
	rtl_writephy(tp, 0x1f, 0x0004);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2940
	rtl_writephy(tp, 0x1f, 0x0007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2941
	rtl_writephy(tp, 0x1e, 0x0020);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2942
	rtl_w1w0_phy(tp, 0x15, 0x0000, 0x0100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2943
	rtl_writephy(tp, 0x1f, 0x0002);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2944
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2945
	rtl_writephy(tp, 0x0d, 0x0007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2946
	rtl_writephy(tp, 0x0e, 0x003c);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2947
	rtl_writephy(tp, 0x0d, 0x4007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2948
	rtl_writephy(tp, 0x0e, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2949
	rtl_writephy(tp, 0x0d, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2950
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2951
	/* Green feature */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2952
	rtl_writephy(tp, 0x1f, 0x0003);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2953
	rtl_w1w0_phy(tp, 0x19, 0x0000, 0x0001);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2954
	rtl_w1w0_phy(tp, 0x10, 0x0000, 0x0400);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2955
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2956
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2957
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2958
static void rtl8168f_1_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2959
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2960
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2961
		/* Channel estimation fine tune */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2962
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2963
		{ 0x09, 0xa20f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2964
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2965
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2966
		/* Modify green table for giga & fnet */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2967
		{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2968
		{ 0x05, 0x8b55 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2969
		{ 0x06, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2970
		{ 0x05, 0x8b5e },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2971
		{ 0x06, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2972
		{ 0x05, 0x8b67 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2973
		{ 0x06, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2974
		{ 0x05, 0x8b70 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2975
		{ 0x06, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2976
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2977
		{ 0x1f, 0x0007 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2978
		{ 0x1e, 0x0078 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2979
		{ 0x17, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2980
		{ 0x19, 0x00fb },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2981
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2982
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2983
		/* Modify green table for 10M */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2984
		{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2985
		{ 0x05, 0x8b79 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2986
		{ 0x06, 0xaa00 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2987
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2988
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2989
		/* Disable hiimpedance detection (RTCT) */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2990
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2991
		{ 0x01, 0x328a },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2992
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2993
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2994
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2995
	rtl_apply_firmware(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2996
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2997
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2998
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2999
	/* For 4-corner performance improve */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3000
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3001
	rtl_writephy(tp, 0x05, 0x8b80);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3002
	rtl_w1w0_phy(tp, 0x06, 0x0006, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3003
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3004
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3005
	/* PHY auto speed down */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3006
	rtl_writephy(tp, 0x1f, 0x0007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3007
	rtl_writephy(tp, 0x1e, 0x002d);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3008
	rtl_w1w0_phy(tp, 0x18, 0x0010, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3009
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3010
	rtl_w1w0_phy(tp, 0x14, 0x8000, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3011
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3012
	/* Improve 10M EEE waveform */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3013
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3014
	rtl_writephy(tp, 0x05, 0x8b86);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3015
	rtl_w1w0_phy(tp, 0x06, 0x0001, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3016
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3017
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3018
	/* Improve 2-pair detection performance */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3019
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3020
	rtl_writephy(tp, 0x05, 0x8b85);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3021
	rtl_w1w0_phy(tp, 0x06, 0x4000, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3022
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3023
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3024
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3025
static void rtl8168f_2_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3026
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3027
	rtl_apply_firmware(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3028
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3029
	/* For 4-corner performance improve */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3030
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3031
	rtl_writephy(tp, 0x05, 0x8b80);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3032
	rtl_w1w0_phy(tp, 0x06, 0x0006, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3033
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3034
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3035
	/* PHY auto speed down */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3036
	rtl_writephy(tp, 0x1f, 0x0007);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3037
	rtl_writephy(tp, 0x1e, 0x002d);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3038
	rtl_w1w0_phy(tp, 0x18, 0x0010, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3039
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3040
	rtl_w1w0_phy(tp, 0x14, 0x8000, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3041
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3042
	/* Improve 10M EEE waveform */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3043
	rtl_writephy(tp, 0x1f, 0x0005);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3044
	rtl_writephy(tp, 0x05, 0x8b86);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3045
	rtl_w1w0_phy(tp, 0x06, 0x0001, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3046
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3047
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3048
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3049
static void rtl8102e_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3050
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3051
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3052
		{ 0x1f, 0x0003 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3053
		{ 0x08, 0x441d },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3054
		{ 0x01, 0x9100 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3055
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3056
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3057
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3058
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3059
	rtl_patchphy(tp, 0x11, 1 << 12);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3060
	rtl_patchphy(tp, 0x19, 1 << 13);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3061
	rtl_patchphy(tp, 0x10, 1 << 15);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3062
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3063
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3064
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3065
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3066
static void rtl8105e_hw_phy_config(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3067
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3068
	static const struct phy_reg phy_reg_init[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3069
		{ 0x1f, 0x0005 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3070
		{ 0x1a, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3071
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3072
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3073
		{ 0x1f, 0x0004 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3074
		{ 0x1c, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3075
		{ 0x1f, 0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3076
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3077
		{ 0x1f, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3078
		{ 0x15, 0x7701 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3079
		{ 0x1f, 0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3080
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3081
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3082
	/* Disable ALDPS before ram code */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3083
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3084
	rtl_writephy(tp, 0x18, 0x0310);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3085
	msleep(100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3086
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3087
	rtl_apply_firmware(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3088
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3089
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3090
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3091
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3092
static void rtl_hw_phy_config(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3093
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3094
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3095
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3096
	rtl8169_print_mac_version(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3097
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3098
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3099
	case RTL_GIGA_MAC_VER_01:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3100
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3101
	case RTL_GIGA_MAC_VER_02:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3102
	case RTL_GIGA_MAC_VER_03:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3103
		rtl8169s_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3104
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3105
	case RTL_GIGA_MAC_VER_04:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3106
		rtl8169sb_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3107
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3108
	case RTL_GIGA_MAC_VER_05:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3109
		rtl8169scd_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3110
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3111
	case RTL_GIGA_MAC_VER_06:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3112
		rtl8169sce_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3113
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3114
	case RTL_GIGA_MAC_VER_07:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3115
	case RTL_GIGA_MAC_VER_08:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3116
	case RTL_GIGA_MAC_VER_09:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3117
		rtl8102e_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3118
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3119
	case RTL_GIGA_MAC_VER_11:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3120
		rtl8168bb_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3121
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3122
	case RTL_GIGA_MAC_VER_12:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3123
		rtl8168bef_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3124
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3125
	case RTL_GIGA_MAC_VER_17:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3126
		rtl8168bef_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3127
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3128
	case RTL_GIGA_MAC_VER_18:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3129
		rtl8168cp_1_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3130
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3131
	case RTL_GIGA_MAC_VER_19:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3132
		rtl8168c_1_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3133
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3134
	case RTL_GIGA_MAC_VER_20:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3135
		rtl8168c_2_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3136
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3137
	case RTL_GIGA_MAC_VER_21:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3138
		rtl8168c_3_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3139
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3140
	case RTL_GIGA_MAC_VER_22:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3141
		rtl8168c_4_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3142
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3143
	case RTL_GIGA_MAC_VER_23:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3144
	case RTL_GIGA_MAC_VER_24:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3145
		rtl8168cp_2_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3146
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3147
	case RTL_GIGA_MAC_VER_25:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3148
		rtl8168d_1_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3149
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3150
	case RTL_GIGA_MAC_VER_26:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3151
		rtl8168d_2_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3152
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3153
	case RTL_GIGA_MAC_VER_27:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3154
		rtl8168d_3_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3155
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3156
	case RTL_GIGA_MAC_VER_28:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3157
		rtl8168d_4_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3158
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3159
	case RTL_GIGA_MAC_VER_29:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3160
	case RTL_GIGA_MAC_VER_30:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3161
		rtl8105e_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3162
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3163
	case RTL_GIGA_MAC_VER_31:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3164
		/* None. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3165
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3166
	case RTL_GIGA_MAC_VER_32:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3167
	case RTL_GIGA_MAC_VER_33:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3168
		rtl8168e_1_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3169
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3170
	case RTL_GIGA_MAC_VER_34:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3171
		rtl8168e_2_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3172
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3173
	case RTL_GIGA_MAC_VER_35:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3174
		rtl8168f_1_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3175
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3176
	case RTL_GIGA_MAC_VER_36:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3177
		rtl8168f_2_hw_phy_config(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3178
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3179
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3180
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3181
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3182
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3183
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3184
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3185
static void rtl8169_phy_timer(unsigned long __opaque)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3186
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3187
	struct net_device *dev = (struct net_device *)__opaque;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3188
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3189
	struct timer_list *timer = &tp->timer;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3190
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3191
	unsigned long timeout = RTL8169_PHY_TIMEOUT;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3192
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3193
	assert(tp->mac_version > RTL_GIGA_MAC_VER_01);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3194
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3195
	spin_lock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3196
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3197
	if (tp->phy_reset_pending(tp)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3198
		/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3199
		 * A busy loop could burn quite a few cycles on nowadays CPU.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3200
		 * Let's delay the execution of the timer for a few ticks.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3201
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3202
		timeout = HZ/10;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3203
		goto out_mod_timer;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3204
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3205
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3206
	if (tp->link_ok(ioaddr))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3207
		goto out_unlock;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3208
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3209
	netif_warn(tp, link, dev, "PHY reset until link up\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3210
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3211
	tp->phy_reset_enable(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3212
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3213
out_mod_timer:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3214
	mod_timer(timer, jiffies + timeout);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3215
out_unlock:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3216
	spin_unlock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3217
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3218
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3219
#ifdef CONFIG_NET_POLL_CONTROLLER
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3220
/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3221
 * Polling 'interrupt' - used by things like netconsole to send skbs
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3222
 * without having to re-enable interrupts. It's not called while
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3223
 * the interrupt routine is executing.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3224
 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3225
static void rtl8169_netpoll(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3226
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3227
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3228
	struct pci_dev *pdev = tp->pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3229
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3230
	disable_irq(pdev->irq);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3231
	rtl8169_interrupt(pdev->irq, dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3232
	enable_irq(pdev->irq);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3233
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3234
#endif
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3235
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3236
static void rtl8169_release_board(struct pci_dev *pdev, struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3237
				  void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3238
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3239
	iounmap(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3240
	pci_release_regions(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3241
	pci_clear_mwi(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3242
	pci_disable_device(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3243
	free_netdev(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3244
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3245
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3246
static void rtl8169_phy_reset(struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3247
			      struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3248
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3249
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3250
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3251
	tp->phy_reset_enable(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3252
	for (i = 0; i < 100; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3253
		if (!tp->phy_reset_pending(tp))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3254
			return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3255
		msleep(1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3256
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3257
	netif_err(tp, link, dev, "PHY reset failed\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3258
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3259
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3260
static bool rtl_tbi_enabled(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3261
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3262
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3263
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3264
	return (tp->mac_version == RTL_GIGA_MAC_VER_01) &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3265
	    (RTL_R8(PHYstatus) & TBI_Enable);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3266
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3267
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3268
static void rtl8169_init_phy(struct net_device *dev, struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3269
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3270
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3271
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3272
	rtl_hw_phy_config(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3273
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3274
	if (tp->mac_version <= RTL_GIGA_MAC_VER_06) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3275
		dprintk("Set MAC Reg C+CR Offset 0x82h = 0x01h\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3276
		RTL_W8(0x82, 0x01);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3277
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3278
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3279
	pci_write_config_byte(tp->pci_dev, PCI_LATENCY_TIMER, 0x40);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3280
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3281
	if (tp->mac_version <= RTL_GIGA_MAC_VER_06)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3282
		pci_write_config_byte(tp->pci_dev, PCI_CACHE_LINE_SIZE, 0x08);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3283
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3284
	if (tp->mac_version == RTL_GIGA_MAC_VER_02) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3285
		dprintk("Set MAC Reg C+CR Offset 0x82h = 0x01h\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3286
		RTL_W8(0x82, 0x01);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3287
		dprintk("Set PHY Reg 0x0bh = 0x00h\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3288
		rtl_writephy(tp, 0x0b, 0x0000); //w 0x0b 15 0 0
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3289
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3290
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3291
	rtl8169_phy_reset(dev, tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3292
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3293
	rtl8169_set_speed(dev, AUTONEG_ENABLE, SPEED_1000, DUPLEX_FULL,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3294
			  ADVERTISED_10baseT_Half | ADVERTISED_10baseT_Full |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3295
			  ADVERTISED_100baseT_Half | ADVERTISED_100baseT_Full |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3296
			  (tp->mii.supports_gmii ?
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3297
			   ADVERTISED_1000baseT_Half |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3298
			   ADVERTISED_1000baseT_Full : 0));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3299
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3300
	if (rtl_tbi_enabled(tp))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3301
		netif_info(tp, link, dev, "TBI auto-negotiating\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3302
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3303
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3304
static void rtl_rar_set(struct rtl8169_private *tp, u8 *addr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3305
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3306
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3307
	u32 high;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3308
	u32 low;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3309
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3310
	low  = addr[0] | (addr[1] << 8) | (addr[2] << 16) | (addr[3] << 24);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3311
	high = addr[4] | (addr[5] << 8);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3312
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3313
	spin_lock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3314
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3315
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3316
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3317
	RTL_W32(MAC4, high);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3318
	RTL_R32(MAC4);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3319
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3320
	RTL_W32(MAC0, low);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3321
	RTL_R32(MAC0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3322
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3323
	if (tp->mac_version == RTL_GIGA_MAC_VER_34) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3324
		const struct exgmac_reg e[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3325
			{ .addr = 0xe0, ERIAR_MASK_1111, .val = low },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3326
			{ .addr = 0xe4, ERIAR_MASK_1111, .val = high },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3327
			{ .addr = 0xf0, ERIAR_MASK_1111, .val = low << 16 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3328
			{ .addr = 0xf4, ERIAR_MASK_1111, .val = high << 16 |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3329
								low  >> 16 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3330
		};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3331
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3332
		rtl_write_exgmac_batch(ioaddr, e, ARRAY_SIZE(e));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3333
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3334
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3335
	RTL_W8(Cfg9346, Cfg9346_Lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3336
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3337
	spin_unlock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3338
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3339
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3340
static int rtl_set_mac_address(struct net_device *dev, void *p)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3341
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3342
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3343
	struct sockaddr *addr = p;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3344
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3345
	if (!is_valid_ether_addr(addr->sa_data))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3346
		return -EADDRNOTAVAIL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3347
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3348
	memcpy(dev->dev_addr, addr->sa_data, dev->addr_len);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3349
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3350
	rtl_rar_set(tp, dev->dev_addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3351
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3352
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3353
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3354
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3355
static int rtl8169_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3356
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3357
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3358
	struct mii_ioctl_data *data = if_mii(ifr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3359
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3360
	return netif_running(dev) ? tp->do_ioctl(tp, data, cmd) : -ENODEV;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3361
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3362
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3363
static int rtl_xmii_ioctl(struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3364
			  struct mii_ioctl_data *data, int cmd)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3365
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3366
	switch (cmd) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3367
	case SIOCGMIIPHY:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3368
		data->phy_id = 32; /* Internal PHY */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3369
		return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3370
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3371
	case SIOCGMIIREG:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3372
		data->val_out = rtl_readphy(tp, data->reg_num & 0x1f);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3373
		return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3374
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3375
	case SIOCSMIIREG:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3376
		rtl_writephy(tp, data->reg_num & 0x1f, data->val_in);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3377
		return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3378
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3379
	return -EOPNOTSUPP;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3380
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3381
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3382
static int rtl_tbi_ioctl(struct rtl8169_private *tp, struct mii_ioctl_data *data, int cmd)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3383
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3384
	return -EOPNOTSUPP;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3385
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3386
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3387
static const struct rtl_cfg_info {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3388
	void (*hw_start)(struct net_device *);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3389
	unsigned int region;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3390
	unsigned int align;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3391
	u16 intr_event;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3392
	u16 napi_event;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3393
	unsigned features;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3394
	u8 default_ver;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3395
} rtl_cfg_infos [] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3396
	[RTL_CFG_0] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3397
		.hw_start	= rtl_hw_start_8169,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3398
		.region		= 1,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3399
		.align		= 0,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3400
		.intr_event	= SYSErr | LinkChg | RxOverflow |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3401
				  RxFIFOOver | TxErr | TxOK | RxOK | RxErr,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3402
		.napi_event	= RxFIFOOver | TxErr | TxOK | RxOK | RxOverflow,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3403
		.features	= RTL_FEATURE_GMII,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3404
		.default_ver	= RTL_GIGA_MAC_VER_01,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3405
	},
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3406
	[RTL_CFG_1] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3407
		.hw_start	= rtl_hw_start_8168,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3408
		.region		= 2,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3409
		.align		= 8,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3410
		.intr_event	= SYSErr | LinkChg | RxOverflow |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3411
				  TxErr | TxOK | RxOK | RxErr,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3412
		.napi_event	= TxErr | TxOK | RxOK | RxOverflow,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3413
		.features	= RTL_FEATURE_GMII | RTL_FEATURE_MSI,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3414
		.default_ver	= RTL_GIGA_MAC_VER_11,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3415
	},
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3416
	[RTL_CFG_2] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3417
		.hw_start	= rtl_hw_start_8101,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3418
		.region		= 2,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3419
		.align		= 8,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3420
		.intr_event	= SYSErr | LinkChg | RxOverflow | PCSTimeout |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3421
				  RxFIFOOver | TxErr | TxOK | RxOK | RxErr,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3422
		.napi_event	= RxFIFOOver | TxErr | TxOK | RxOK | RxOverflow,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3423
		.features	= RTL_FEATURE_MSI,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3424
		.default_ver	= RTL_GIGA_MAC_VER_13,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3425
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3426
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3427
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3428
/* Cfg9346_Unlock assumed. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3429
static unsigned rtl_try_msi(struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3430
			    const struct rtl_cfg_info *cfg)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3431
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3432
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3433
	unsigned msi = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3434
	u8 cfg2;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3435
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3436
	cfg2 = RTL_R8(Config2) & ~MSIEnable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3437
	if (cfg->features & RTL_FEATURE_MSI) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3438
		if (pci_enable_msi(tp->pci_dev)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3439
			netif_info(tp, hw, tp->dev, "no MSI. Back to INTx.\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3440
		} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3441
			cfg2 |= MSIEnable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3442
			msi = RTL_FEATURE_MSI;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3443
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3444
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3445
	if (tp->mac_version <= RTL_GIGA_MAC_VER_06)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3446
		RTL_W8(Config2, cfg2);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3447
	return msi;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3448
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3449
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3450
static void rtl_disable_msi(struct pci_dev *pdev, struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3451
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3452
	if (tp->features & RTL_FEATURE_MSI) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3453
		pci_disable_msi(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3454
		tp->features &= ~RTL_FEATURE_MSI;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3455
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3456
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3457
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3458
static const struct net_device_ops rtl8169_netdev_ops = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3459
	.ndo_open		= rtl8169_open,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3460
	.ndo_stop		= rtl8169_close,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3461
	.ndo_get_stats		= rtl8169_get_stats,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3462
	.ndo_start_xmit		= rtl8169_start_xmit,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3463
	.ndo_tx_timeout		= rtl8169_tx_timeout,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3464
	.ndo_validate_addr	= eth_validate_addr,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3465
	.ndo_change_mtu		= rtl8169_change_mtu,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3466
	.ndo_fix_features	= rtl8169_fix_features,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3467
	.ndo_set_features	= rtl8169_set_features,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3468
	.ndo_set_mac_address	= rtl_set_mac_address,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3469
	.ndo_do_ioctl		= rtl8169_ioctl,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3470
	.ndo_set_rx_mode	= rtl_set_rx_mode,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3471
#ifdef CONFIG_NET_POLL_CONTROLLER
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3472
	.ndo_poll_controller	= rtl8169_netpoll,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3473
#endif
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3474
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3475
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3476
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3477
static void __devinit rtl_init_mdio_ops(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3478
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3479
	struct mdio_ops *ops = &tp->mdio_ops;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3480
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3481
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3482
	case RTL_GIGA_MAC_VER_27:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3483
		ops->write	= r8168dp_1_mdio_write;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3484
		ops->read	= r8168dp_1_mdio_read;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3485
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3486
	case RTL_GIGA_MAC_VER_28:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3487
	case RTL_GIGA_MAC_VER_31:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3488
		ops->write	= r8168dp_2_mdio_write;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3489
		ops->read	= r8168dp_2_mdio_read;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3490
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3491
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3492
		ops->write	= r8169_mdio_write;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3493
		ops->read	= r8169_mdio_read;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3494
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3495
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3496
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3497
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3498
static void rtl_wol_suspend_quirk(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3499
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3500
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3501
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3502
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3503
	case RTL_GIGA_MAC_VER_29:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3504
	case RTL_GIGA_MAC_VER_30:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3505
	case RTL_GIGA_MAC_VER_32:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3506
	case RTL_GIGA_MAC_VER_33:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3507
	case RTL_GIGA_MAC_VER_34:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3508
		RTL_W32(RxConfig, RTL_R32(RxConfig) |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3509
			AcceptBroadcast | AcceptMulticast | AcceptMyPhys);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3510
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3511
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3512
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3513
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3514
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3515
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3516
static bool rtl_wol_pll_power_down(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3517
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3518
	if (!(__rtl8169_get_wol(tp) & WAKE_ANY))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3519
		return false;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3520
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3521
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3522
	rtl_writephy(tp, MII_BMCR, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3523
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3524
	rtl_wol_suspend_quirk(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3525
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3526
	return true;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3527
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3528
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3529
static void r810x_phy_power_down(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3530
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3531
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3532
	rtl_writephy(tp, MII_BMCR, BMCR_PDOWN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3533
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3534
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3535
static void r810x_phy_power_up(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3536
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3537
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3538
	rtl_writephy(tp, MII_BMCR, BMCR_ANENABLE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3539
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3540
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3541
static void r810x_pll_power_down(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3542
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3543
	if (rtl_wol_pll_power_down(tp))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3544
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3545
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3546
	r810x_phy_power_down(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3547
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3548
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3549
static void r810x_pll_power_up(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3550
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3551
	r810x_phy_power_up(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3552
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3553
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3554
static void r8168_phy_power_up(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3555
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3556
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3557
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3558
	case RTL_GIGA_MAC_VER_11:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3559
	case RTL_GIGA_MAC_VER_12:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3560
	case RTL_GIGA_MAC_VER_17:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3561
	case RTL_GIGA_MAC_VER_18:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3562
	case RTL_GIGA_MAC_VER_19:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3563
	case RTL_GIGA_MAC_VER_20:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3564
	case RTL_GIGA_MAC_VER_21:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3565
	case RTL_GIGA_MAC_VER_22:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3566
	case RTL_GIGA_MAC_VER_23:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3567
	case RTL_GIGA_MAC_VER_24:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3568
	case RTL_GIGA_MAC_VER_25:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3569
	case RTL_GIGA_MAC_VER_26:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3570
	case RTL_GIGA_MAC_VER_27:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3571
	case RTL_GIGA_MAC_VER_28:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3572
	case RTL_GIGA_MAC_VER_31:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3573
		rtl_writephy(tp, 0x0e, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3574
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3575
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3576
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3577
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3578
	rtl_writephy(tp, MII_BMCR, BMCR_ANENABLE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3579
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3580
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3581
static void r8168_phy_power_down(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3582
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3583
	rtl_writephy(tp, 0x1f, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3584
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3585
	case RTL_GIGA_MAC_VER_32:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3586
	case RTL_GIGA_MAC_VER_33:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3587
		rtl_writephy(tp, MII_BMCR, BMCR_ANENABLE | BMCR_PDOWN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3588
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3589
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3590
	case RTL_GIGA_MAC_VER_11:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3591
	case RTL_GIGA_MAC_VER_12:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3592
	case RTL_GIGA_MAC_VER_17:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3593
	case RTL_GIGA_MAC_VER_18:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3594
	case RTL_GIGA_MAC_VER_19:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3595
	case RTL_GIGA_MAC_VER_20:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3596
	case RTL_GIGA_MAC_VER_21:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3597
	case RTL_GIGA_MAC_VER_22:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3598
	case RTL_GIGA_MAC_VER_23:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3599
	case RTL_GIGA_MAC_VER_24:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3600
	case RTL_GIGA_MAC_VER_25:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3601
	case RTL_GIGA_MAC_VER_26:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3602
	case RTL_GIGA_MAC_VER_27:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3603
	case RTL_GIGA_MAC_VER_28:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3604
	case RTL_GIGA_MAC_VER_31:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3605
		rtl_writephy(tp, 0x0e, 0x0200);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3606
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3607
		rtl_writephy(tp, MII_BMCR, BMCR_PDOWN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3608
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3609
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3610
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3611
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3612
static void r8168_pll_power_down(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3613
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3614
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3615
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3616
	if ((tp->mac_version == RTL_GIGA_MAC_VER_27 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3617
	     tp->mac_version == RTL_GIGA_MAC_VER_28 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3618
	     tp->mac_version == RTL_GIGA_MAC_VER_31) &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3619
	    r8168dp_check_dash(tp)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3620
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3621
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3622
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3623
	if ((tp->mac_version == RTL_GIGA_MAC_VER_23 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3624
	     tp->mac_version == RTL_GIGA_MAC_VER_24) &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3625
	    (RTL_R16(CPlusCmd) & ASF)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3626
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3627
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3628
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3629
	if (tp->mac_version == RTL_GIGA_MAC_VER_32 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3630
	    tp->mac_version == RTL_GIGA_MAC_VER_33)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3631
		rtl_ephy_write(ioaddr, 0x19, 0xff64);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3632
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3633
	if (rtl_wol_pll_power_down(tp))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3634
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3635
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3636
	r8168_phy_power_down(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3637
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3638
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3639
	case RTL_GIGA_MAC_VER_25:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3640
	case RTL_GIGA_MAC_VER_26:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3641
	case RTL_GIGA_MAC_VER_27:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3642
	case RTL_GIGA_MAC_VER_28:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3643
	case RTL_GIGA_MAC_VER_31:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3644
	case RTL_GIGA_MAC_VER_32:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3645
	case RTL_GIGA_MAC_VER_33:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3646
		RTL_W8(PMCH, RTL_R8(PMCH) & ~0x80);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3647
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3648
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3649
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3650
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3651
static void r8168_pll_power_up(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3652
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3653
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3654
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3655
	if ((tp->mac_version == RTL_GIGA_MAC_VER_27 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3656
	     tp->mac_version == RTL_GIGA_MAC_VER_28 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3657
	     tp->mac_version == RTL_GIGA_MAC_VER_31) &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3658
	    r8168dp_check_dash(tp)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3659
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3660
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3661
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3662
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3663
	case RTL_GIGA_MAC_VER_25:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3664
	case RTL_GIGA_MAC_VER_26:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3665
	case RTL_GIGA_MAC_VER_27:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3666
	case RTL_GIGA_MAC_VER_28:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3667
	case RTL_GIGA_MAC_VER_31:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3668
	case RTL_GIGA_MAC_VER_32:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3669
	case RTL_GIGA_MAC_VER_33:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3670
		RTL_W8(PMCH, RTL_R8(PMCH) | 0x80);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3671
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3672
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3673
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3674
	r8168_phy_power_up(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3675
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3676
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3677
static void rtl_generic_op(struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3678
			   void (*op)(struct rtl8169_private *))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3679
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3680
	if (op)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3681
		op(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3682
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3683
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3684
static void rtl_pll_power_down(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3685
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3686
	rtl_generic_op(tp, tp->pll_power_ops.down);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3687
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3688
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3689
static void rtl_pll_power_up(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3690
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3691
	rtl_generic_op(tp, tp->pll_power_ops.up);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3692
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3693
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3694
static void __devinit rtl_init_pll_power_ops(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3695
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3696
	struct pll_power_ops *ops = &tp->pll_power_ops;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3697
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3698
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3699
	case RTL_GIGA_MAC_VER_07:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3700
	case RTL_GIGA_MAC_VER_08:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3701
	case RTL_GIGA_MAC_VER_09:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3702
	case RTL_GIGA_MAC_VER_10:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3703
	case RTL_GIGA_MAC_VER_16:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3704
	case RTL_GIGA_MAC_VER_29:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3705
	case RTL_GIGA_MAC_VER_30:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3706
		ops->down	= r810x_pll_power_down;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3707
		ops->up		= r810x_pll_power_up;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3708
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3709
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3710
	case RTL_GIGA_MAC_VER_11:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3711
	case RTL_GIGA_MAC_VER_12:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3712
	case RTL_GIGA_MAC_VER_17:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3713
	case RTL_GIGA_MAC_VER_18:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3714
	case RTL_GIGA_MAC_VER_19:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3715
	case RTL_GIGA_MAC_VER_20:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3716
	case RTL_GIGA_MAC_VER_21:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3717
	case RTL_GIGA_MAC_VER_22:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3718
	case RTL_GIGA_MAC_VER_23:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3719
	case RTL_GIGA_MAC_VER_24:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3720
	case RTL_GIGA_MAC_VER_25:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3721
	case RTL_GIGA_MAC_VER_26:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3722
	case RTL_GIGA_MAC_VER_27:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3723
	case RTL_GIGA_MAC_VER_28:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3724
	case RTL_GIGA_MAC_VER_31:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3725
	case RTL_GIGA_MAC_VER_32:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3726
	case RTL_GIGA_MAC_VER_33:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3727
	case RTL_GIGA_MAC_VER_34:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3728
	case RTL_GIGA_MAC_VER_35:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3729
	case RTL_GIGA_MAC_VER_36:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3730
		ops->down	= r8168_pll_power_down;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3731
		ops->up		= r8168_pll_power_up;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3732
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3733
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3734
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3735
		ops->down	= NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3736
		ops->up		= NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3737
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3738
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3739
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3740
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3741
static void rtl_init_rxcfg(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3742
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3743
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3744
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3745
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3746
	case RTL_GIGA_MAC_VER_01:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3747
	case RTL_GIGA_MAC_VER_02:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3748
	case RTL_GIGA_MAC_VER_03:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3749
	case RTL_GIGA_MAC_VER_04:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3750
	case RTL_GIGA_MAC_VER_05:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3751
	case RTL_GIGA_MAC_VER_06:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3752
	case RTL_GIGA_MAC_VER_10:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3753
	case RTL_GIGA_MAC_VER_11:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3754
	case RTL_GIGA_MAC_VER_12:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3755
	case RTL_GIGA_MAC_VER_13:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3756
	case RTL_GIGA_MAC_VER_14:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3757
	case RTL_GIGA_MAC_VER_15:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3758
	case RTL_GIGA_MAC_VER_16:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3759
	case RTL_GIGA_MAC_VER_17:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3760
		RTL_W32(RxConfig, RX_FIFO_THRESH | RX_DMA_BURST);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3761
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3762
	case RTL_GIGA_MAC_VER_18:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3763
	case RTL_GIGA_MAC_VER_19:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3764
	case RTL_GIGA_MAC_VER_20:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3765
	case RTL_GIGA_MAC_VER_21:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3766
	case RTL_GIGA_MAC_VER_22:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3767
	case RTL_GIGA_MAC_VER_23:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3768
	case RTL_GIGA_MAC_VER_24:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3769
		RTL_W32(RxConfig, RX128_INT_EN | RX_MULTI_EN | RX_DMA_BURST);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3770
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3771
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3772
		RTL_W32(RxConfig, RX128_INT_EN | RX_DMA_BURST);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3773
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3774
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3775
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3776
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3777
static void rtl8169_init_ring_indexes(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3778
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3779
	tp->dirty_tx = tp->dirty_rx = tp->cur_tx = tp->cur_rx = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3780
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3781
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3782
static void rtl_hw_jumbo_enable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3783
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3784
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3785
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3786
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3787
	rtl_generic_op(tp, tp->jumbo_ops.enable);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3788
	RTL_W8(Cfg9346, Cfg9346_Lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3789
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3790
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3791
static void rtl_hw_jumbo_disable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3792
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3793
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3794
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3795
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3796
	rtl_generic_op(tp, tp->jumbo_ops.disable);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3797
	RTL_W8(Cfg9346, Cfg9346_Lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3798
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3799
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3800
static void r8168c_hw_jumbo_enable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3801
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3802
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3803
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3804
	RTL_W8(Config3, RTL_R8(Config3) | Jumbo_En0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3805
	RTL_W8(Config4, RTL_R8(Config4) | Jumbo_En1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3806
	rtl_tx_performance_tweak(tp->pci_dev, 0x2 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3807
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3808
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3809
static void r8168c_hw_jumbo_disable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3810
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3811
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3812
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3813
	RTL_W8(Config3, RTL_R8(Config3) & ~Jumbo_En0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3814
	RTL_W8(Config4, RTL_R8(Config4) & ~Jumbo_En1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3815
	rtl_tx_performance_tweak(tp->pci_dev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3816
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3817
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3818
static void r8168dp_hw_jumbo_enable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3819
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3820
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3821
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3822
	RTL_W8(Config3, RTL_R8(Config3) | Jumbo_En0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3823
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3824
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3825
static void r8168dp_hw_jumbo_disable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3826
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3827
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3828
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3829
	RTL_W8(Config3, RTL_R8(Config3) & ~Jumbo_En0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3830
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3831
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3832
static void r8168e_hw_jumbo_enable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3833
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3834
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3835
	struct pci_dev *pdev = tp->pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3836
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3837
	RTL_W8(MaxTxPacketSize, 0x3f);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3838
	RTL_W8(Config3, RTL_R8(Config3) | Jumbo_En0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3839
	RTL_W8(Config4, RTL_R8(Config4) | 0x01);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3840
	pci_write_config_byte(pdev, 0x79, 0x20);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3841
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3842
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3843
static void r8168e_hw_jumbo_disable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3844
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3845
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3846
	struct pci_dev *pdev = tp->pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3847
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3848
	RTL_W8(MaxTxPacketSize, 0x0c);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3849
	RTL_W8(Config3, RTL_R8(Config3) & ~Jumbo_En0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3850
	RTL_W8(Config4, RTL_R8(Config4) & ~0x01);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3851
	pci_write_config_byte(pdev, 0x79, 0x50);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3852
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3853
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3854
static void r8168b_0_hw_jumbo_enable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3855
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3856
	rtl_tx_performance_tweak(tp->pci_dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3857
		(0x2 << MAX_READ_REQUEST_SHIFT) | PCI_EXP_DEVCTL_NOSNOOP_EN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3858
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3859
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3860
static void r8168b_0_hw_jumbo_disable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3861
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3862
	rtl_tx_performance_tweak(tp->pci_dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3863
		(0x5 << MAX_READ_REQUEST_SHIFT) | PCI_EXP_DEVCTL_NOSNOOP_EN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3864
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3865
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3866
static void r8168b_1_hw_jumbo_enable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3867
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3868
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3869
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3870
	r8168b_0_hw_jumbo_enable(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3871
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3872
	RTL_W8(Config4, RTL_R8(Config4) | (1 << 0));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3873
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3874
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3875
static void r8168b_1_hw_jumbo_disable(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3876
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3877
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3878
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3879
	r8168b_0_hw_jumbo_disable(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3880
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3881
	RTL_W8(Config4, RTL_R8(Config4) & ~(1 << 0));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3882
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3883
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3884
static void __devinit rtl_init_jumbo_ops(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3885
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3886
	struct jumbo_ops *ops = &tp->jumbo_ops;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3887
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3888
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3889
	case RTL_GIGA_MAC_VER_11:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3890
		ops->disable	= r8168b_0_hw_jumbo_disable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3891
		ops->enable	= r8168b_0_hw_jumbo_enable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3892
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3893
	case RTL_GIGA_MAC_VER_12:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3894
	case RTL_GIGA_MAC_VER_17:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3895
		ops->disable	= r8168b_1_hw_jumbo_disable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3896
		ops->enable	= r8168b_1_hw_jumbo_enable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3897
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3898
	case RTL_GIGA_MAC_VER_18: /* Wild guess. Needs info from Realtek. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3899
	case RTL_GIGA_MAC_VER_19:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3900
	case RTL_GIGA_MAC_VER_20:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3901
	case RTL_GIGA_MAC_VER_21: /* Wild guess. Needs info from Realtek. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3902
	case RTL_GIGA_MAC_VER_22:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3903
	case RTL_GIGA_MAC_VER_23:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3904
	case RTL_GIGA_MAC_VER_24:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3905
	case RTL_GIGA_MAC_VER_25:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3906
	case RTL_GIGA_MAC_VER_26:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3907
		ops->disable	= r8168c_hw_jumbo_disable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3908
		ops->enable	= r8168c_hw_jumbo_enable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3909
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3910
	case RTL_GIGA_MAC_VER_27:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3911
	case RTL_GIGA_MAC_VER_28:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3912
		ops->disable	= r8168dp_hw_jumbo_disable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3913
		ops->enable	= r8168dp_hw_jumbo_enable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3914
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3915
	case RTL_GIGA_MAC_VER_31: /* Wild guess. Needs info from Realtek. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3916
	case RTL_GIGA_MAC_VER_32:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3917
	case RTL_GIGA_MAC_VER_33:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3918
	case RTL_GIGA_MAC_VER_34:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3919
		ops->disable	= r8168e_hw_jumbo_disable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3920
		ops->enable	= r8168e_hw_jumbo_enable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3921
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3922
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3923
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3924
	 * No action needed for jumbo frames with 8169.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3925
	 * No jumbo for 810x at all.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3926
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3927
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3928
		ops->disable	= NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3929
		ops->enable	= NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3930
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3931
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3932
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3933
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3934
static void rtl_hw_reset(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3935
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3936
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3937
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3938
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3939
	/* Soft reset the chip. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3940
	RTL_W8(ChipCmd, CmdReset);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3941
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3942
	/* Check that the chip has finished the reset. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3943
	for (i = 0; i < 100; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3944
		if ((RTL_R8(ChipCmd) & CmdReset) == 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3945
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3946
		udelay(100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3947
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3948
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3949
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3950
static int __devinit
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3951
rtl8169_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3952
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3953
	const struct rtl_cfg_info *cfg = rtl_cfg_infos + ent->driver_data;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3954
	const unsigned int region = cfg->region;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3955
	struct rtl8169_private *tp;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3956
	struct mii_if_info *mii;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3957
	struct net_device *dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3958
	void __iomem *ioaddr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3959
	int chipset, i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3960
	int rc;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3961
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3962
	if (netif_msg_drv(&debug)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3963
		printk(KERN_INFO "%s Gigabit Ethernet driver %s loaded\n",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3964
		       MODULENAME, RTL8169_VERSION);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3965
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3966
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3967
	dev = alloc_etherdev(sizeof (*tp));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3968
	if (!dev) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3969
		if (netif_msg_drv(&debug))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3970
			dev_err(&pdev->dev, "unable to alloc new ethernet\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3971
		rc = -ENOMEM;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3972
		goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3973
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3974
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3975
	SET_NETDEV_DEV(dev, &pdev->dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3976
	dev->netdev_ops = &rtl8169_netdev_ops;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3977
	tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3978
	tp->dev = dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3979
	tp->pci_dev = pdev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3980
	tp->msg_enable = netif_msg_init(debug.msg_enable, R8169_MSG_DEFAULT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3981
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3982
	mii = &tp->mii;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3983
	mii->dev = dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3984
	mii->mdio_read = rtl_mdio_read;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3985
	mii->mdio_write = rtl_mdio_write;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3986
	mii->phy_id_mask = 0x1f;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3987
	mii->reg_num_mask = 0x1f;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3988
	mii->supports_gmii = !!(cfg->features & RTL_FEATURE_GMII);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3989
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3990
	/* disable ASPM completely as that cause random device stop working
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3991
	 * problems as well as full system hangs for some PCIe devices users */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3992
	pci_disable_link_state(pdev, PCIE_LINK_STATE_L0S | PCIE_LINK_STATE_L1 |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3993
				     PCIE_LINK_STATE_CLKPM);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3994
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3995
	/* enable device (incl. PCI PM wakeup and hotplug setup) */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3996
	rc = pci_enable_device(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3997
	if (rc < 0) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3998
		netif_err(tp, probe, dev, "enable failure\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3999
		goto err_out_free_dev_1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4000
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4001
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4002
	if (pci_set_mwi(pdev) < 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4003
		netif_info(tp, probe, dev, "Mem-Wr-Inval unavailable\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4004
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4005
	/* make sure PCI base addr 1 is MMIO */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4006
	if (!(pci_resource_flags(pdev, region) & IORESOURCE_MEM)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4007
		netif_err(tp, probe, dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4008
			  "region #%d not an MMIO resource, aborting\n",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4009
			  region);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4010
		rc = -ENODEV;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4011
		goto err_out_mwi_2;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4012
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4013
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4014
	/* check for weird/broken PCI region reporting */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4015
	if (pci_resource_len(pdev, region) < R8169_REGS_SIZE) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4016
		netif_err(tp, probe, dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4017
			  "Invalid PCI region size(s), aborting\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4018
		rc = -ENODEV;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4019
		goto err_out_mwi_2;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4020
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4021
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4022
	rc = pci_request_regions(pdev, MODULENAME);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4023
	if (rc < 0) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4024
		netif_err(tp, probe, dev, "could not request regions\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4025
		goto err_out_mwi_2;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4026
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4027
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4028
	tp->cp_cmd = RxChkSum;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4029
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4030
	if ((sizeof(dma_addr_t) > 4) &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4031
	    !pci_set_dma_mask(pdev, DMA_BIT_MASK(64)) && use_dac) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4032
		tp->cp_cmd |= PCIDAC;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4033
		dev->features |= NETIF_F_HIGHDMA;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4034
	} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4035
		rc = pci_set_dma_mask(pdev, DMA_BIT_MASK(32));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4036
		if (rc < 0) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4037
			netif_err(tp, probe, dev, "DMA configuration failed\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4038
			goto err_out_free_res_3;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4039
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4040
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4041
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4042
	/* ioremap MMIO region */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4043
	ioaddr = ioremap(pci_resource_start(pdev, region), R8169_REGS_SIZE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4044
	if (!ioaddr) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4045
		netif_err(tp, probe, dev, "cannot remap MMIO, aborting\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4046
		rc = -EIO;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4047
		goto err_out_free_res_3;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4048
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4049
	tp->mmio_addr = ioaddr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4050
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4051
	if (!pci_is_pcie(pdev))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4052
		netif_info(tp, probe, dev, "not PCI Express\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4053
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4054
	/* Identify chip attached to board */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4055
	rtl8169_get_mac_version(tp, dev, cfg->default_ver);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4056
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4057
	rtl_init_rxcfg(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4058
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4059
	RTL_W16(IntrMask, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4060
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4061
	rtl_hw_reset(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4062
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4063
	RTL_W16(IntrStatus, 0xffff);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4064
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4065
	pci_set_master(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4066
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4067
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4068
	 * Pretend we are using VLANs; This bypasses a nasty bug where
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4069
	 * Interrupts stop flowing on high load on 8110SCd controllers.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4070
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4071
	if (tp->mac_version == RTL_GIGA_MAC_VER_05)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4072
		tp->cp_cmd |= RxVlan;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4073
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4074
	rtl_init_mdio_ops(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4075
	rtl_init_pll_power_ops(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4076
	rtl_init_jumbo_ops(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4077
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4078
	rtl8169_print_mac_version(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4079
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4080
	chipset = tp->mac_version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4081
	tp->txd_version = rtl_chip_infos[chipset].txd_version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4082
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4083
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4084
	RTL_W8(Config1, RTL_R8(Config1) | PMEnable);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4085
	RTL_W8(Config5, RTL_R8(Config5) & PMEStatus);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4086
	if ((RTL_R8(Config3) & (LinkUp | MagicPacket)) != 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4087
		tp->features |= RTL_FEATURE_WOL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4088
	if ((RTL_R8(Config5) & (UWF | BWF | MWF)) != 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4089
		tp->features |= RTL_FEATURE_WOL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4090
	tp->features |= rtl_try_msi(tp, cfg);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4091
	RTL_W8(Cfg9346, Cfg9346_Lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4092
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4093
	if (rtl_tbi_enabled(tp)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4094
		tp->set_speed = rtl8169_set_speed_tbi;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4095
		tp->get_settings = rtl8169_gset_tbi;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4096
		tp->phy_reset_enable = rtl8169_tbi_reset_enable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4097
		tp->phy_reset_pending = rtl8169_tbi_reset_pending;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4098
		tp->link_ok = rtl8169_tbi_link_ok;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4099
		tp->do_ioctl = rtl_tbi_ioctl;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4100
	} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4101
		tp->set_speed = rtl8169_set_speed_xmii;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4102
		tp->get_settings = rtl8169_gset_xmii;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4103
		tp->phy_reset_enable = rtl8169_xmii_reset_enable;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4104
		tp->phy_reset_pending = rtl8169_xmii_reset_pending;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4105
		tp->link_ok = rtl8169_xmii_link_ok;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4106
		tp->do_ioctl = rtl_xmii_ioctl;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4107
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4108
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4109
	spin_lock_init(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4110
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4111
	/* Get MAC address */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4112
	for (i = 0; i < MAC_ADDR_LEN; i++)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4113
		dev->dev_addr[i] = RTL_R8(MAC0 + i);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4114
	memcpy(dev->perm_addr, dev->dev_addr, dev->addr_len);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4115
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4116
	SET_ETHTOOL_OPS(dev, &rtl8169_ethtool_ops);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4117
	dev->watchdog_timeo = RTL8169_TX_TIMEOUT;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4118
	dev->irq = pdev->irq;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4119
	dev->base_addr = (unsigned long) ioaddr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4120
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4121
	netif_napi_add(dev, &tp->napi, rtl8169_poll, R8169_NAPI_WEIGHT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4122
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4123
	/* don't enable SG, IP_CSUM and TSO by default - it might not work
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4124
	 * properly for all devices */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4125
	dev->features |= NETIF_F_RXCSUM |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4126
		NETIF_F_HW_VLAN_TX | NETIF_F_HW_VLAN_RX;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4127
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4128
	dev->hw_features = NETIF_F_SG | NETIF_F_IP_CSUM | NETIF_F_TSO |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4129
		NETIF_F_RXCSUM | NETIF_F_HW_VLAN_TX | NETIF_F_HW_VLAN_RX;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4130
	dev->vlan_features = NETIF_F_SG | NETIF_F_IP_CSUM | NETIF_F_TSO |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4131
		NETIF_F_HIGHDMA;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4132
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4133
	if (tp->mac_version == RTL_GIGA_MAC_VER_05)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4134
		/* 8110SCd requires hardware Rx VLAN - disallow toggling */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4135
		dev->hw_features &= ~NETIF_F_HW_VLAN_RX;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4136
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4137
	tp->intr_mask = 0xffff;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4138
	tp->hw_start = cfg->hw_start;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4139
	tp->intr_event = cfg->intr_event;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4140
	tp->napi_event = cfg->napi_event;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4141
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4142
	tp->opts1_mask = (tp->mac_version != RTL_GIGA_MAC_VER_01) ?
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4143
		~(RxBOVF | RxFOVF) : ~0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4144
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4145
	init_timer(&tp->timer);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4146
	tp->timer.data = (unsigned long) dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4147
	tp->timer.function = rtl8169_phy_timer;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4148
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4149
	tp->rtl_fw = RTL_FIRMWARE_UNKNOWN;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4150
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4151
	rc = register_netdev(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4152
	if (rc < 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4153
		goto err_out_msi_4;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4154
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4155
	pci_set_drvdata(pdev, dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4156
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4157
	netif_info(tp, probe, dev, "%s at 0x%lx, %pM, XID %08x IRQ %d\n",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4158
		   rtl_chip_infos[chipset].name, dev->base_addr, dev->dev_addr,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4159
		   (u32)(RTL_R32(TxConfig) & 0x9cf0f8ff), dev->irq);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4160
	if (rtl_chip_infos[chipset].jumbo_max != JUMBO_1K) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4161
		netif_info(tp, probe, dev, "jumbo features [frames: %d bytes, "
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4162
			   "tx checksumming: %s]\n",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4163
			   rtl_chip_infos[chipset].jumbo_max,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4164
			   rtl_chip_infos[chipset].jumbo_tx_csum ? "ok" : "ko");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4165
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4166
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4167
	if (tp->mac_version == RTL_GIGA_MAC_VER_27 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4168
	    tp->mac_version == RTL_GIGA_MAC_VER_28 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4169
	    tp->mac_version == RTL_GIGA_MAC_VER_31) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4170
		rtl8168_driver_start(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4171
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4172
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4173
	device_set_wakeup_enable(&pdev->dev, tp->features & RTL_FEATURE_WOL);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4174
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4175
	if (pci_dev_run_wake(pdev))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4176
		pm_runtime_put_noidle(&pdev->dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4177
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4178
	netif_carrier_off(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4179
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4180
out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4181
	return rc;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4182
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4183
err_out_msi_4:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4184
	rtl_disable_msi(pdev, tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4185
	iounmap(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4186
err_out_free_res_3:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4187
	pci_release_regions(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4188
err_out_mwi_2:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4189
	pci_clear_mwi(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4190
	pci_disable_device(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4191
err_out_free_dev_1:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4192
	free_netdev(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4193
	goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4194
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4195
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4196
static void __devexit rtl8169_remove_one(struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4197
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4198
	struct net_device *dev = pci_get_drvdata(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4199
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4200
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4201
	if (tp->mac_version == RTL_GIGA_MAC_VER_27 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4202
	    tp->mac_version == RTL_GIGA_MAC_VER_28 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4203
	    tp->mac_version == RTL_GIGA_MAC_VER_31) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4204
		rtl8168_driver_stop(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4205
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4206
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4207
	cancel_delayed_work_sync(&tp->task);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4208
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4209
	unregister_netdev(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4210
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4211
	rtl_release_firmware(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4212
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4213
	if (pci_dev_run_wake(pdev))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4214
		pm_runtime_get_noresume(&pdev->dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4215
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4216
	/* restore original MAC address */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4217
	rtl_rar_set(tp, dev->perm_addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4218
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4219
	rtl_disable_msi(pdev, tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4220
	rtl8169_release_board(pdev, dev, tp->mmio_addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4221
	pci_set_drvdata(pdev, NULL);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4222
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4223
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4224
static void rtl_request_uncached_firmware(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4225
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4226
	struct rtl_fw *rtl_fw;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4227
	const char *name;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4228
	int rc = -ENOMEM;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4229
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4230
	name = rtl_lookup_firmware_name(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4231
	if (!name)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4232
		goto out_no_firmware;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4233
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4234
	rtl_fw = kzalloc(sizeof(*rtl_fw), GFP_KERNEL);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4235
	if (!rtl_fw)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4236
		goto err_warn;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4237
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4238
	rc = request_firmware(&rtl_fw->fw, name, &tp->pci_dev->dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4239
	if (rc < 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4240
		goto err_free;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4241
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4242
	rc = rtl_check_firmware(tp, rtl_fw);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4243
	if (rc < 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4244
		goto err_release_firmware;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4245
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4246
	tp->rtl_fw = rtl_fw;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4247
out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4248
	return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4249
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4250
err_release_firmware:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4251
	release_firmware(rtl_fw->fw);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4252
err_free:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4253
	kfree(rtl_fw);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4254
err_warn:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4255
	netif_warn(tp, ifup, tp->dev, "unable to load firmware patch %s (%d)\n",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4256
		   name, rc);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4257
out_no_firmware:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4258
	tp->rtl_fw = NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4259
	goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4260
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4261
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4262
static void rtl_request_firmware(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4263
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4264
	if (IS_ERR(tp->rtl_fw))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4265
		rtl_request_uncached_firmware(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4266
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4267
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4268
static int rtl8169_open(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4269
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4270
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4271
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4272
	struct pci_dev *pdev = tp->pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4273
	int retval = -ENOMEM;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4274
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4275
	pm_runtime_get_sync(&pdev->dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4276
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4277
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4278
	 * Rx and Tx desscriptors needs 256 bytes alignment.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4279
	 * dma_alloc_coherent provides more.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4280
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4281
	tp->TxDescArray = dma_alloc_coherent(&pdev->dev, R8169_TX_RING_BYTES,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4282
					     &tp->TxPhyAddr, GFP_KERNEL);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4283
	if (!tp->TxDescArray)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4284
		goto err_pm_runtime_put;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4285
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4286
	tp->RxDescArray = dma_alloc_coherent(&pdev->dev, R8169_RX_RING_BYTES,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4287
					     &tp->RxPhyAddr, GFP_KERNEL);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4288
	if (!tp->RxDescArray)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4289
		goto err_free_tx_0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4290
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4291
	retval = rtl8169_init_ring(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4292
	if (retval < 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4293
		goto err_free_rx_1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4294
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4295
	INIT_DELAYED_WORK(&tp->task, NULL);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4296
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4297
	smp_mb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4298
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4299
	rtl_request_firmware(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4300
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4301
	retval = request_irq(dev->irq, rtl8169_interrupt,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4302
			     (tp->features & RTL_FEATURE_MSI) ? 0 : IRQF_SHARED,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4303
			     dev->name, dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4304
	if (retval < 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4305
		goto err_release_fw_2;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4306
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4307
	napi_enable(&tp->napi);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4308
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4309
	rtl8169_init_phy(dev, tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4310
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4311
	rtl8169_set_features(dev, dev->features);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4312
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4313
	rtl_pll_power_up(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4314
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4315
	rtl_hw_start(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4316
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4317
	tp->saved_wolopts = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4318
	pm_runtime_put_noidle(&pdev->dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4319
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4320
	rtl8169_check_link_status(dev, tp, ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4321
out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4322
	return retval;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4323
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4324
err_release_fw_2:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4325
	rtl_release_firmware(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4326
	rtl8169_rx_clear(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4327
err_free_rx_1:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4328
	dma_free_coherent(&pdev->dev, R8169_RX_RING_BYTES, tp->RxDescArray,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4329
			  tp->RxPhyAddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4330
	tp->RxDescArray = NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4331
err_free_tx_0:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4332
	dma_free_coherent(&pdev->dev, R8169_TX_RING_BYTES, tp->TxDescArray,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4333
			  tp->TxPhyAddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4334
	tp->TxDescArray = NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4335
err_pm_runtime_put:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4336
	pm_runtime_put_noidle(&pdev->dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4337
	goto out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4338
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4339
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4340
static void rtl_rx_close(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4341
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4342
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4343
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4344
	RTL_W32(RxConfig, RTL_R32(RxConfig) & ~RX_CONFIG_ACCEPT_MASK);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4345
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4346
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4347
static void rtl8169_hw_reset(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4348
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4349
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4350
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4351
	/* Disable interrupts */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4352
	rtl8169_irq_mask_and_ack(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4353
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4354
	rtl_rx_close(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4355
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4356
	if (tp->mac_version == RTL_GIGA_MAC_VER_27 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4357
	    tp->mac_version == RTL_GIGA_MAC_VER_28 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4358
	    tp->mac_version == RTL_GIGA_MAC_VER_31) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4359
		while (RTL_R8(TxPoll) & NPQ)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4360
			udelay(20);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4361
	} else if (tp->mac_version == RTL_GIGA_MAC_VER_34 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4362
	           tp->mac_version == RTL_GIGA_MAC_VER_35 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4363
	           tp->mac_version == RTL_GIGA_MAC_VER_36) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4364
		RTL_W8(ChipCmd, RTL_R8(ChipCmd) | StopReq);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4365
		while (!(RTL_R32(TxConfig) & TXCFG_EMPTY))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4366
			udelay(100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4367
	} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4368
		RTL_W8(ChipCmd, RTL_R8(ChipCmd) | StopReq);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4369
		udelay(100);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4370
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4371
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4372
	rtl_hw_reset(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4373
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4374
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4375
static void rtl_set_rx_tx_config_registers(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4376
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4377
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4378
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4379
	/* Set DMA burst size and Interframe Gap Time */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4380
	RTL_W32(TxConfig, (TX_DMA_BURST << TxDMAShift) |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4381
		(InterFrameGap << TxInterFrameGapShift));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4382
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4383
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4384
static void rtl_hw_start(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4385
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4386
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4387
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4388
	tp->hw_start(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4389
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4390
	netif_start_queue(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4391
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4392
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4393
static void rtl_set_rx_tx_desc_registers(struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4394
					 void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4395
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4396
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4397
	 * Magic spell: some iop3xx ARM board needs the TxDescAddrHigh
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4398
	 * register to be written before TxDescAddrLow to work.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4399
	 * Switching from MMIO to I/O access fixes the issue as well.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4400
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4401
	RTL_W32(TxDescStartAddrHigh, ((u64) tp->TxPhyAddr) >> 32);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4402
	RTL_W32(TxDescStartAddrLow, ((u64) tp->TxPhyAddr) & DMA_BIT_MASK(32));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4403
	RTL_W32(RxDescAddrHigh, ((u64) tp->RxPhyAddr) >> 32);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4404
	RTL_W32(RxDescAddrLow, ((u64) tp->RxPhyAddr) & DMA_BIT_MASK(32));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4405
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4406
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4407
static u16 rtl_rw_cpluscmd(void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4408
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4409
	u16 cmd;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4410
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4411
	cmd = RTL_R16(CPlusCmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4412
	RTL_W16(CPlusCmd, cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4413
	return cmd;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4414
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4415
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4416
static void rtl_set_rx_max_size(void __iomem *ioaddr, unsigned int rx_buf_sz)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4417
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4418
	/* Low hurts. Let's disable the filtering. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4419
	RTL_W16(RxMaxSize, rx_buf_sz + 1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4420
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4421
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4422
static void rtl8169_set_magic_reg(void __iomem *ioaddr, unsigned mac_version)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4423
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4424
	static const struct rtl_cfg2_info {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4425
		u32 mac_version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4426
		u32 clk;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4427
		u32 val;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4428
	} cfg2_info [] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4429
		{ RTL_GIGA_MAC_VER_05, PCI_Clock_33MHz, 0x000fff00 }, // 8110SCd
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4430
		{ RTL_GIGA_MAC_VER_05, PCI_Clock_66MHz, 0x000fffff },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4431
		{ RTL_GIGA_MAC_VER_06, PCI_Clock_33MHz, 0x00ffff00 }, // 8110SCe
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4432
		{ RTL_GIGA_MAC_VER_06, PCI_Clock_66MHz, 0x00ffffff }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4433
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4434
	const struct rtl_cfg2_info *p = cfg2_info;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4435
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4436
	u32 clk;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4437
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4438
	clk = RTL_R8(Config2) & PCI_Clock_66MHz;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4439
	for (i = 0; i < ARRAY_SIZE(cfg2_info); i++, p++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4440
		if ((p->mac_version == mac_version) && (p->clk == clk)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4441
			RTL_W32(0x7c, p->val);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4442
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4443
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4444
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4445
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4446
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4447
static void rtl_hw_start_8169(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4448
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4449
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4450
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4451
	struct pci_dev *pdev = tp->pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4452
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4453
	if (tp->mac_version == RTL_GIGA_MAC_VER_05) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4454
		RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) | PCIMulRW);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4455
		pci_write_config_byte(pdev, PCI_CACHE_LINE_SIZE, 0x08);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4456
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4457
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4458
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4459
	if (tp->mac_version == RTL_GIGA_MAC_VER_01 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4460
	    tp->mac_version == RTL_GIGA_MAC_VER_02 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4461
	    tp->mac_version == RTL_GIGA_MAC_VER_03 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4462
	    tp->mac_version == RTL_GIGA_MAC_VER_04)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4463
		RTL_W8(ChipCmd, CmdTxEnb | CmdRxEnb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4464
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4465
	rtl_init_rxcfg(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4466
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4467
	RTL_W8(EarlyTxThres, NoEarlyTx);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4468
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4469
	rtl_set_rx_max_size(ioaddr, rx_buf_sz);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4470
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4471
	if (tp->mac_version == RTL_GIGA_MAC_VER_01 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4472
	    tp->mac_version == RTL_GIGA_MAC_VER_02 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4473
	    tp->mac_version == RTL_GIGA_MAC_VER_03 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4474
	    tp->mac_version == RTL_GIGA_MAC_VER_04)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4475
		rtl_set_rx_tx_config_registers(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4476
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4477
	tp->cp_cmd |= rtl_rw_cpluscmd(ioaddr) | PCIMulRW;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4478
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4479
	if (tp->mac_version == RTL_GIGA_MAC_VER_02 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4480
	    tp->mac_version == RTL_GIGA_MAC_VER_03) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4481
		dprintk("Set MAC Reg C+CR Offset 0xE0. "
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4482
			"Bit-3 and bit-14 MUST be 1\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4483
		tp->cp_cmd |= (1 << 14);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4484
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4485
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4486
	RTL_W16(CPlusCmd, tp->cp_cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4487
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4488
	rtl8169_set_magic_reg(ioaddr, tp->mac_version);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4489
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4490
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4491
	 * Undocumented corner. Supposedly:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4492
	 * (TxTimer << 12) | (TxPackets << 8) | (RxTimer << 4) | RxPackets
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4493
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4494
	RTL_W16(IntrMitigate, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4495
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4496
	rtl_set_rx_tx_desc_registers(tp, ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4497
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4498
	if (tp->mac_version != RTL_GIGA_MAC_VER_01 &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4499
	    tp->mac_version != RTL_GIGA_MAC_VER_02 &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4500
	    tp->mac_version != RTL_GIGA_MAC_VER_03 &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4501
	    tp->mac_version != RTL_GIGA_MAC_VER_04) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4502
		RTL_W8(ChipCmd, CmdTxEnb | CmdRxEnb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4503
		rtl_set_rx_tx_config_registers(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4504
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4505
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4506
	RTL_W8(Cfg9346, Cfg9346_Lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4507
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4508
	/* Initially a 10 us delay. Turned it into a PCI commit. - FR */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4509
	RTL_R8(IntrMask);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4510
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4511
	RTL_W32(RxMissed, 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4512
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4513
	rtl_set_rx_mode(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4514
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4515
	/* no early-rx interrupts */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4516
	RTL_W16(MultiIntr, RTL_R16(MultiIntr) & 0xF000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4517
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4518
	/* Enable all known interrupts by setting the interrupt mask. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4519
	RTL_W16(IntrMask, tp->intr_event);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4520
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4521
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4522
static void rtl_csi_access_enable(void __iomem *ioaddr, u32 bits)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4523
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4524
	u32 csi;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4525
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4526
	csi = rtl_csi_read(ioaddr, 0x070c) & 0x00ffffff;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4527
	rtl_csi_write(ioaddr, 0x070c, csi | bits);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4528
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4529
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4530
static void rtl_csi_access_enable_1(void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4531
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4532
	rtl_csi_access_enable(ioaddr, 0x17000000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4533
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4534
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4535
static void rtl_csi_access_enable_2(void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4536
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4537
	rtl_csi_access_enable(ioaddr, 0x27000000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4538
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4539
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4540
struct ephy_info {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4541
	unsigned int offset;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4542
	u16 mask;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4543
	u16 bits;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4544
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4545
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4546
static void rtl_ephy_init(void __iomem *ioaddr, const struct ephy_info *e, int len)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4547
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4548
	u16 w;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4549
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4550
	while (len-- > 0) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4551
		w = (rtl_ephy_read(ioaddr, e->offset) & ~e->mask) | e->bits;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4552
		rtl_ephy_write(ioaddr, e->offset, w);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4553
		e++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4554
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4555
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4556
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4557
static void rtl_disable_clock_request(struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4558
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4559
	int cap = pci_pcie_cap(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4560
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4561
	if (cap) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4562
		u16 ctl;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4563
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4564
		pci_read_config_word(pdev, cap + PCI_EXP_LNKCTL, &ctl);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4565
		ctl &= ~PCI_EXP_LNKCTL_CLKREQ_EN;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4566
		pci_write_config_word(pdev, cap + PCI_EXP_LNKCTL, ctl);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4567
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4568
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4569
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4570
static void rtl_enable_clock_request(struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4571
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4572
	int cap = pci_pcie_cap(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4573
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4574
	if (cap) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4575
		u16 ctl;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4576
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4577
		pci_read_config_word(pdev, cap + PCI_EXP_LNKCTL, &ctl);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4578
		ctl |= PCI_EXP_LNKCTL_CLKREQ_EN;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4579
		pci_write_config_word(pdev, cap + PCI_EXP_LNKCTL, ctl);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4580
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4581
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4582
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4583
#define R8168_CPCMD_QUIRK_MASK (\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4584
	EnableBist | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4585
	Mac_dbgo_oe | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4586
	Force_half_dup | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4587
	Force_rxflow_en | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4588
	Force_txflow_en | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4589
	Cxpl_dbg_sel | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4590
	ASF | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4591
	PktCntrDisable | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4592
	Mac_dbgo_sel)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4593
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4594
static void rtl_hw_start_8168bb(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4595
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4596
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4597
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4598
	RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) & ~R8168_CPCMD_QUIRK_MASK);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4599
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4600
	rtl_tx_performance_tweak(pdev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4601
		(0x5 << MAX_READ_REQUEST_SHIFT) | PCI_EXP_DEVCTL_NOSNOOP_EN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4602
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4603
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4604
static void rtl_hw_start_8168bef(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4605
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4606
	rtl_hw_start_8168bb(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4607
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4608
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4609
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4610
	RTL_W8(Config4, RTL_R8(Config4) & ~(1 << 0));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4611
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4612
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4613
static void __rtl_hw_start_8168cp(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4614
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4615
	RTL_W8(Config1, RTL_R8(Config1) | Speed_down);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4616
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4617
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4618
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4619
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4620
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4621
	rtl_disable_clock_request(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4622
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4623
	RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) & ~R8168_CPCMD_QUIRK_MASK);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4624
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4625
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4626
static void rtl_hw_start_8168cp_1(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4627
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4628
	static const struct ephy_info e_info_8168cp[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4629
		{ 0x01, 0,	0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4630
		{ 0x02, 0x0800,	0x1000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4631
		{ 0x03, 0,	0x0042 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4632
		{ 0x06, 0x0080,	0x0000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4633
		{ 0x07, 0,	0x2000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4634
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4635
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4636
	rtl_csi_access_enable_2(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4637
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4638
	rtl_ephy_init(ioaddr, e_info_8168cp, ARRAY_SIZE(e_info_8168cp));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4639
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4640
	__rtl_hw_start_8168cp(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4641
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4642
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4643
static void rtl_hw_start_8168cp_2(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4644
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4645
	rtl_csi_access_enable_2(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4646
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4647
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4648
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4649
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4650
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4651
	RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) & ~R8168_CPCMD_QUIRK_MASK);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4652
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4653
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4654
static void rtl_hw_start_8168cp_3(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4655
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4656
	rtl_csi_access_enable_2(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4657
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4658
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4659
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4660
	/* Magic. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4661
	RTL_W8(DBG_REG, 0x20);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4662
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4663
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4664
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4665
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4666
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4667
	RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) & ~R8168_CPCMD_QUIRK_MASK);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4668
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4669
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4670
static void rtl_hw_start_8168c_1(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4671
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4672
	static const struct ephy_info e_info_8168c_1[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4673
		{ 0x02, 0x0800,	0x1000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4674
		{ 0x03, 0,	0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4675
		{ 0x06, 0x0080,	0x0000 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4676
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4677
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4678
	rtl_csi_access_enable_2(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4679
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4680
	RTL_W8(DBG_REG, 0x06 | FIX_NAK_1 | FIX_NAK_2);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4681
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4682
	rtl_ephy_init(ioaddr, e_info_8168c_1, ARRAY_SIZE(e_info_8168c_1));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4683
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4684
	__rtl_hw_start_8168cp(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4685
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4686
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4687
static void rtl_hw_start_8168c_2(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4688
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4689
	static const struct ephy_info e_info_8168c_2[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4690
		{ 0x01, 0,	0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4691
		{ 0x03, 0x0400,	0x0220 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4692
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4693
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4694
	rtl_csi_access_enable_2(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4695
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4696
	rtl_ephy_init(ioaddr, e_info_8168c_2, ARRAY_SIZE(e_info_8168c_2));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4697
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4698
	__rtl_hw_start_8168cp(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4699
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4700
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4701
static void rtl_hw_start_8168c_3(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4702
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4703
	rtl_hw_start_8168c_2(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4704
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4705
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4706
static void rtl_hw_start_8168c_4(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4707
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4708
	rtl_csi_access_enable_2(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4709
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4710
	__rtl_hw_start_8168cp(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4711
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4712
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4713
static void rtl_hw_start_8168d(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4714
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4715
	rtl_csi_access_enable_2(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4716
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4717
	rtl_disable_clock_request(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4718
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4719
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4720
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4721
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4722
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4723
	RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) & ~R8168_CPCMD_QUIRK_MASK);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4724
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4725
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4726
static void rtl_hw_start_8168dp(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4727
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4728
	rtl_csi_access_enable_1(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4729
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4730
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4731
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4732
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4733
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4734
	rtl_disable_clock_request(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4735
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4736
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4737
static void rtl_hw_start_8168d_4(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4738
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4739
	static const struct ephy_info e_info_8168d_4[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4740
		{ 0x0b, ~0,	0x48 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4741
		{ 0x19, 0x20,	0x50 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4742
		{ 0x0c, ~0,	0x20 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4743
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4744
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4745
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4746
	rtl_csi_access_enable_1(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4747
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4748
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4749
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4750
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4751
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4752
	for (i = 0; i < ARRAY_SIZE(e_info_8168d_4); i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4753
		const struct ephy_info *e = e_info_8168d_4 + i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4754
		u16 w;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4755
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4756
		w = rtl_ephy_read(ioaddr, e->offset);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4757
		rtl_ephy_write(ioaddr, 0x03, (w & e->mask) | e->bits);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4758
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4759
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4760
	rtl_enable_clock_request(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4761
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4762
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4763
static void rtl_hw_start_8168e_1(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4764
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4765
	static const struct ephy_info e_info_8168e_1[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4766
		{ 0x00, 0x0200,	0x0100 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4767
		{ 0x00, 0x0000,	0x0004 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4768
		{ 0x06, 0x0002,	0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4769
		{ 0x06, 0x0000,	0x0030 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4770
		{ 0x07, 0x0000,	0x2000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4771
		{ 0x00, 0x0000,	0x0020 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4772
		{ 0x03, 0x5800,	0x2000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4773
		{ 0x03, 0x0000,	0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4774
		{ 0x01, 0x0800,	0x1000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4775
		{ 0x07, 0x0000,	0x4000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4776
		{ 0x1e, 0x0000,	0x2000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4777
		{ 0x19, 0xffff,	0xfe6c },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4778
		{ 0x0a, 0x0000,	0x0040 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4779
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4780
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4781
	rtl_csi_access_enable_2(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4782
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4783
	rtl_ephy_init(ioaddr, e_info_8168e_1, ARRAY_SIZE(e_info_8168e_1));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4784
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4785
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4786
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4787
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4788
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4789
	rtl_disable_clock_request(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4790
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4791
	/* Reset tx FIFO pointer */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4792
	RTL_W32(MISC, RTL_R32(MISC) | TXPLA_RST);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4793
	RTL_W32(MISC, RTL_R32(MISC) & ~TXPLA_RST);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4794
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4795
	RTL_W8(Config5, RTL_R8(Config5) & ~Spi_en);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4796
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4797
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4798
static void rtl_hw_start_8168e_2(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4799
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4800
	static const struct ephy_info e_info_8168e_2[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4801
		{ 0x09, 0x0000,	0x0080 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4802
		{ 0x19, 0x0000,	0x0224 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4803
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4804
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4805
	rtl_csi_access_enable_1(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4806
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4807
	rtl_ephy_init(ioaddr, e_info_8168e_2, ARRAY_SIZE(e_info_8168e_2));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4808
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4809
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4810
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4811
	rtl_eri_write(ioaddr, 0xc0, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4812
	rtl_eri_write(ioaddr, 0xb8, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4813
	rtl_eri_write(ioaddr, 0xc8, ERIAR_MASK_1111, 0x00100002, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4814
	rtl_eri_write(ioaddr, 0xe8, ERIAR_MASK_1111, 0x00100006, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4815
	rtl_eri_write(ioaddr, 0xcc, ERIAR_MASK_1111, 0x00000050, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4816
	rtl_eri_write(ioaddr, 0xd0, ERIAR_MASK_1111, 0x07ff0060, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4817
	rtl_w1w0_eri(ioaddr, 0x1b0, ERIAR_MASK_0001, 0x10, 0x00, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4818
	rtl_w1w0_eri(ioaddr, 0x0d4, ERIAR_MASK_0011, 0x0c00, 0xff00,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4819
		     ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4820
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4821
	RTL_W8(MaxTxPacketSize, EarlySize);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4822
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4823
	rtl_disable_clock_request(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4824
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4825
	RTL_W32(TxConfig, RTL_R32(TxConfig) | TXCFG_AUTO_FIFO);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4826
	RTL_W8(MCU, RTL_R8(MCU) & ~NOW_IS_OOB);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4827
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4828
	/* Adjust EEE LED frequency */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4829
	RTL_W8(EEE_LED, RTL_R8(EEE_LED) & ~0x07);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4830
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4831
	RTL_W8(DLLPR, RTL_R8(DLLPR) | PFM_EN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4832
	RTL_W32(MISC, RTL_R32(MISC) | PWM_EN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4833
	RTL_W8(Config5, RTL_R8(Config5) & ~Spi_en);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4834
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4835
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4836
static void rtl_hw_start_8168f_1(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4837
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4838
	static const struct ephy_info e_info_8168f_1[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4839
		{ 0x06, 0x00c0,	0x0020 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4840
		{ 0x08, 0x0001,	0x0002 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4841
		{ 0x09, 0x0000,	0x0080 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4842
		{ 0x19, 0x0000,	0x0224 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4843
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4844
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4845
	rtl_csi_access_enable_1(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4846
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4847
	rtl_ephy_init(ioaddr, e_info_8168f_1, ARRAY_SIZE(e_info_8168f_1));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4848
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4849
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4850
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4851
	rtl_eri_write(ioaddr, 0xc0, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4852
	rtl_eri_write(ioaddr, 0xb8, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4853
	rtl_eri_write(ioaddr, 0xc8, ERIAR_MASK_1111, 0x00100002, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4854
	rtl_eri_write(ioaddr, 0xe8, ERIAR_MASK_1111, 0x00100006, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4855
	rtl_w1w0_eri(ioaddr, 0xdc, ERIAR_MASK_0001, 0x00, 0x01, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4856
	rtl_w1w0_eri(ioaddr, 0xdc, ERIAR_MASK_0001, 0x01, 0x00, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4857
	rtl_w1w0_eri(ioaddr, 0x1b0, ERIAR_MASK_0001, 0x10, 0x00, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4858
	rtl_w1w0_eri(ioaddr, 0x1d0, ERIAR_MASK_0001, 0x10, 0x00, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4859
	rtl_eri_write(ioaddr, 0xcc, ERIAR_MASK_1111, 0x00000050, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4860
	rtl_eri_write(ioaddr, 0xd0, ERIAR_MASK_1111, 0x00000060, ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4861
	rtl_w1w0_eri(ioaddr, 0x0d4, ERIAR_MASK_0011, 0x0c00, 0xff00,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4862
		     ERIAR_EXGMAC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4863
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4864
	RTL_W8(MaxTxPacketSize, EarlySize);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4865
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4866
	rtl_disable_clock_request(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4867
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4868
	RTL_W32(TxConfig, RTL_R32(TxConfig) | TXCFG_AUTO_FIFO);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4869
	RTL_W8(MCU, RTL_R8(MCU) & ~NOW_IS_OOB);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4870
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4871
	/* Adjust EEE LED frequency */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4872
	RTL_W8(EEE_LED, RTL_R8(EEE_LED) & ~0x07);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4873
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4874
	RTL_W8(DLLPR, RTL_R8(DLLPR) | PFM_EN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4875
	RTL_W32(MISC, RTL_R32(MISC) | PWM_EN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4876
	RTL_W8(Config5, RTL_R8(Config5) & ~Spi_en);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4877
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4878
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4879
static void rtl_hw_start_8168(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4880
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4881
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4882
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4883
	struct pci_dev *pdev = tp->pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4884
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4885
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4886
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4887
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4888
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4889
	rtl_set_rx_max_size(ioaddr, rx_buf_sz);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4890
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4891
	tp->cp_cmd |= RTL_R16(CPlusCmd) | PktCntrDisable | INTT_1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4892
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4893
	RTL_W16(CPlusCmd, tp->cp_cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4894
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4895
	RTL_W16(IntrMitigate, 0x5151);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4896
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4897
	/* Work around for RxFIFO overflow. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4898
	if (tp->mac_version == RTL_GIGA_MAC_VER_11) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4899
		tp->intr_event |= RxFIFOOver | PCSTimeout;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4900
		tp->intr_event &= ~RxOverflow;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4901
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4902
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4903
	rtl_set_rx_tx_desc_registers(tp, ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4904
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4905
	rtl_set_rx_mode(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4906
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4907
	RTL_W32(TxConfig, (TX_DMA_BURST << TxDMAShift) |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4908
		(InterFrameGap << TxInterFrameGapShift));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4909
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4910
	RTL_R8(IntrMask);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4911
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4912
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4913
	case RTL_GIGA_MAC_VER_11:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4914
		rtl_hw_start_8168bb(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4915
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4916
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4917
	case RTL_GIGA_MAC_VER_12:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4918
	case RTL_GIGA_MAC_VER_17:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4919
		rtl_hw_start_8168bef(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4920
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4921
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4922
	case RTL_GIGA_MAC_VER_18:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4923
		rtl_hw_start_8168cp_1(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4924
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4925
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4926
	case RTL_GIGA_MAC_VER_19:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4927
		rtl_hw_start_8168c_1(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4928
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4929
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4930
	case RTL_GIGA_MAC_VER_20:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4931
		rtl_hw_start_8168c_2(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4932
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4933
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4934
	case RTL_GIGA_MAC_VER_21:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4935
		rtl_hw_start_8168c_3(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4936
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4937
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4938
	case RTL_GIGA_MAC_VER_22:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4939
		rtl_hw_start_8168c_4(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4940
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4941
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4942
	case RTL_GIGA_MAC_VER_23:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4943
		rtl_hw_start_8168cp_2(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4944
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4945
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4946
	case RTL_GIGA_MAC_VER_24:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4947
		rtl_hw_start_8168cp_3(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4948
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4949
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4950
	case RTL_GIGA_MAC_VER_25:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4951
	case RTL_GIGA_MAC_VER_26:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4952
	case RTL_GIGA_MAC_VER_27:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4953
		rtl_hw_start_8168d(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4954
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4955
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4956
	case RTL_GIGA_MAC_VER_28:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4957
		rtl_hw_start_8168d_4(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4958
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4959
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4960
	case RTL_GIGA_MAC_VER_31:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4961
		rtl_hw_start_8168dp(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4962
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4963
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4964
	case RTL_GIGA_MAC_VER_32:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4965
	case RTL_GIGA_MAC_VER_33:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4966
		rtl_hw_start_8168e_1(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4967
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4968
	case RTL_GIGA_MAC_VER_34:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4969
		rtl_hw_start_8168e_2(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4970
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4971
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4972
	case RTL_GIGA_MAC_VER_35:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4973
	case RTL_GIGA_MAC_VER_36:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4974
		rtl_hw_start_8168f_1(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4975
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4976
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4977
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4978
		printk(KERN_ERR PFX "%s: unknown chipset (mac_version = %d).\n",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4979
			dev->name, tp->mac_version);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4980
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4981
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4982
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4983
	RTL_W8(ChipCmd, CmdTxEnb | CmdRxEnb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4984
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4985
	RTL_W8(Cfg9346, Cfg9346_Lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4986
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4987
	RTL_W16(MultiIntr, RTL_R16(MultiIntr) & 0xF000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4988
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4989
	RTL_W16(IntrMask, tp->intr_event);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4990
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4991
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4992
#define R810X_CPCMD_QUIRK_MASK (\
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4993
	EnableBist | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4994
	Mac_dbgo_oe | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4995
	Force_half_dup | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4996
	Force_rxflow_en | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4997
	Force_txflow_en | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4998
	Cxpl_dbg_sel | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4999
	ASF | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5000
	PktCntrDisable | \
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5001
	Mac_dbgo_sel)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5002
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5003
static void rtl_hw_start_8102e_1(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5004
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5005
	static const struct ephy_info e_info_8102e_1[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5006
		{ 0x01,	0, 0x6e65 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5007
		{ 0x02,	0, 0x091f },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5008
		{ 0x03,	0, 0xc2f9 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5009
		{ 0x06,	0, 0xafb5 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5010
		{ 0x07,	0, 0x0e00 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5011
		{ 0x19,	0, 0xec80 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5012
		{ 0x01,	0, 0x2e65 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5013
		{ 0x01,	0, 0x6e65 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5014
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5015
	u8 cfg1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5016
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5017
	rtl_csi_access_enable_2(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5018
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5019
	RTL_W8(DBG_REG, FIX_NAK_1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5020
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5021
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5022
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5023
	RTL_W8(Config1,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5024
	       LEDS1 | LEDS0 | Speed_down | MEMMAP | IOMAP | VPD | PMEnable);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5025
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5026
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5027
	cfg1 = RTL_R8(Config1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5028
	if ((cfg1 & LEDS0) && (cfg1 & LEDS1))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5029
		RTL_W8(Config1, cfg1 & ~LEDS0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5030
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5031
	rtl_ephy_init(ioaddr, e_info_8102e_1, ARRAY_SIZE(e_info_8102e_1));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5032
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5033
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5034
static void rtl_hw_start_8102e_2(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5035
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5036
	rtl_csi_access_enable_2(ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5037
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5038
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5039
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5040
	RTL_W8(Config1, MEMMAP | IOMAP | VPD | PMEnable);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5041
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5042
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5043
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5044
static void rtl_hw_start_8102e_3(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5045
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5046
	rtl_hw_start_8102e_2(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5047
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5048
	rtl_ephy_write(ioaddr, 0x03, 0xc2f9);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5049
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5050
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5051
static void rtl_hw_start_8105e_1(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5052
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5053
	static const struct ephy_info e_info_8105e_1[] = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5054
		{ 0x07,	0, 0x4000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5055
		{ 0x19,	0, 0x0200 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5056
		{ 0x19,	0, 0x0020 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5057
		{ 0x1e,	0, 0x2000 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5058
		{ 0x03,	0, 0x0001 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5059
		{ 0x19,	0, 0x0100 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5060
		{ 0x19,	0, 0x0004 },
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5061
		{ 0x0a,	0, 0x0020 }
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5062
	};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5063
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5064
	/* Force LAN exit from ASPM if Rx/Tx are not idle */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5065
	RTL_W32(FuncEvent, RTL_R32(FuncEvent) | 0x002800);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5066
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5067
	/* Disable Early Tally Counter */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5068
	RTL_W32(FuncEvent, RTL_R32(FuncEvent) & ~0x010000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5069
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5070
	RTL_W8(MCU, RTL_R8(MCU) | EN_NDP | EN_OOB_RESET);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5071
	RTL_W8(DLLPR, RTL_R8(DLLPR) | PFM_EN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5072
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5073
	rtl_ephy_init(ioaddr, e_info_8105e_1, ARRAY_SIZE(e_info_8105e_1));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5074
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5075
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5076
static void rtl_hw_start_8105e_2(void __iomem *ioaddr, struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5077
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5078
	rtl_hw_start_8105e_1(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5079
	rtl_ephy_write(ioaddr, 0x1e, rtl_ephy_read(ioaddr, 0x1e) | 0x8000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5080
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5081
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5082
static void rtl_hw_start_8101(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5083
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5084
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5085
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5086
	struct pci_dev *pdev = tp->pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5087
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5088
	if (tp->mac_version >= RTL_GIGA_MAC_VER_30) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5089
		tp->intr_event &= ~RxFIFOOver;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5090
		tp->napi_event &= ~RxFIFOOver;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5091
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5092
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5093
	if (tp->mac_version == RTL_GIGA_MAC_VER_13 ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5094
	    tp->mac_version == RTL_GIGA_MAC_VER_16) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5095
		int cap = pci_pcie_cap(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5096
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5097
		if (cap) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5098
			pci_write_config_word(pdev, cap + PCI_EXP_DEVCTL,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5099
					      PCI_EXP_DEVCTL_NOSNOOP_EN);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5100
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5101
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5102
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5103
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5104
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5105
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5106
	case RTL_GIGA_MAC_VER_07:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5107
		rtl_hw_start_8102e_1(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5108
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5109
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5110
	case RTL_GIGA_MAC_VER_08:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5111
		rtl_hw_start_8102e_3(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5112
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5113
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5114
	case RTL_GIGA_MAC_VER_09:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5115
		rtl_hw_start_8102e_2(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5116
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5117
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5118
	case RTL_GIGA_MAC_VER_29:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5119
		rtl_hw_start_8105e_1(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5120
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5121
	case RTL_GIGA_MAC_VER_30:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5122
		rtl_hw_start_8105e_2(ioaddr, pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5123
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5124
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5125
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5126
	RTL_W8(Cfg9346, Cfg9346_Lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5127
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5128
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5129
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5130
	rtl_set_rx_max_size(ioaddr, rx_buf_sz);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5131
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5132
	tp->cp_cmd &= ~R810X_CPCMD_QUIRK_MASK;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5133
	RTL_W16(CPlusCmd, tp->cp_cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5134
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5135
	RTL_W16(IntrMitigate, 0x0000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5136
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5137
	rtl_set_rx_tx_desc_registers(tp, ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5138
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5139
	RTL_W8(ChipCmd, CmdTxEnb | CmdRxEnb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5140
	rtl_set_rx_tx_config_registers(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5141
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5142
	RTL_R8(IntrMask);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5143
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5144
	rtl_set_rx_mode(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5145
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5146
	RTL_W16(MultiIntr, RTL_R16(MultiIntr) & 0xf000);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5147
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5148
	RTL_W16(IntrMask, tp->intr_event);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5149
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5150
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5151
static int rtl8169_change_mtu(struct net_device *dev, int new_mtu)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5152
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5153
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5154
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5155
	if (new_mtu < ETH_ZLEN ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5156
	    new_mtu > rtl_chip_infos[tp->mac_version].jumbo_max)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5157
		return -EINVAL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5158
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5159
	if (new_mtu > ETH_DATA_LEN)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5160
		rtl_hw_jumbo_enable(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5161
	else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5162
		rtl_hw_jumbo_disable(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5163
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5164
	dev->mtu = new_mtu;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5165
	netdev_update_features(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5166
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5167
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5168
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5169
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5170
static inline void rtl8169_make_unusable_by_asic(struct RxDesc *desc)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5171
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5172
	desc->addr = cpu_to_le64(0x0badbadbadbadbadull);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5173
	desc->opts1 &= ~cpu_to_le32(DescOwn | RsvdMask);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5174
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5175
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5176
static void rtl8169_free_rx_databuff(struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5177
				     void **data_buff, struct RxDesc *desc)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5178
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5179
	dma_unmap_single(&tp->pci_dev->dev, le64_to_cpu(desc->addr), rx_buf_sz,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5180
			 DMA_FROM_DEVICE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5181
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5182
	kfree(*data_buff);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5183
	*data_buff = NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5184
	rtl8169_make_unusable_by_asic(desc);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5185
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5186
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5187
static inline void rtl8169_mark_to_asic(struct RxDesc *desc, u32 rx_buf_sz)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5188
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5189
	u32 eor = le32_to_cpu(desc->opts1) & RingEnd;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5190
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5191
	desc->opts1 = cpu_to_le32(DescOwn | eor | rx_buf_sz);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5192
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5193
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5194
static inline void rtl8169_map_to_asic(struct RxDesc *desc, dma_addr_t mapping,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5195
				       u32 rx_buf_sz)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5196
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5197
	desc->addr = cpu_to_le64(mapping);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5198
	wmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5199
	rtl8169_mark_to_asic(desc, rx_buf_sz);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5200
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5201
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5202
static inline void *rtl8169_align(void *data)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5203
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5204
	return (void *)ALIGN((long)data, 16);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5205
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5206
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5207
static struct sk_buff *rtl8169_alloc_rx_data(struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5208
					     struct RxDesc *desc)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5209
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5210
	void *data;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5211
	dma_addr_t mapping;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5212
	struct device *d = &tp->pci_dev->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5213
	struct net_device *dev = tp->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5214
	int node = dev->dev.parent ? dev_to_node(dev->dev.parent) : -1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5215
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5216
	data = kmalloc_node(rx_buf_sz, GFP_KERNEL, node);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5217
	if (!data)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5218
		return NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5219
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5220
	if (rtl8169_align(data) != data) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5221
		kfree(data);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5222
		data = kmalloc_node(rx_buf_sz + 15, GFP_KERNEL, node);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5223
		if (!data)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5224
			return NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5225
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5226
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5227
	mapping = dma_map_single(d, rtl8169_align(data), rx_buf_sz,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5228
				 DMA_FROM_DEVICE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5229
	if (unlikely(dma_mapping_error(d, mapping))) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5230
		if (net_ratelimit())
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5231
			netif_err(tp, drv, tp->dev, "Failed to map RX DMA!\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5232
		goto err_out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5233
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5234
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5235
	rtl8169_map_to_asic(desc, mapping, rx_buf_sz);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5236
	return data;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5237
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5238
err_out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5239
	kfree(data);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5240
	return NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5241
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5242
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5243
static void rtl8169_rx_clear(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5244
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5245
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5246
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5247
	for (i = 0; i < NUM_RX_DESC; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5248
		if (tp->Rx_databuff[i]) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5249
			rtl8169_free_rx_databuff(tp, tp->Rx_databuff + i,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5250
					    tp->RxDescArray + i);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5251
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5252
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5253
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5254
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5255
static inline void rtl8169_mark_as_last_descriptor(struct RxDesc *desc)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5256
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5257
	desc->opts1 |= cpu_to_le32(RingEnd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5258
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5259
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5260
static int rtl8169_rx_fill(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5261
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5262
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5263
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5264
	for (i = 0; i < NUM_RX_DESC; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5265
		void *data;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5266
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5267
		if (tp->Rx_databuff[i])
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5268
			continue;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5269
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5270
		data = rtl8169_alloc_rx_data(tp, tp->RxDescArray + i);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5271
		if (!data) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5272
			rtl8169_make_unusable_by_asic(tp->RxDescArray + i);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5273
			goto err_out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5274
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5275
		tp->Rx_databuff[i] = data;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5276
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5277
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5278
	rtl8169_mark_as_last_descriptor(tp->RxDescArray + NUM_RX_DESC - 1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5279
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5280
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5281
err_out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5282
	rtl8169_rx_clear(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5283
	return -ENOMEM;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5284
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5285
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5286
static int rtl8169_init_ring(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5287
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5288
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5289
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5290
	rtl8169_init_ring_indexes(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5291
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5292
	memset(tp->tx_skb, 0x0, NUM_TX_DESC * sizeof(struct ring_info));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5293
	memset(tp->Rx_databuff, 0x0, NUM_RX_DESC * sizeof(void *));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5294
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5295
	return rtl8169_rx_fill(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5296
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5297
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5298
static void rtl8169_unmap_tx_skb(struct device *d, struct ring_info *tx_skb,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5299
				 struct TxDesc *desc)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5300
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5301
	unsigned int len = tx_skb->len;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5302
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5303
	dma_unmap_single(d, le64_to_cpu(desc->addr), len, DMA_TO_DEVICE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5304
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5305
	desc->opts1 = 0x00;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5306
	desc->opts2 = 0x00;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5307
	desc->addr = 0x00;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5308
	tx_skb->len = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5309
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5310
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5311
static void rtl8169_tx_clear_range(struct rtl8169_private *tp, u32 start,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5312
				   unsigned int n)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5313
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5314
	unsigned int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5315
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5316
	for (i = 0; i < n; i++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5317
		unsigned int entry = (start + i) % NUM_TX_DESC;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5318
		struct ring_info *tx_skb = tp->tx_skb + entry;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5319
		unsigned int len = tx_skb->len;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5320
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5321
		if (len) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5322
			struct sk_buff *skb = tx_skb->skb;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5323
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5324
			rtl8169_unmap_tx_skb(&tp->pci_dev->dev, tx_skb,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5325
					     tp->TxDescArray + entry);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5326
			if (skb) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5327
				tp->dev->stats.tx_dropped++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5328
				dev_kfree_skb(skb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5329
				tx_skb->skb = NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5330
			}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5331
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5332
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5333
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5334
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5335
static void rtl8169_tx_clear(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5336
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5337
	rtl8169_tx_clear_range(tp, tp->dirty_tx, NUM_TX_DESC);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5338
	tp->cur_tx = tp->dirty_tx = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5339
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5340
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5341
static void rtl8169_schedule_work(struct net_device *dev, work_func_t task)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5342
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5343
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5344
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5345
	PREPARE_DELAYED_WORK(&tp->task, task);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5346
	schedule_delayed_work(&tp->task, 4);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5347
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5348
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5349
static void rtl8169_wait_for_quiescence(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5350
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5351
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5352
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5353
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5354
	synchronize_irq(dev->irq);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5355
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5356
	/* Wait for any pending NAPI task to complete */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5357
	napi_disable(&tp->napi);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5358
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5359
	rtl8169_irq_mask_and_ack(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5360
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5361
	tp->intr_mask = 0xffff;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5362
	RTL_W16(IntrMask, tp->intr_event);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5363
	napi_enable(&tp->napi);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5364
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5365
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5366
static void rtl8169_reinit_task(struct work_struct *work)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5367
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5368
	struct rtl8169_private *tp =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5369
		container_of(work, struct rtl8169_private, task.work);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5370
	struct net_device *dev = tp->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5371
	int ret;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5372
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5373
	rtnl_lock();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5374
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5375
	if (!netif_running(dev))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5376
		goto out_unlock;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5377
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5378
	rtl8169_wait_for_quiescence(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5379
	rtl8169_close(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5380
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5381
	ret = rtl8169_open(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5382
	if (unlikely(ret < 0)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5383
		if (net_ratelimit())
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5384
			netif_err(tp, drv, dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5385
				  "reinit failure (status = %d). Rescheduling\n",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5386
				  ret);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5387
		rtl8169_schedule_work(dev, rtl8169_reinit_task);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5388
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5389
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5390
out_unlock:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5391
	rtnl_unlock();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5392
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5393
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5394
static void rtl8169_reset_task(struct work_struct *work)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5395
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5396
	struct rtl8169_private *tp =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5397
		container_of(work, struct rtl8169_private, task.work);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5398
	struct net_device *dev = tp->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5399
	int i;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5400
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5401
	rtnl_lock();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5402
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5403
	if (!netif_running(dev))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5404
		goto out_unlock;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5405
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5406
	rtl8169_hw_reset(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5407
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5408
	rtl8169_wait_for_quiescence(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5409
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5410
	for (i = 0; i < NUM_RX_DESC; i++)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5411
		rtl8169_mark_to_asic(tp->RxDescArray + i, rx_buf_sz);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5412
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5413
	rtl8169_tx_clear(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5414
	rtl8169_init_ring_indexes(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5415
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5416
	rtl_hw_start(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5417
	netif_wake_queue(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5418
	rtl8169_check_link_status(dev, tp, tp->mmio_addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5419
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5420
out_unlock:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5421
	rtnl_unlock();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5422
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5423
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5424
static void rtl8169_tx_timeout(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5425
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5426
	rtl8169_schedule_work(dev, rtl8169_reset_task);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5427
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5428
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5429
static int rtl8169_xmit_frags(struct rtl8169_private *tp, struct sk_buff *skb,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5430
			      u32 *opts)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5431
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5432
	struct skb_shared_info *info = skb_shinfo(skb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5433
	unsigned int cur_frag, entry;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5434
	struct TxDesc * uninitialized_var(txd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5435
	struct device *d = &tp->pci_dev->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5436
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5437
	entry = tp->cur_tx;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5438
	for (cur_frag = 0; cur_frag < info->nr_frags; cur_frag++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5439
		const skb_frag_t *frag = info->frags + cur_frag;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5440
		dma_addr_t mapping;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5441
		u32 status, len;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5442
		void *addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5443
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5444
		entry = (entry + 1) % NUM_TX_DESC;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5445
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5446
		txd = tp->TxDescArray + entry;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5447
		len = skb_frag_size(frag);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5448
		addr = skb_frag_address(frag);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5449
		mapping = dma_map_single(d, addr, len, DMA_TO_DEVICE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5450
		if (unlikely(dma_mapping_error(d, mapping))) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5451
			if (net_ratelimit())
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5452
				netif_err(tp, drv, tp->dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5453
					  "Failed to map TX fragments DMA!\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5454
			goto err_out;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5455
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5456
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5457
		/* Anti gcc 2.95.3 bugware (sic) */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5458
		status = opts[0] | len |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5459
			(RingEnd * !((entry + 1) % NUM_TX_DESC));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5460
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5461
		txd->opts1 = cpu_to_le32(status);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5462
		txd->opts2 = cpu_to_le32(opts[1]);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5463
		txd->addr = cpu_to_le64(mapping);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5464
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5465
		tp->tx_skb[entry].len = len;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5466
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5467
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5468
	if (cur_frag) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5469
		tp->tx_skb[entry].skb = skb;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5470
		txd->opts1 |= cpu_to_le32(LastFrag);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5471
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5472
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5473
	return cur_frag;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5474
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5475
err_out:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5476
	rtl8169_tx_clear_range(tp, tp->cur_tx + 1, cur_frag);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5477
	return -EIO;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5478
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5479
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5480
static inline void rtl8169_tso_csum(struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5481
				    struct sk_buff *skb, u32 *opts)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5482
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5483
	const struct rtl_tx_desc_info *info = tx_desc_info + tp->txd_version;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5484
	u32 mss = skb_shinfo(skb)->gso_size;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5485
	int offset = info->opts_offset;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5486
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5487
	if (mss) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5488
		opts[0] |= TD_LSO;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5489
		opts[offset] |= min(mss, TD_MSS_MAX) << info->mss_shift;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5490
	} else if (skb->ip_summed == CHECKSUM_PARTIAL) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5491
		const struct iphdr *ip = ip_hdr(skb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5492
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5493
		if (ip->protocol == IPPROTO_TCP)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5494
			opts[offset] |= info->checksum.tcp;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5495
		else if (ip->protocol == IPPROTO_UDP)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5496
			opts[offset] |= info->checksum.udp;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5497
		else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5498
			WARN_ON_ONCE(1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5499
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5500
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5501
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5502
static netdev_tx_t rtl8169_start_xmit(struct sk_buff *skb,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5503
				      struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5504
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5505
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5506
	unsigned int entry = tp->cur_tx % NUM_TX_DESC;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5507
	struct TxDesc *txd = tp->TxDescArray + entry;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5508
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5509
	struct device *d = &tp->pci_dev->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5510
	dma_addr_t mapping;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5511
	u32 status, len;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5512
	u32 opts[2];
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5513
	int frags;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5514
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5515
	if (unlikely(TX_BUFFS_AVAIL(tp) < skb_shinfo(skb)->nr_frags)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5516
		netif_err(tp, drv, dev, "BUG! Tx Ring full when queue awake!\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5517
		goto err_stop_0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5518
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5519
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5520
	if (unlikely(le32_to_cpu(txd->opts1) & DescOwn))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5521
		goto err_stop_0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5522
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5523
	len = skb_headlen(skb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5524
	mapping = dma_map_single(d, skb->data, len, DMA_TO_DEVICE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5525
	if (unlikely(dma_mapping_error(d, mapping))) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5526
		if (net_ratelimit())
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5527
			netif_err(tp, drv, dev, "Failed to map TX DMA!\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5528
		goto err_dma_0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5529
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5530
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5531
	tp->tx_skb[entry].len = len;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5532
	txd->addr = cpu_to_le64(mapping);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5533
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5534
	opts[1] = cpu_to_le32(rtl8169_tx_vlan_tag(tp, skb));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5535
	opts[0] = DescOwn;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5536
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5537
	rtl8169_tso_csum(tp, skb, opts);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5538
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5539
	frags = rtl8169_xmit_frags(tp, skb, opts);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5540
	if (frags < 0)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5541
		goto err_dma_1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5542
	else if (frags)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5543
		opts[0] |= FirstFrag;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5544
	else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5545
		opts[0] |= FirstFrag | LastFrag;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5546
		tp->tx_skb[entry].skb = skb;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5547
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5548
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5549
	txd->opts2 = cpu_to_le32(opts[1]);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5550
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5551
	wmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5552
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5553
	/* Anti gcc 2.95.3 bugware (sic) */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5554
	status = opts[0] | len | (RingEnd * !((entry + 1) % NUM_TX_DESC));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5555
	txd->opts1 = cpu_to_le32(status);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5556
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5557
	tp->cur_tx += frags + 1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5558
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5559
	wmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5560
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5561
	RTL_W8(TxPoll, NPQ);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5562
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5563
	if (TX_BUFFS_AVAIL(tp) < MAX_SKB_FRAGS) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5564
		netif_stop_queue(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5565
		smp_rmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5566
		if (TX_BUFFS_AVAIL(tp) >= MAX_SKB_FRAGS)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5567
			netif_wake_queue(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5568
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5569
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5570
	return NETDEV_TX_OK;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5571
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5572
err_dma_1:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5573
	rtl8169_unmap_tx_skb(d, tp->tx_skb + entry, txd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5574
err_dma_0:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5575
	dev_kfree_skb(skb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5576
	dev->stats.tx_dropped++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5577
	return NETDEV_TX_OK;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5578
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5579
err_stop_0:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5580
	netif_stop_queue(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5581
	dev->stats.tx_dropped++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5582
	return NETDEV_TX_BUSY;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5583
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5584
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5585
static void rtl8169_pcierr_interrupt(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5586
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5587
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5588
	struct pci_dev *pdev = tp->pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5589
	u16 pci_status, pci_cmd;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5590
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5591
	pci_read_config_word(pdev, PCI_COMMAND, &pci_cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5592
	pci_read_config_word(pdev, PCI_STATUS, &pci_status);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5593
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5594
	netif_err(tp, intr, dev, "PCI error (cmd = 0x%04x, status = 0x%04x)\n",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5595
		  pci_cmd, pci_status);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5596
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5597
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5598
	 * The recovery sequence below admits a very elaborated explanation:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5599
	 * - it seems to work;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5600
	 * - I did not see what else could be done;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5601
	 * - it makes iop3xx happy.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5602
	 *
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5603
	 * Feel free to adjust to your needs.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5604
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5605
	if (pdev->broken_parity_status)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5606
		pci_cmd &= ~PCI_COMMAND_PARITY;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5607
	else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5608
		pci_cmd |= PCI_COMMAND_SERR | PCI_COMMAND_PARITY;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5609
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5610
	pci_write_config_word(pdev, PCI_COMMAND, pci_cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5611
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5612
	pci_write_config_word(pdev, PCI_STATUS,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5613
		pci_status & (PCI_STATUS_DETECTED_PARITY |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5614
		PCI_STATUS_SIG_SYSTEM_ERROR | PCI_STATUS_REC_MASTER_ABORT |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5615
		PCI_STATUS_REC_TARGET_ABORT | PCI_STATUS_SIG_TARGET_ABORT));
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5616
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5617
	/* The infamous DAC f*ckup only happens at boot time */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5618
	if ((tp->cp_cmd & PCIDAC) && !tp->dirty_rx && !tp->cur_rx) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5619
		void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5620
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5621
		netif_info(tp, intr, dev, "disabling PCI DAC\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5622
		tp->cp_cmd &= ~PCIDAC;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5623
		RTL_W16(CPlusCmd, tp->cp_cmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5624
		dev->features &= ~NETIF_F_HIGHDMA;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5625
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5626
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5627
	rtl8169_hw_reset(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5628
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5629
	rtl8169_schedule_work(dev, rtl8169_reinit_task);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5630
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5631
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5632
static void rtl8169_tx_interrupt(struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5633
				 struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5634
				 void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5635
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5636
	unsigned int dirty_tx, tx_left;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5637
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5638
	dirty_tx = tp->dirty_tx;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5639
	smp_rmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5640
	tx_left = tp->cur_tx - dirty_tx;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5641
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5642
	while (tx_left > 0) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5643
		unsigned int entry = dirty_tx % NUM_TX_DESC;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5644
		struct ring_info *tx_skb = tp->tx_skb + entry;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5645
		u32 status;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5646
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5647
		rmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5648
		status = le32_to_cpu(tp->TxDescArray[entry].opts1);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5649
		if (status & DescOwn)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5650
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5651
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5652
		rtl8169_unmap_tx_skb(&tp->pci_dev->dev, tx_skb,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5653
				     tp->TxDescArray + entry);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5654
		if (status & LastFrag) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5655
			dev->stats.tx_packets++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5656
			dev->stats.tx_bytes += tx_skb->skb->len;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5657
			dev_kfree_skb(tx_skb->skb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5658
			tx_skb->skb = NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5659
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5660
		dirty_tx++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5661
		tx_left--;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5662
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5663
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5664
	if (tp->dirty_tx != dirty_tx) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5665
		tp->dirty_tx = dirty_tx;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5666
		smp_wmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5667
		if (netif_queue_stopped(dev) &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5668
		    (TX_BUFFS_AVAIL(tp) >= MAX_SKB_FRAGS)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5669
			netif_wake_queue(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5670
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5671
		/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5672
		 * 8168 hack: TxPoll requests are lost when the Tx packets are
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5673
		 * too close. Let's kick an extra TxPoll request when a burst
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5674
		 * of start_xmit activity is detected (if it is not detected,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5675
		 * it is slow enough). -- FR
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5676
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5677
		smp_rmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5678
		if (tp->cur_tx != dirty_tx)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5679
			RTL_W8(TxPoll, NPQ);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5680
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5681
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5682
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5683
static inline int rtl8169_fragmented_frame(u32 status)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5684
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5685
	return (status & (FirstFrag | LastFrag)) != (FirstFrag | LastFrag);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5686
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5687
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5688
static inline void rtl8169_rx_csum(struct sk_buff *skb, u32 opts1)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5689
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5690
	u32 status = opts1 & RxProtoMask;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5691
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5692
	if (((status == RxProtoTCP) && !(opts1 & TCPFail)) ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5693
	    ((status == RxProtoUDP) && !(opts1 & UDPFail)))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5694
		skb->ip_summed = CHECKSUM_UNNECESSARY;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5695
	else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5696
		skb_checksum_none_assert(skb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5697
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5698
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5699
static struct sk_buff *rtl8169_try_rx_copy(void *data,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5700
					   struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5701
					   int pkt_size,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5702
					   dma_addr_t addr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5703
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5704
	struct sk_buff *skb;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5705
	struct device *d = &tp->pci_dev->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5706
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5707
	data = rtl8169_align(data);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5708
	dma_sync_single_for_cpu(d, addr, pkt_size, DMA_FROM_DEVICE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5709
	prefetch(data);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5710
	skb = netdev_alloc_skb_ip_align(tp->dev, pkt_size);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5711
	if (skb)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5712
		memcpy(skb->data, data, pkt_size);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5713
	dma_sync_single_for_device(d, addr, pkt_size, DMA_FROM_DEVICE);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5714
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5715
	return skb;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5716
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5717
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5718
static int rtl8169_rx_interrupt(struct net_device *dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5719
				struct rtl8169_private *tp,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5720
				void __iomem *ioaddr, u32 budget)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5721
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5722
	unsigned int cur_rx, rx_left;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5723
	unsigned int count;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5724
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5725
	cur_rx = tp->cur_rx;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5726
	rx_left = NUM_RX_DESC + tp->dirty_rx - cur_rx;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5727
	rx_left = min(rx_left, budget);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5728
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5729
	for (; rx_left > 0; rx_left--, cur_rx++) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5730
		unsigned int entry = cur_rx % NUM_RX_DESC;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5731
		struct RxDesc *desc = tp->RxDescArray + entry;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5732
		u32 status;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5733
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5734
		rmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5735
		status = le32_to_cpu(desc->opts1) & tp->opts1_mask;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5736
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5737
		if (status & DescOwn)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5738
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5739
		if (unlikely(status & RxRES)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5740
			netif_info(tp, rx_err, dev, "Rx ERROR. status = %08x\n",
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5741
				   status);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5742
			dev->stats.rx_errors++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5743
			if (status & (RxRWT | RxRUNT))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5744
				dev->stats.rx_length_errors++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5745
			if (status & RxCRC)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5746
				dev->stats.rx_crc_errors++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5747
			if (status & RxFOVF) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5748
				rtl8169_schedule_work(dev, rtl8169_reset_task);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5749
				dev->stats.rx_fifo_errors++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5750
			}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5751
			rtl8169_mark_to_asic(desc, rx_buf_sz);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5752
		} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5753
			struct sk_buff *skb;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5754
			dma_addr_t addr = le64_to_cpu(desc->addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5755
			int pkt_size = (status & 0x00003fff) - 4;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5756
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5757
			/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5758
			 * The driver does not support incoming fragmented
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5759
			 * frames. They are seen as a symptom of over-mtu
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5760
			 * sized frames.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5761
			 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5762
			if (unlikely(rtl8169_fragmented_frame(status))) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5763
				dev->stats.rx_dropped++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5764
				dev->stats.rx_length_errors++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5765
				rtl8169_mark_to_asic(desc, rx_buf_sz);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5766
				continue;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5767
			}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5768
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5769
			skb = rtl8169_try_rx_copy(tp->Rx_databuff[entry],
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5770
						  tp, pkt_size, addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5771
			rtl8169_mark_to_asic(desc, rx_buf_sz);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5772
			if (!skb) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5773
				dev->stats.rx_dropped++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5774
				continue;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5775
			}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5776
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5777
			rtl8169_rx_csum(skb, status);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5778
			skb_put(skb, pkt_size);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5779
			skb->protocol = eth_type_trans(skb, dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5780
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5781
			rtl8169_rx_vlan_tag(desc, skb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5782
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5783
			napi_gro_receive(&tp->napi, skb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5784
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5785
			dev->stats.rx_bytes += pkt_size;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5786
			dev->stats.rx_packets++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5787
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5788
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5789
		/* Work around for AMD plateform. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5790
		if ((desc->opts2 & cpu_to_le32(0xfffe000)) &&
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5791
		    (tp->mac_version == RTL_GIGA_MAC_VER_05)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5792
			desc->opts2 = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5793
			cur_rx++;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5794
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5795
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5796
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5797
	count = cur_rx - tp->cur_rx;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5798
	tp->cur_rx = cur_rx;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5799
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5800
	tp->dirty_rx += count;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5801
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5802
	return count;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5803
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5804
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5805
static irqreturn_t rtl8169_interrupt(int irq, void *dev_instance)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5806
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5807
	struct net_device *dev = dev_instance;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5808
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5809
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5810
	int handled = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5811
	int status;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5812
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5813
	/* loop handling interrupts until we have no new ones or
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5814
	 * we hit a invalid/hotplug case.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5815
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5816
	status = RTL_R16(IntrStatus);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5817
	while (status && status != 0xffff) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5818
		status &= tp->intr_event;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5819
		if (!status)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5820
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5821
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5822
		handled = 1;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5823
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5824
		/* Handle all of the error cases first. These will reset
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5825
		 * the chip, so just exit the loop.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5826
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5827
		if (unlikely(!netif_running(dev))) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5828
			rtl8169_hw_reset(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5829
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5830
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5831
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5832
		if (unlikely(status & RxFIFOOver)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5833
			switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5834
			/* Work around for rx fifo overflow */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5835
			case RTL_GIGA_MAC_VER_11:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5836
				netif_stop_queue(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5837
				rtl8169_tx_timeout(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5838
				goto done;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5839
			default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5840
				break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5841
			}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5842
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5843
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5844
		if (unlikely(status & SYSErr)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5845
			rtl8169_pcierr_interrupt(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5846
			break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5847
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5848
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5849
		if (status & LinkChg)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5850
			__rtl8169_check_link_status(dev, tp, ioaddr, true);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5851
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5852
		/* We need to see the lastest version of tp->intr_mask to
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5853
		 * avoid ignoring an MSI interrupt and having to wait for
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5854
		 * another event which may never come.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5855
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5856
		smp_rmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5857
		if (status & tp->intr_mask & tp->napi_event) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5858
			RTL_W16(IntrMask, tp->intr_event & ~tp->napi_event);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5859
			tp->intr_mask = ~tp->napi_event;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5860
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5861
			if (likely(napi_schedule_prep(&tp->napi)))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5862
				__napi_schedule(&tp->napi);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5863
			else
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5864
				netif_info(tp, intr, dev,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5865
					   "interrupt %04x in poll\n", status);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5866
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5867
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5868
		/* We only get a new MSI interrupt when all active irq
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5869
		 * sources on the chip have been acknowledged. So, ack
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5870
		 * everything we've seen and check if new sources have become
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5871
		 * active to avoid blocking all interrupts from the chip.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5872
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5873
		RTL_W16(IntrStatus,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5874
			(status & RxFIFOOver) ? (status | RxOverflow) : status);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5875
		status = RTL_R16(IntrStatus);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5876
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5877
done:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5878
	return IRQ_RETVAL(handled);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5879
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5880
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5881
static int rtl8169_poll(struct napi_struct *napi, int budget)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5882
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5883
	struct rtl8169_private *tp = container_of(napi, struct rtl8169_private, napi);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5884
	struct net_device *dev = tp->dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5885
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5886
	int work_done;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5887
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5888
	work_done = rtl8169_rx_interrupt(dev, tp, ioaddr, (u32) budget);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5889
	rtl8169_tx_interrupt(dev, tp, ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5890
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5891
	if (work_done < budget) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5892
		napi_complete(napi);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5893
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5894
		/* We need for force the visibility of tp->intr_mask
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5895
		 * for other CPUs, as we can loose an MSI interrupt
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5896
		 * and potentially wait for a retransmit timeout if we don't.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5897
		 * The posted write to IntrMask is safe, as it will
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5898
		 * eventually make it to the chip and we won't loose anything
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5899
		 * until it does.
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5900
		 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5901
		tp->intr_mask = 0xffff;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5902
		wmb();
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5903
		RTL_W16(IntrMask, tp->intr_event);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5904
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5905
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5906
	return work_done;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5907
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5908
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5909
static void rtl8169_rx_missed(struct net_device *dev, void __iomem *ioaddr)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5910
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5911
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5912
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5913
	if (tp->mac_version > RTL_GIGA_MAC_VER_06)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5914
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5915
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5916
	dev->stats.rx_missed_errors += (RTL_R32(RxMissed) & 0xffffff);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5917
	RTL_W32(RxMissed, 0);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5918
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5919
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5920
static void rtl8169_down(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5921
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5922
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5923
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5924
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5925
	del_timer_sync(&tp->timer);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5926
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5927
	netif_stop_queue(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5928
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5929
	napi_disable(&tp->napi);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5930
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5931
	spin_lock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5932
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5933
	rtl8169_hw_reset(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5934
	/*
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5935
	 * At this point device interrupts can not be enabled in any function,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5936
	 * as netif_running is not true (rtl8169_interrupt, rtl8169_reset_task,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5937
	 * rtl8169_reinit_task) and napi is disabled (rtl8169_poll).
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5938
	 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5939
	rtl8169_rx_missed(dev, ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5940
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5941
	spin_unlock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5942
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5943
	synchronize_irq(dev->irq);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5944
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5945
	/* Give a racing hard_start_xmit a few cycles to complete. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5946
	synchronize_sched();  /* FIXME: should this be synchronize_irq()? */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5947
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5948
	rtl8169_tx_clear(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5949
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5950
	rtl8169_rx_clear(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5951
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5952
	rtl_pll_power_down(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5953
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5954
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5955
static int rtl8169_close(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5956
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5957
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5958
	struct pci_dev *pdev = tp->pci_dev;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5959
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5960
	pm_runtime_get_sync(&pdev->dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5961
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5962
	/* Update counters before going down */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5963
	rtl8169_update_counters(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5964
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5965
	rtl8169_down(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5966
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5967
	free_irq(dev->irq, dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5968
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5969
	dma_free_coherent(&pdev->dev, R8169_RX_RING_BYTES, tp->RxDescArray,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5970
			  tp->RxPhyAddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5971
	dma_free_coherent(&pdev->dev, R8169_TX_RING_BYTES, tp->TxDescArray,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5972
			  tp->TxPhyAddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5973
	tp->TxDescArray = NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5974
	tp->RxDescArray = NULL;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5975
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5976
	pm_runtime_put_sync(&pdev->dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5977
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5978
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5979
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5980
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5981
static void rtl_set_rx_mode(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5982
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5983
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5984
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5985
	unsigned long flags;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5986
	u32 mc_filter[2];	/* Multicast hash filter */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5987
	int rx_mode;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5988
	u32 tmp = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5989
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5990
	if (dev->flags & IFF_PROMISC) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5991
		/* Unconditionally log net taps. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5992
		netif_notice(tp, link, dev, "Promiscuous mode enabled\n");
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5993
		rx_mode =
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5994
		    AcceptBroadcast | AcceptMulticast | AcceptMyPhys |
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5995
		    AcceptAllPhys;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5996
		mc_filter[1] = mc_filter[0] = 0xffffffff;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5997
	} else if ((netdev_mc_count(dev) > multicast_filter_limit) ||
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5998
		   (dev->flags & IFF_ALLMULTI)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5999
		/* Too many to filter perfectly -- accept all multicasts. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6000
		rx_mode = AcceptBroadcast | AcceptMulticast | AcceptMyPhys;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6001
		mc_filter[1] = mc_filter[0] = 0xffffffff;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6002
	} else {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6003
		struct netdev_hw_addr *ha;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6004
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6005
		rx_mode = AcceptBroadcast | AcceptMyPhys;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6006
		mc_filter[1] = mc_filter[0] = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6007
		netdev_for_each_mc_addr(ha, dev) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6008
			int bit_nr = ether_crc(ETH_ALEN, ha->addr) >> 26;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6009
			mc_filter[bit_nr >> 5] |= 1 << (bit_nr & 31);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6010
			rx_mode |= AcceptMulticast;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6011
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6012
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6013
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6014
	spin_lock_irqsave(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6015
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6016
	tmp = (RTL_R32(RxConfig) & ~RX_CONFIG_ACCEPT_MASK) | rx_mode;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6017
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6018
	if (tp->mac_version > RTL_GIGA_MAC_VER_06) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6019
		u32 data = mc_filter[0];
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6020
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6021
		mc_filter[0] = swab32(mc_filter[1]);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6022
		mc_filter[1] = swab32(data);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6023
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6024
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6025
	RTL_W32(MAR0 + 4, mc_filter[1]);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6026
	RTL_W32(MAR0 + 0, mc_filter[0]);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6027
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6028
	RTL_W32(RxConfig, tmp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6029
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6030
	spin_unlock_irqrestore(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6031
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6032
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6033
/**
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6034
 *  rtl8169_get_stats - Get rtl8169 read/write statistics
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6035
 *  @dev: The Ethernet Device to get statistics for
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6036
 *
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6037
 *  Get TX/RX statistics for rtl8169
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6038
 */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6039
static struct net_device_stats *rtl8169_get_stats(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6040
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6041
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6042
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6043
	unsigned long flags;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6044
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6045
	if (netif_running(dev)) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6046
		spin_lock_irqsave(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6047
		rtl8169_rx_missed(dev, ioaddr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6048
		spin_unlock_irqrestore(&tp->lock, flags);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6049
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6050
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6051
	return &dev->stats;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6052
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6053
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6054
static void rtl8169_net_suspend(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6055
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6056
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6057
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6058
	if (!netif_running(dev))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6059
		return;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6060
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6061
	rtl_pll_power_down(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6062
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6063
	netif_device_detach(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6064
	netif_stop_queue(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6065
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6066
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6067
#ifdef CONFIG_PM
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6068
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6069
static int rtl8169_suspend(struct device *device)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6070
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6071
	struct pci_dev *pdev = to_pci_dev(device);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6072
	struct net_device *dev = pci_get_drvdata(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6073
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6074
	rtl8169_net_suspend(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6075
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6076
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6077
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6078
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6079
static void __rtl8169_resume(struct net_device *dev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6080
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6081
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6082
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6083
	netif_device_attach(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6084
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6085
	rtl_pll_power_up(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6086
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6087
	rtl8169_schedule_work(dev, rtl8169_reset_task);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6088
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6089
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6090
static int rtl8169_resume(struct device *device)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6091
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6092
	struct pci_dev *pdev = to_pci_dev(device);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6093
	struct net_device *dev = pci_get_drvdata(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6094
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6095
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6096
	rtl8169_init_phy(dev, tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6097
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6098
	if (netif_running(dev))
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6099
		__rtl8169_resume(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6100
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6101
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6102
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6103
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6104
static int rtl8169_runtime_suspend(struct device *device)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6105
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6106
	struct pci_dev *pdev = to_pci_dev(device);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6107
	struct net_device *dev = pci_get_drvdata(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6108
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6109
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6110
	if (!tp->TxDescArray)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6111
		return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6112
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6113
	spin_lock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6114
	tp->saved_wolopts = __rtl8169_get_wol(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6115
	__rtl8169_set_wol(tp, WAKE_ANY);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6116
	spin_unlock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6117
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6118
	rtl8169_net_suspend(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6119
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6120
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6121
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6122
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6123
static int rtl8169_runtime_resume(struct device *device)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6124
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6125
	struct pci_dev *pdev = to_pci_dev(device);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6126
	struct net_device *dev = pci_get_drvdata(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6127
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6128
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6129
	if (!tp->TxDescArray)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6130
		return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6131
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6132
	spin_lock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6133
	__rtl8169_set_wol(tp, tp->saved_wolopts);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6134
	tp->saved_wolopts = 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6135
	spin_unlock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6136
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6137
	rtl8169_init_phy(dev, tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6138
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6139
	__rtl8169_resume(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6140
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6141
	return 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6142
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6143
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6144
static int rtl8169_runtime_idle(struct device *device)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6145
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6146
	struct pci_dev *pdev = to_pci_dev(device);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6147
	struct net_device *dev = pci_get_drvdata(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6148
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6149
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6150
	return tp->TxDescArray ? -EBUSY : 0;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6151
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6152
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6153
static const struct dev_pm_ops rtl8169_pm_ops = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6154
	.suspend		= rtl8169_suspend,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6155
	.resume			= rtl8169_resume,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6156
	.freeze			= rtl8169_suspend,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6157
	.thaw			= rtl8169_resume,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6158
	.poweroff		= rtl8169_suspend,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6159
	.restore		= rtl8169_resume,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6160
	.runtime_suspend	= rtl8169_runtime_suspend,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6161
	.runtime_resume		= rtl8169_runtime_resume,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6162
	.runtime_idle		= rtl8169_runtime_idle,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6163
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6164
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6165
#define RTL8169_PM_OPS	(&rtl8169_pm_ops)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6166
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6167
#else /* !CONFIG_PM */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6168
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6169
#define RTL8169_PM_OPS	NULL
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6170
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6171
#endif /* !CONFIG_PM */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6172
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6173
static void rtl_wol_shutdown_quirk(struct rtl8169_private *tp)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6174
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6175
	void __iomem *ioaddr = tp->mmio_addr;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6176
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6177
	/* WoL fails with 8168b when the receiver is disabled. */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6178
	switch (tp->mac_version) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6179
	case RTL_GIGA_MAC_VER_11:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6180
	case RTL_GIGA_MAC_VER_12:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6181
	case RTL_GIGA_MAC_VER_17:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6182
		pci_clear_master(tp->pci_dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6183
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6184
		RTL_W8(ChipCmd, CmdRxEnb);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6185
		/* PCI commit */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6186
		RTL_R8(ChipCmd);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6187
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6188
	default:
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6189
		break;
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6190
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6191
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6192
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6193
static void rtl_shutdown(struct pci_dev *pdev)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6194
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6195
	struct net_device *dev = pci_get_drvdata(pdev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6196
	struct rtl8169_private *tp = netdev_priv(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6197
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6198
	rtl8169_net_suspend(dev);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6199
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6200
	/* Restore original MAC address */
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6201
	rtl_rar_set(tp, dev->perm_addr);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6202
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6203
	spin_lock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6204
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6205
	rtl8169_hw_reset(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6206
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6207
	spin_unlock_irq(&tp->lock);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6208
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6209
	if (system_state == SYSTEM_POWER_OFF) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6210
		if (__rtl8169_get_wol(tp) & WAKE_ANY) {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6211
			rtl_wol_suspend_quirk(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6212
			rtl_wol_shutdown_quirk(tp);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6213
		}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6214
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6215
		pci_wake_from_d3(pdev, true);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6216
		pci_set_power_state(pdev, PCI_D3hot);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6217
	}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6218
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6219
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6220
static struct pci_driver rtl8169_pci_driver = {
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6221
	.name		= MODULENAME,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6222
	.id_table	= rtl8169_pci_tbl,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6223
	.probe		= rtl8169_init_one,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6224
	.remove		= __devexit_p(rtl8169_remove_one),
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6225
	.shutdown	= rtl_shutdown,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6226
	.driver.pm	= RTL8169_PM_OPS,
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6227
};
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6228
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6229
static int __init rtl8169_init_module(void)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6230
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6231
	return pci_register_driver(&rtl8169_pci_driver);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6232
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6233
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6234
static void __exit rtl8169_cleanup_module(void)
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6235
{
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6236
	pci_unregister_driver(&rtl8169_pci_driver);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6237
}
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6238
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6239
module_init(rtl8169_init_module);
5cbd10256e12 Added r8169 driver for kernel 3.2 (thanks to J. Kunz).
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6240
module_exit(rtl8169_cleanup_module);