devices/r8169-3.6-ethercat.c
author Patrick Bruenn <p.bruenn@beckhoff.com>
Tue, 12 Apr 2016 11:17:36 +0200
branchstable-1.5
changeset 2654 b3f6b3e5ef29
parent 2582 87e502828b3f
permissions -rw-r--r--
devices/ccat: revert "limit rx processing to one frame per poll"

revert "limit rx processing to one frame per poll", which caused etherlab
frame timeouts in setups with more than one frame per cycle.
2547
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     1
/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     2
 * r8169.c: RealTek 8169/8168/8101 ethernet driver.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     3
 *
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     4
 * Copyright (c) 2002 ShuChen <shuchen@realtek.com.tw>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     5
 * Copyright (c) 2003 - 2007 Francois Romieu <romieu@fr.zoreil.com>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     6
 * Copyright (c) a lot of people too. Please respect their work.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     7
 *
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     8
 * See MAINTAINERS file for support contact information.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
     9
 *
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    10
 * vim: noexpandtab
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    11
 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    12
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    13
#include <linux/module.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    14
#include <linux/moduleparam.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    15
#include <linux/pci.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    16
#include <linux/netdevice.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    17
#include <linux/etherdevice.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    18
#include <linux/delay.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    19
#include <linux/ethtool.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    20
#include <linux/mii.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    21
#include <linux/if_vlan.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    22
#include <linux/crc32.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    23
#include <linux/in.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    24
#include <linux/ip.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    25
#include <linux/tcp.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    26
#include <linux/init.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    27
#include <linux/interrupt.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    28
#include <linux/dma-mapping.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    29
#include <linux/pm_runtime.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    30
#include <linux/firmware.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    31
#include <linux/pci-aspm.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    32
#include <linux/prefetch.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    33
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    34
#include <asm/io.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    35
#include <asm/irq.h>
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    36
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    37
#include "../globals.h"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    38
#include "ecdev.h"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    39
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    40
#define RTL8169_VERSION "2.3LK-NAPI"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    41
#define MODULENAME "ec_r8169"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    42
#define PFX MODULENAME ": "
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    43
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    44
#define FIRMWARE_8168D_1	"rtl_nic/rtl8168d-1.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    45
#define FIRMWARE_8168D_2	"rtl_nic/rtl8168d-2.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    46
#define FIRMWARE_8168E_1	"rtl_nic/rtl8168e-1.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    47
#define FIRMWARE_8168E_2	"rtl_nic/rtl8168e-2.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    48
#define FIRMWARE_8168E_3	"rtl_nic/rtl8168e-3.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    49
#define FIRMWARE_8168F_1	"rtl_nic/rtl8168f-1.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    50
#define FIRMWARE_8168F_2	"rtl_nic/rtl8168f-2.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    51
#define FIRMWARE_8105E_1	"rtl_nic/rtl8105e-1.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    52
#define FIRMWARE_8402_1		"rtl_nic/rtl8402-1.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    53
#define FIRMWARE_8411_1		"rtl_nic/rtl8411-1.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    54
#define FIRMWARE_8106E_1	"rtl_nic/rtl8106e-1.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    55
#define FIRMWARE_8168G_1	"rtl_nic/rtl8168g-1.fw"
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    56
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    57
#ifdef RTL8169_DEBUG
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    58
#define assert(expr) \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    59
	if (!(expr)) {					\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    60
		printk( "Assertion failed! %s,%s,%s,line=%d\n",	\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    61
		#expr,__FILE__,__func__,__LINE__);		\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    62
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    63
#define dprintk(fmt, args...) \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    64
	do { printk(KERN_DEBUG PFX fmt, ## args); } while (0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    65
#else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    66
#define assert(expr) do {} while (0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    67
#define dprintk(fmt, args...)	do {} while (0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    68
#endif /* RTL8169_DEBUG */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    69
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    70
#define R8169_MSG_DEFAULT \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    71
	(NETIF_MSG_DRV | NETIF_MSG_PROBE | NETIF_MSG_IFUP | NETIF_MSG_IFDOWN)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    72
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    73
#define TX_SLOTS_AVAIL(tp) \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    74
	(tp->dirty_tx + NUM_TX_DESC - tp->cur_tx)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    75
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    76
/* A skbuff with nr_frags needs nr_frags+1 entries in the tx queue */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    77
#define TX_FRAGS_READY_FOR(tp,nr_frags) \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    78
	(TX_SLOTS_AVAIL(tp) >= (nr_frags + 1))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    79
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    80
/* Maximum number of multicast addresses to filter (vs. Rx-all-multicast).
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    81
   The RTL chips use a 64 element hash table based on the Ethernet CRC. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    82
static const int multicast_filter_limit = 32;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    83
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    84
#define MAX_READ_REQUEST_SHIFT	12
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    85
#define TX_DMA_BURST	7	/* Maximum PCI burst, '7' is unlimited */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    86
#define SafeMtu		0x1c20	/* ... actually life sucks beyond ~7k */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    87
#define InterFrameGap	0x03	/* 3 means InterFrameGap = the shortest one */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    88
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    89
#define R8169_REGS_SIZE		256
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    90
#define R8169_NAPI_WEIGHT	64
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    91
#define NUM_TX_DESC	64	/* Number of Tx descriptor registers */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    92
#define NUM_RX_DESC	256	/* Number of Rx descriptor registers */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    93
#define RX_BUF_SIZE	1536	/* Rx Buffer size */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    94
#define R8169_TX_RING_BYTES	(NUM_TX_DESC * sizeof(struct TxDesc))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    95
#define R8169_RX_RING_BYTES	(NUM_RX_DESC * sizeof(struct RxDesc))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    96
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    97
#define RTL8169_TX_TIMEOUT	(6*HZ)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    98
#define RTL8169_PHY_TIMEOUT	(10*HZ)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
    99
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   100
#define RTL_EEPROM_SIG		cpu_to_le32(0x8129)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   101
#define RTL_EEPROM_SIG_MASK	cpu_to_le32(0xffff)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   102
#define RTL_EEPROM_SIG_ADDR	0x0000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   103
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   104
/* write/read MMIO register */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   105
#define RTL_W8(reg, val8)	writeb ((val8), ioaddr + (reg))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   106
#define RTL_W16(reg, val16)	writew ((val16), ioaddr + (reg))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   107
#define RTL_W32(reg, val32)	writel ((val32), ioaddr + (reg))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   108
#define RTL_R8(reg)		readb (ioaddr + (reg))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   109
#define RTL_R16(reg)		readw (ioaddr + (reg))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   110
#define RTL_R32(reg)		readl (ioaddr + (reg))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   111
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   112
enum mac_version {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   113
	RTL_GIGA_MAC_VER_01 = 0,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   114
	RTL_GIGA_MAC_VER_02,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   115
	RTL_GIGA_MAC_VER_03,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   116
	RTL_GIGA_MAC_VER_04,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   117
	RTL_GIGA_MAC_VER_05,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   118
	RTL_GIGA_MAC_VER_06,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   119
	RTL_GIGA_MAC_VER_07,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   120
	RTL_GIGA_MAC_VER_08,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   121
	RTL_GIGA_MAC_VER_09,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   122
	RTL_GIGA_MAC_VER_10,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   123
	RTL_GIGA_MAC_VER_11,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   124
	RTL_GIGA_MAC_VER_12,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   125
	RTL_GIGA_MAC_VER_13,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   126
	RTL_GIGA_MAC_VER_14,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   127
	RTL_GIGA_MAC_VER_15,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   128
	RTL_GIGA_MAC_VER_16,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   129
	RTL_GIGA_MAC_VER_17,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   130
	RTL_GIGA_MAC_VER_18,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   131
	RTL_GIGA_MAC_VER_19,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   132
	RTL_GIGA_MAC_VER_20,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   133
	RTL_GIGA_MAC_VER_21,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   134
	RTL_GIGA_MAC_VER_22,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   135
	RTL_GIGA_MAC_VER_23,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   136
	RTL_GIGA_MAC_VER_24,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   137
	RTL_GIGA_MAC_VER_25,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   138
	RTL_GIGA_MAC_VER_26,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   139
	RTL_GIGA_MAC_VER_27,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   140
	RTL_GIGA_MAC_VER_28,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   141
	RTL_GIGA_MAC_VER_29,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   142
	RTL_GIGA_MAC_VER_30,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   143
	RTL_GIGA_MAC_VER_31,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   144
	RTL_GIGA_MAC_VER_32,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   145
	RTL_GIGA_MAC_VER_33,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   146
	RTL_GIGA_MAC_VER_34,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   147
	RTL_GIGA_MAC_VER_35,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   148
	RTL_GIGA_MAC_VER_36,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   149
	RTL_GIGA_MAC_VER_37,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   150
	RTL_GIGA_MAC_VER_38,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   151
	RTL_GIGA_MAC_VER_39,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   152
	RTL_GIGA_MAC_VER_40,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   153
	RTL_GIGA_MAC_VER_41,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   154
	RTL_GIGA_MAC_NONE   = 0xff,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   155
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   156
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   157
enum rtl_tx_desc_version {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   158
	RTL_TD_0	= 0,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   159
	RTL_TD_1	= 1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   160
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   161
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   162
#define JUMBO_1K	ETH_DATA_LEN
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   163
#define JUMBO_4K	(4*1024 - ETH_HLEN - 2)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   164
#define JUMBO_6K	(6*1024 - ETH_HLEN - 2)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   165
#define JUMBO_7K	(7*1024 - ETH_HLEN - 2)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   166
#define JUMBO_9K	(9*1024 - ETH_HLEN - 2)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   167
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   168
#define _R(NAME,TD,FW,SZ,B) {	\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   169
	.name = NAME,		\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   170
	.txd_version = TD,	\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   171
	.fw_name = FW,		\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   172
	.jumbo_max = SZ,	\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   173
	.jumbo_tx_csum = B	\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   174
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   175
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   176
static const struct {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   177
	const char *name;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   178
	enum rtl_tx_desc_version txd_version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   179
	const char *fw_name;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   180
	u16 jumbo_max;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   181
	bool jumbo_tx_csum;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   182
} rtl_chip_infos[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   183
	/* PCI devices. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   184
	[RTL_GIGA_MAC_VER_01] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   185
		_R("RTL8169",		RTL_TD_0, NULL, JUMBO_7K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   186
	[RTL_GIGA_MAC_VER_02] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   187
		_R("RTL8169s",		RTL_TD_0, NULL, JUMBO_7K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   188
	[RTL_GIGA_MAC_VER_03] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   189
		_R("RTL8110s",		RTL_TD_0, NULL, JUMBO_7K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   190
	[RTL_GIGA_MAC_VER_04] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   191
		_R("RTL8169sb/8110sb",	RTL_TD_0, NULL, JUMBO_7K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   192
	[RTL_GIGA_MAC_VER_05] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   193
		_R("RTL8169sc/8110sc",	RTL_TD_0, NULL, JUMBO_7K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   194
	[RTL_GIGA_MAC_VER_06] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   195
		_R("RTL8169sc/8110sc",	RTL_TD_0, NULL, JUMBO_7K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   196
	/* PCI-E devices. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   197
	[RTL_GIGA_MAC_VER_07] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   198
		_R("RTL8102e",		RTL_TD_1, NULL, JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   199
	[RTL_GIGA_MAC_VER_08] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   200
		_R("RTL8102e",		RTL_TD_1, NULL, JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   201
	[RTL_GIGA_MAC_VER_09] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   202
		_R("RTL8102e",		RTL_TD_1, NULL, JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   203
	[RTL_GIGA_MAC_VER_10] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   204
		_R("RTL8101e",		RTL_TD_0, NULL, JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   205
	[RTL_GIGA_MAC_VER_11] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   206
		_R("RTL8168b/8111b",	RTL_TD_0, NULL, JUMBO_4K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   207
	[RTL_GIGA_MAC_VER_12] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   208
		_R("RTL8168b/8111b",	RTL_TD_0, NULL, JUMBO_4K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   209
	[RTL_GIGA_MAC_VER_13] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   210
		_R("RTL8101e",		RTL_TD_0, NULL, JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   211
	[RTL_GIGA_MAC_VER_14] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   212
		_R("RTL8100e",		RTL_TD_0, NULL, JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   213
	[RTL_GIGA_MAC_VER_15] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   214
		_R("RTL8100e",		RTL_TD_0, NULL, JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   215
	[RTL_GIGA_MAC_VER_16] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   216
		_R("RTL8101e",		RTL_TD_0, NULL, JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   217
	[RTL_GIGA_MAC_VER_17] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   218
		_R("RTL8168b/8111b",	RTL_TD_1, NULL, JUMBO_4K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   219
	[RTL_GIGA_MAC_VER_18] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   220
		_R("RTL8168cp/8111cp",	RTL_TD_1, NULL, JUMBO_6K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   221
	[RTL_GIGA_MAC_VER_19] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   222
		_R("RTL8168c/8111c",	RTL_TD_1, NULL, JUMBO_6K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   223
	[RTL_GIGA_MAC_VER_20] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   224
		_R("RTL8168c/8111c",	RTL_TD_1, NULL, JUMBO_6K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   225
	[RTL_GIGA_MAC_VER_21] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   226
		_R("RTL8168c/8111c",	RTL_TD_1, NULL, JUMBO_6K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   227
	[RTL_GIGA_MAC_VER_22] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   228
		_R("RTL8168c/8111c",	RTL_TD_1, NULL, JUMBO_6K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   229
	[RTL_GIGA_MAC_VER_23] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   230
		_R("RTL8168cp/8111cp",	RTL_TD_1, NULL, JUMBO_6K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   231
	[RTL_GIGA_MAC_VER_24] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   232
		_R("RTL8168cp/8111cp",	RTL_TD_1, NULL, JUMBO_6K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   233
	[RTL_GIGA_MAC_VER_25] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   234
		_R("RTL8168d/8111d",	RTL_TD_1, FIRMWARE_8168D_1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   235
							JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   236
	[RTL_GIGA_MAC_VER_26] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   237
		_R("RTL8168d/8111d",	RTL_TD_1, FIRMWARE_8168D_2,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   238
							JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   239
	[RTL_GIGA_MAC_VER_27] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   240
		_R("RTL8168dp/8111dp",	RTL_TD_1, NULL, JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   241
	[RTL_GIGA_MAC_VER_28] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   242
		_R("RTL8168dp/8111dp",	RTL_TD_1, NULL, JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   243
	[RTL_GIGA_MAC_VER_29] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   244
		_R("RTL8105e",		RTL_TD_1, FIRMWARE_8105E_1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   245
							JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   246
	[RTL_GIGA_MAC_VER_30] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   247
		_R("RTL8105e",		RTL_TD_1, FIRMWARE_8105E_1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   248
							JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   249
	[RTL_GIGA_MAC_VER_31] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   250
		_R("RTL8168dp/8111dp",	RTL_TD_1, NULL, JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   251
	[RTL_GIGA_MAC_VER_32] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   252
		_R("RTL8168e/8111e",	RTL_TD_1, FIRMWARE_8168E_1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   253
							JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   254
	[RTL_GIGA_MAC_VER_33] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   255
		_R("RTL8168e/8111e",	RTL_TD_1, FIRMWARE_8168E_2,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   256
							JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   257
	[RTL_GIGA_MAC_VER_34] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   258
		_R("RTL8168evl/8111evl",RTL_TD_1, FIRMWARE_8168E_3,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   259
							JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   260
	[RTL_GIGA_MAC_VER_35] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   261
		_R("RTL8168f/8111f",	RTL_TD_1, FIRMWARE_8168F_1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   262
							JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   263
	[RTL_GIGA_MAC_VER_36] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   264
		_R("RTL8168f/8111f",	RTL_TD_1, FIRMWARE_8168F_2,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   265
							JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   266
	[RTL_GIGA_MAC_VER_37] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   267
		_R("RTL8402",		RTL_TD_1, FIRMWARE_8402_1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   268
							JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   269
	[RTL_GIGA_MAC_VER_38] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   270
		_R("RTL8411",		RTL_TD_1, FIRMWARE_8411_1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   271
							JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   272
	[RTL_GIGA_MAC_VER_39] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   273
		_R("RTL8106e",		RTL_TD_1, FIRMWARE_8106E_1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   274
							JUMBO_1K, true),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   275
	[RTL_GIGA_MAC_VER_40] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   276
		_R("RTL8168g/8111g",	RTL_TD_1, FIRMWARE_8168G_1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   277
							JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   278
	[RTL_GIGA_MAC_VER_41] =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   279
		_R("RTL8168g/8111g",	RTL_TD_1, NULL, JUMBO_9K, false),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   280
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   281
#undef _R
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   282
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   283
enum cfg_version {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   284
	RTL_CFG_0 = 0x00,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   285
	RTL_CFG_1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   286
	RTL_CFG_2
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   287
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   288
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   289
static DEFINE_PCI_DEVICE_TABLE(rtl8169_pci_tbl) = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   290
	{ PCI_DEVICE(PCI_VENDOR_ID_REALTEK,	0x8129), 0, 0, RTL_CFG_0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   291
	{ PCI_DEVICE(PCI_VENDOR_ID_REALTEK,	0x8136), 0, 0, RTL_CFG_2 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   292
	{ PCI_DEVICE(PCI_VENDOR_ID_REALTEK,	0x8167), 0, 0, RTL_CFG_0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   293
	{ PCI_DEVICE(PCI_VENDOR_ID_REALTEK,	0x8168), 0, 0, RTL_CFG_1 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   294
	{ PCI_DEVICE(PCI_VENDOR_ID_REALTEK,	0x8169), 0, 0, RTL_CFG_0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   295
	{ PCI_DEVICE(PCI_VENDOR_ID_DLINK,	0x4300), 0, 0, RTL_CFG_0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   296
	{ PCI_DEVICE(PCI_VENDOR_ID_DLINK,	0x4302), 0, 0, RTL_CFG_0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   297
	{ PCI_DEVICE(PCI_VENDOR_ID_AT,		0xc107), 0, 0, RTL_CFG_0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   298
	{ PCI_DEVICE(0x16ec,			0x0116), 0, 0, RTL_CFG_0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   299
	{ PCI_VENDOR_ID_LINKSYS,		0x1032,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   300
		PCI_ANY_ID, 0x0024, 0, 0, RTL_CFG_0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   301
	{ 0x0001,				0x8168,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   302
		PCI_ANY_ID, 0x2410, 0, 0, RTL_CFG_2 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   303
	{0,},
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   304
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   305
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   306
/* prevent driver from being loaded automatically */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   307
//MODULE_DEVICE_TABLE(pci, rtl8169_pci_tbl);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   308
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   309
static int rx_buf_sz = 16383;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   310
static int use_dac;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   311
static struct {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   312
	u32 msg_enable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   313
} debug = { -1 };
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   314
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   315
enum rtl_registers {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   316
	MAC0		= 0,	/* Ethernet hardware address. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   317
	MAC4		= 4,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   318
	MAR0		= 8,	/* Multicast filter. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   319
	CounterAddrLow		= 0x10,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   320
	CounterAddrHigh		= 0x14,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   321
	TxDescStartAddrLow	= 0x20,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   322
	TxDescStartAddrHigh	= 0x24,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   323
	TxHDescStartAddrLow	= 0x28,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   324
	TxHDescStartAddrHigh	= 0x2c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   325
	FLASH		= 0x30,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   326
	ERSR		= 0x36,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   327
	ChipCmd		= 0x37,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   328
	TxPoll		= 0x38,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   329
	IntrMask	= 0x3c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   330
	IntrStatus	= 0x3e,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   331
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   332
	TxConfig	= 0x40,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   333
#define	TXCFG_AUTO_FIFO			(1 << 7)	/* 8111e-vl */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   334
#define	TXCFG_EMPTY			(1 << 11)	/* 8111e-vl */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   335
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   336
	RxConfig	= 0x44,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   337
#define	RX128_INT_EN			(1 << 15)	/* 8111c and later */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   338
#define	RX_MULTI_EN			(1 << 14)	/* 8111c only */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   339
#define	RXCFG_FIFO_SHIFT		13
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   340
					/* No threshold before first PCI xfer */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   341
#define	RX_FIFO_THRESH			(7 << RXCFG_FIFO_SHIFT)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   342
#define	RXCFG_DMA_SHIFT			8
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   343
					/* Unlimited maximum PCI burst. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   344
#define	RX_DMA_BURST			(7 << RXCFG_DMA_SHIFT)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   345
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   346
	RxMissed	= 0x4c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   347
	Cfg9346		= 0x50,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   348
	Config0		= 0x51,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   349
	Config1		= 0x52,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   350
	Config2		= 0x53,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   351
#define PME_SIGNAL			(1 << 5)	/* 8168c and later */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   352
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   353
	Config3		= 0x54,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   354
	Config4		= 0x55,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   355
	Config5		= 0x56,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   356
	MultiIntr	= 0x5c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   357
	PHYAR		= 0x60,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   358
	PHYstatus	= 0x6c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   359
	RxMaxSize	= 0xda,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   360
	CPlusCmd	= 0xe0,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   361
	IntrMitigate	= 0xe2,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   362
	RxDescAddrLow	= 0xe4,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   363
	RxDescAddrHigh	= 0xe8,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   364
	EarlyTxThres	= 0xec,	/* 8169. Unit of 32 bytes. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   365
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   366
#define NoEarlyTx	0x3f	/* Max value : no early transmit. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   367
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   368
	MaxTxPacketSize	= 0xec,	/* 8101/8168. Unit of 128 bytes. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   369
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   370
#define TxPacketMax	(8064 >> 7)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   371
#define EarlySize	0x27
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   372
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   373
	FuncEvent	= 0xf0,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   374
	FuncEventMask	= 0xf4,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   375
	FuncPresetState	= 0xf8,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   376
	FuncForceEvent	= 0xfc,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   377
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   378
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   379
enum rtl8110_registers {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   380
	TBICSR			= 0x64,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   381
	TBI_ANAR		= 0x68,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   382
	TBI_LPAR		= 0x6a,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   383
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   384
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   385
enum rtl8168_8101_registers {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   386
	CSIDR			= 0x64,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   387
	CSIAR			= 0x68,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   388
#define	CSIAR_FLAG			0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   389
#define	CSIAR_WRITE_CMD			0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   390
#define	CSIAR_BYTE_ENABLE		0x0f
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   391
#define	CSIAR_BYTE_ENABLE_SHIFT		12
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   392
#define	CSIAR_ADDR_MASK			0x0fff
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   393
#define CSIAR_FUNC_CARD			0x00000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   394
#define CSIAR_FUNC_SDIO			0x00010000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   395
#define CSIAR_FUNC_NIC			0x00020000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   396
	PMCH			= 0x6f,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   397
	EPHYAR			= 0x80,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   398
#define	EPHYAR_FLAG			0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   399
#define	EPHYAR_WRITE_CMD		0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   400
#define	EPHYAR_REG_MASK			0x1f
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   401
#define	EPHYAR_REG_SHIFT		16
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   402
#define	EPHYAR_DATA_MASK		0xffff
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   403
	DLLPR			= 0xd0,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   404
#define	PFM_EN				(1 << 6)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   405
	DBG_REG			= 0xd1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   406
#define	FIX_NAK_1			(1 << 4)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   407
#define	FIX_NAK_2			(1 << 3)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   408
	TWSI			= 0xd2,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   409
	MCU			= 0xd3,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   410
#define	NOW_IS_OOB			(1 << 7)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   411
#define	TX_EMPTY			(1 << 5)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   412
#define	RX_EMPTY			(1 << 4)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   413
#define	RXTX_EMPTY			(TX_EMPTY | RX_EMPTY)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   414
#define	EN_NDP				(1 << 3)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   415
#define	EN_OOB_RESET			(1 << 2)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   416
#define	LINK_LIST_RDY			(1 << 1)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   417
	EFUSEAR			= 0xdc,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   418
#define	EFUSEAR_FLAG			0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   419
#define	EFUSEAR_WRITE_CMD		0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   420
#define	EFUSEAR_READ_CMD		0x00000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   421
#define	EFUSEAR_REG_MASK		0x03ff
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   422
#define	EFUSEAR_REG_SHIFT		8
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   423
#define	EFUSEAR_DATA_MASK		0xff
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   424
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   425
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   426
enum rtl8168_registers {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   427
	LED_FREQ		= 0x1a,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   428
	EEE_LED			= 0x1b,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   429
	ERIDR			= 0x70,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   430
	ERIAR			= 0x74,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   431
#define ERIAR_FLAG			0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   432
#define ERIAR_WRITE_CMD			0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   433
#define ERIAR_READ_CMD			0x00000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   434
#define ERIAR_ADDR_BYTE_ALIGN		4
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   435
#define ERIAR_TYPE_SHIFT		16
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   436
#define ERIAR_EXGMAC			(0x00 << ERIAR_TYPE_SHIFT)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   437
#define ERIAR_MSIX			(0x01 << ERIAR_TYPE_SHIFT)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   438
#define ERIAR_ASF			(0x02 << ERIAR_TYPE_SHIFT)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   439
#define ERIAR_MASK_SHIFT		12
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   440
#define ERIAR_MASK_0001			(0x1 << ERIAR_MASK_SHIFT)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   441
#define ERIAR_MASK_0011			(0x3 << ERIAR_MASK_SHIFT)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   442
#define ERIAR_MASK_0101			(0x5 << ERIAR_MASK_SHIFT)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   443
#define ERIAR_MASK_1111			(0xf << ERIAR_MASK_SHIFT)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   444
	EPHY_RXER_NUM		= 0x7c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   445
	OCPDR			= 0xb0,	/* OCP GPHY access */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   446
#define OCPDR_WRITE_CMD			0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   447
#define OCPDR_READ_CMD			0x00000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   448
#define OCPDR_REG_MASK			0x7f
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   449
#define OCPDR_GPHY_REG_SHIFT		16
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   450
#define OCPDR_DATA_MASK			0xffff
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   451
	OCPAR			= 0xb4,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   452
#define OCPAR_FLAG			0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   453
#define OCPAR_GPHY_WRITE_CMD		0x8000f060
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   454
#define OCPAR_GPHY_READ_CMD		0x0000f060
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   455
	GPHY_OCP		= 0xb8,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   456
	RDSAR1			= 0xd0,	/* 8168c only. Undocumented on 8168dp */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   457
	MISC			= 0xf0,	/* 8168e only. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   458
#define TXPLA_RST			(1 << 29)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   459
#define DISABLE_LAN_EN			(1 << 23) /* Enable GPIO pin */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   460
#define PWM_EN				(1 << 22)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   461
#define RXDV_GATED_EN			(1 << 19)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   462
#define EARLY_TALLY_EN			(1 << 16)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   463
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   464
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   465
enum rtl_register_content {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   466
	/* InterruptStatusBits */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   467
	SYSErr		= 0x8000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   468
	PCSTimeout	= 0x4000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   469
	SWInt		= 0x0100,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   470
	TxDescUnavail	= 0x0080,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   471
	RxFIFOOver	= 0x0040,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   472
	LinkChg		= 0x0020,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   473
	RxOverflow	= 0x0010,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   474
	TxErr		= 0x0008,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   475
	TxOK		= 0x0004,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   476
	RxErr		= 0x0002,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   477
	RxOK		= 0x0001,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   478
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   479
	/* RxStatusDesc */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   480
	RxBOVF	= (1 << 24),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   481
	RxFOVF	= (1 << 23),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   482
	RxRWT	= (1 << 22),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   483
	RxRES	= (1 << 21),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   484
	RxRUNT	= (1 << 20),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   485
	RxCRC	= (1 << 19),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   486
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   487
	/* ChipCmdBits */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   488
	StopReq		= 0x80,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   489
	CmdReset	= 0x10,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   490
	CmdRxEnb	= 0x08,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   491
	CmdTxEnb	= 0x04,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   492
	RxBufEmpty	= 0x01,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   493
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   494
	/* TXPoll register p.5 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   495
	HPQ		= 0x80,		/* Poll cmd on the high prio queue */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   496
	NPQ		= 0x40,		/* Poll cmd on the low prio queue */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   497
	FSWInt		= 0x01,		/* Forced software interrupt */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   498
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   499
	/* Cfg9346Bits */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   500
	Cfg9346_Lock	= 0x00,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   501
	Cfg9346_Unlock	= 0xc0,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   502
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   503
	/* rx_mode_bits */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   504
	AcceptErr	= 0x20,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   505
	AcceptRunt	= 0x10,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   506
	AcceptBroadcast	= 0x08,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   507
	AcceptMulticast	= 0x04,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   508
	AcceptMyPhys	= 0x02,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   509
	AcceptAllPhys	= 0x01,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   510
#define RX_CONFIG_ACCEPT_MASK		0x3f
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   511
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   512
	/* TxConfigBits */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   513
	TxInterFrameGapShift = 24,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   514
	TxDMAShift = 8,	/* DMA burst value (0-7) is shift this many bits */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   515
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   516
	/* Config1 register p.24 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   517
	LEDS1		= (1 << 7),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   518
	LEDS0		= (1 << 6),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   519
	Speed_down	= (1 << 4),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   520
	MEMMAP		= (1 << 3),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   521
	IOMAP		= (1 << 2),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   522
	VPD		= (1 << 1),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   523
	PMEnable	= (1 << 0),	/* Power Management Enable */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   524
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   525
	/* Config2 register p. 25 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   526
	MSIEnable	= (1 << 5),	/* 8169 only. Reserved in the 8168. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   527
	PCI_Clock_66MHz = 0x01,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   528
	PCI_Clock_33MHz = 0x00,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   529
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   530
	/* Config3 register p.25 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   531
	MagicPacket	= (1 << 5),	/* Wake up when receives a Magic Packet */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   532
	LinkUp		= (1 << 4),	/* Wake up when the cable connection is re-established */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   533
	Jumbo_En0	= (1 << 2),	/* 8168 only. Reserved in the 8168b */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   534
	Beacon_en	= (1 << 0),	/* 8168 only. Reserved in the 8168b */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   535
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   536
	/* Config4 register */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   537
	Jumbo_En1	= (1 << 1),	/* 8168 only. Reserved in the 8168b */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   538
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   539
	/* Config5 register p.27 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   540
	BWF		= (1 << 6),	/* Accept Broadcast wakeup frame */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   541
	MWF		= (1 << 5),	/* Accept Multicast wakeup frame */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   542
	UWF		= (1 << 4),	/* Accept Unicast wakeup frame */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   543
	Spi_en		= (1 << 3),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   544
	LanWake		= (1 << 1),	/* LanWake enable/disable */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   545
	PMEStatus	= (1 << 0),	/* PME status can be reset by PCI RST# */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   546
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   547
	/* TBICSR p.28 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   548
	TBIReset	= 0x80000000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   549
	TBILoopback	= 0x40000000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   550
	TBINwEnable	= 0x20000000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   551
	TBINwRestart	= 0x10000000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   552
	TBILinkOk	= 0x02000000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   553
	TBINwComplete	= 0x01000000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   554
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   555
	/* CPlusCmd p.31 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   556
	EnableBist	= (1 << 15),	// 8168 8101
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   557
	Mac_dbgo_oe	= (1 << 14),	// 8168 8101
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   558
	Normal_mode	= (1 << 13),	// unused
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   559
	Force_half_dup	= (1 << 12),	// 8168 8101
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   560
	Force_rxflow_en	= (1 << 11),	// 8168 8101
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   561
	Force_txflow_en	= (1 << 10),	// 8168 8101
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   562
	Cxpl_dbg_sel	= (1 << 9),	// 8168 8101
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   563
	ASF		= (1 << 8),	// 8168 8101
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   564
	PktCntrDisable	= (1 << 7),	// 8168 8101
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   565
	Mac_dbgo_sel	= 0x001c,	// 8168
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   566
	RxVlan		= (1 << 6),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   567
	RxChkSum	= (1 << 5),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   568
	PCIDAC		= (1 << 4),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   569
	PCIMulRW	= (1 << 3),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   570
	INTT_0		= 0x0000,	// 8168
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   571
	INTT_1		= 0x0001,	// 8168
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   572
	INTT_2		= 0x0002,	// 8168
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   573
	INTT_3		= 0x0003,	// 8168
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   574
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   575
	/* rtl8169_PHYstatus */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   576
	TBI_Enable	= 0x80,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   577
	TxFlowCtrl	= 0x40,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   578
	RxFlowCtrl	= 0x20,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   579
	_1000bpsF	= 0x10,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   580
	_100bps		= 0x08,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   581
	_10bps		= 0x04,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   582
	LinkStatus	= 0x02,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   583
	FullDup		= 0x01,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   584
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   585
	/* _TBICSRBit */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   586
	TBILinkOK	= 0x02000000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   587
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   588
	/* DumpCounterCommand */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   589
	CounterDump	= 0x8,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   590
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   591
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   592
enum rtl_desc_bit {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   593
	/* First doubleword. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   594
	DescOwn		= (1 << 31), /* Descriptor is owned by NIC */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   595
	RingEnd		= (1 << 30), /* End of descriptor ring */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   596
	FirstFrag	= (1 << 29), /* First segment of a packet */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   597
	LastFrag	= (1 << 28), /* Final segment of a packet */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   598
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   599
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   600
/* Generic case. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   601
enum rtl_tx_desc_bit {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   602
	/* First doubleword. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   603
	TD_LSO		= (1 << 27),		/* Large Send Offload */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   604
#define TD_MSS_MAX			0x07ffu	/* MSS value */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   605
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   606
	/* Second doubleword. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   607
	TxVlanTag	= (1 << 17),		/* Add VLAN tag */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   608
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   609
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   610
/* 8169, 8168b and 810x except 8102e. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   611
enum rtl_tx_desc_bit_0 {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   612
	/* First doubleword. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   613
#define TD0_MSS_SHIFT			16	/* MSS position (11 bits) */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   614
	TD0_TCP_CS	= (1 << 16),		/* Calculate TCP/IP checksum */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   615
	TD0_UDP_CS	= (1 << 17),		/* Calculate UDP/IP checksum */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   616
	TD0_IP_CS	= (1 << 18),		/* Calculate IP checksum */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   617
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   618
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   619
/* 8102e, 8168c and beyond. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   620
enum rtl_tx_desc_bit_1 {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   621
	/* Second doubleword. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   622
#define TD1_MSS_SHIFT			18	/* MSS position (11 bits) */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   623
	TD1_IP_CS	= (1 << 29),		/* Calculate IP checksum */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   624
	TD1_TCP_CS	= (1 << 30),		/* Calculate TCP/IP checksum */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   625
	TD1_UDP_CS	= (1 << 31),		/* Calculate UDP/IP checksum */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   626
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   627
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   628
static const struct rtl_tx_desc_info {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   629
	struct {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   630
		u32 udp;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   631
		u32 tcp;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   632
	} checksum;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   633
	u16 mss_shift;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   634
	u16 opts_offset;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   635
} tx_desc_info [] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   636
	[RTL_TD_0] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   637
		.checksum = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   638
			.udp	= TD0_IP_CS | TD0_UDP_CS,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   639
			.tcp	= TD0_IP_CS | TD0_TCP_CS
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   640
		},
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   641
		.mss_shift	= TD0_MSS_SHIFT,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   642
		.opts_offset	= 0
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   643
	},
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   644
	[RTL_TD_1] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   645
		.checksum = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   646
			.udp	= TD1_IP_CS | TD1_UDP_CS,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   647
			.tcp	= TD1_IP_CS | TD1_TCP_CS
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   648
		},
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   649
		.mss_shift	= TD1_MSS_SHIFT,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   650
		.opts_offset	= 1
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   651
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   652
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   653
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   654
enum rtl_rx_desc_bit {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   655
	/* Rx private */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   656
	PID1		= (1 << 18), /* Protocol ID bit 1/2 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   657
	PID0		= (1 << 17), /* Protocol ID bit 2/2 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   658
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   659
#define RxProtoUDP	(PID1)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   660
#define RxProtoTCP	(PID0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   661
#define RxProtoIP	(PID1 | PID0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   662
#define RxProtoMask	RxProtoIP
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   663
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   664
	IPFail		= (1 << 16), /* IP checksum failed */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   665
	UDPFail		= (1 << 15), /* UDP/IP checksum failed */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   666
	TCPFail		= (1 << 14), /* TCP/IP checksum failed */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   667
	RxVlanTag	= (1 << 16), /* VLAN tag available */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   668
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   669
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   670
#define RsvdMask	0x3fffc000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   671
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   672
struct TxDesc {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   673
	__le32 opts1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   674
	__le32 opts2;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   675
	__le64 addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   676
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   677
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   678
struct RxDesc {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   679
	__le32 opts1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   680
	__le32 opts2;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   681
	__le64 addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   682
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   683
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   684
struct ring_info {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   685
	struct sk_buff	*skb;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   686
	u32		len;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   687
	u8		__pad[sizeof(void *) - sizeof(u32)];
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   688
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   689
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   690
enum features {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   691
	RTL_FEATURE_WOL		= (1 << 0),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   692
	RTL_FEATURE_MSI		= (1 << 1),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   693
	RTL_FEATURE_GMII	= (1 << 2),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   694
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   695
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   696
struct rtl8169_counters {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   697
	__le64	tx_packets;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   698
	__le64	rx_packets;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   699
	__le64	tx_errors;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   700
	__le32	rx_errors;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   701
	__le16	rx_missed;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   702
	__le16	align_errors;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   703
	__le32	tx_one_collision;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   704
	__le32	tx_multi_collision;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   705
	__le64	rx_unicast;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   706
	__le64	rx_broadcast;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   707
	__le32	rx_multicast;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   708
	__le16	tx_aborted;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   709
	__le16	tx_underun;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   710
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   711
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   712
enum rtl_flag {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   713
	RTL_FLAG_TASK_ENABLED,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   714
	RTL_FLAG_TASK_SLOW_PENDING,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   715
	RTL_FLAG_TASK_RESET_PENDING,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   716
	RTL_FLAG_TASK_PHY_PENDING,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   717
	RTL_FLAG_MAX
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   718
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   719
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   720
struct rtl8169_stats {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   721
	u64			packets;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   722
	u64			bytes;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   723
	struct u64_stats_sync	syncp;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   724
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   725
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   726
struct rtl8169_private {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   727
	void __iomem *mmio_addr;	/* memory map physical address */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   728
	struct pci_dev *pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   729
	struct net_device *dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   730
	struct napi_struct napi;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   731
	u32 msg_enable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   732
	u16 txd_version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   733
	u16 mac_version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   734
	u32 cur_rx; /* Index into the Rx descriptor buffer of next Rx pkt. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   735
	u32 cur_tx; /* Index into the Tx descriptor buffer of next Rx pkt. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   736
	u32 dirty_rx;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   737
	u32 dirty_tx;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   738
	struct rtl8169_stats rx_stats;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   739
	struct rtl8169_stats tx_stats;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   740
	struct TxDesc *TxDescArray;	/* 256-aligned Tx descriptor ring */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   741
	struct RxDesc *RxDescArray;	/* 256-aligned Rx descriptor ring */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   742
	dma_addr_t TxPhyAddr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   743
	dma_addr_t RxPhyAddr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   744
	void *Rx_databuff[NUM_RX_DESC];	/* Rx data buffers */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   745
	struct ring_info tx_skb[NUM_TX_DESC];	/* Tx data buffers */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   746
	struct timer_list timer;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   747
	u16 cp_cmd;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   748
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   749
	u16 event_slow;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   750
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   751
	struct mdio_ops {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   752
		void (*write)(struct rtl8169_private *, int, int);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   753
		int (*read)(struct rtl8169_private *, int);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   754
	} mdio_ops;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   755
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   756
	struct pll_power_ops {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   757
		void (*down)(struct rtl8169_private *);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   758
		void (*up)(struct rtl8169_private *);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   759
	} pll_power_ops;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   760
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   761
	struct jumbo_ops {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   762
		void (*enable)(struct rtl8169_private *);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   763
		void (*disable)(struct rtl8169_private *);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   764
	} jumbo_ops;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   765
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   766
	struct csi_ops {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   767
		void (*write)(struct rtl8169_private *, int, int);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   768
		u32 (*read)(struct rtl8169_private *, int);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   769
	} csi_ops;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   770
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   771
	int (*set_speed)(struct net_device *, u8 aneg, u16 sp, u8 dpx, u32 adv);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   772
	int (*get_settings)(struct net_device *, struct ethtool_cmd *);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   773
	void (*phy_reset_enable)(struct rtl8169_private *tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   774
	void (*hw_start)(struct net_device *);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   775
	unsigned int (*phy_reset_pending)(struct rtl8169_private *tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   776
	unsigned int (*link_ok)(void __iomem *);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   777
	int (*do_ioctl)(struct rtl8169_private *tp, struct mii_ioctl_data *data, int cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   778
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   779
	struct {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   780
		DECLARE_BITMAP(flags, RTL_FLAG_MAX);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   781
		struct mutex mutex;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   782
		struct work_struct work;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   783
	} wk;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   784
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   785
	unsigned features;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   786
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   787
	struct mii_if_info mii;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   788
	struct rtl8169_counters counters;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   789
	u32 saved_wolopts;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   790
	u32 opts1_mask;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   791
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   792
	struct rtl_fw {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   793
		const struct firmware *fw;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   794
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   795
#define RTL_VER_SIZE		32
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   796
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   797
		char version[RTL_VER_SIZE];
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   798
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   799
		struct rtl_fw_phy_action {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   800
			__le32 *code;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   801
			size_t size;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   802
		} phy_action;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   803
	} *rtl_fw;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   804
#define RTL_FIRMWARE_UNKNOWN	ERR_PTR(-EAGAIN)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   805
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   806
	u32 ocp_base;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   807
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   808
	ec_device_t *ecdev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   809
	unsigned long ec_watchdog_jiffies;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   810
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   811
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   812
MODULE_AUTHOR("Realtek and the Linux r8169 crew <netdev@vger.kernel.org>");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   813
MODULE_DESCRIPTION("RealTek RTL-8169 Gigabit Ethernet driver (EtherCAT)");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   814
module_param(use_dac, int, 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   815
MODULE_PARM_DESC(use_dac, "Enable PCI DAC. Unsafe on 32 bit PCI slot.");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   816
module_param_named(debug, debug.msg_enable, int, 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   817
MODULE_PARM_DESC(debug, "Debug verbosity level (0=none, ..., 16=all)");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   818
MODULE_LICENSE("GPL");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   819
MODULE_VERSION(EC_MASTER_VERSION);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   820
MODULE_FIRMWARE(FIRMWARE_8168D_1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   821
MODULE_FIRMWARE(FIRMWARE_8168D_2);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   822
MODULE_FIRMWARE(FIRMWARE_8168E_1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   823
MODULE_FIRMWARE(FIRMWARE_8168E_2);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   824
MODULE_FIRMWARE(FIRMWARE_8168E_3);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   825
MODULE_FIRMWARE(FIRMWARE_8105E_1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   826
MODULE_FIRMWARE(FIRMWARE_8168F_1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   827
MODULE_FIRMWARE(FIRMWARE_8168F_2);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   828
MODULE_FIRMWARE(FIRMWARE_8402_1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   829
MODULE_FIRMWARE(FIRMWARE_8411_1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   830
MODULE_FIRMWARE(FIRMWARE_8106E_1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   831
MODULE_FIRMWARE(FIRMWARE_8168G_1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   832
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   833
static void rtl_lock_work(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   834
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   835
	mutex_lock(&tp->wk.mutex);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   836
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   837
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   838
static void rtl_unlock_work(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   839
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   840
	mutex_unlock(&tp->wk.mutex);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   841
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   842
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   843
static void rtl_tx_performance_tweak(struct pci_dev *pdev, u16 force)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   844
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   845
	int cap = pci_pcie_cap(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   846
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   847
	if (cap) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   848
		u16 ctl;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   849
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   850
		pci_read_config_word(pdev, cap + PCI_EXP_DEVCTL, &ctl);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   851
		ctl = (ctl & ~PCI_EXP_DEVCTL_READRQ) | force;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   852
		pci_write_config_word(pdev, cap + PCI_EXP_DEVCTL, ctl);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   853
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   854
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   855
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   856
struct rtl_cond {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   857
	bool (*check)(struct rtl8169_private *);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   858
	const char *msg;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   859
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   860
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   861
static void rtl_udelay(unsigned int d)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   862
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   863
	udelay(d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   864
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   865
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   866
static bool rtl_loop_wait(struct rtl8169_private *tp, const struct rtl_cond *c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   867
			  void (*delay)(unsigned int), unsigned int d, int n,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   868
			  bool high)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   869
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   870
	int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   871
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   872
	for (i = 0; i < n; i++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   873
		delay(d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   874
		if (c->check(tp) == high)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   875
			return true;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   876
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   877
	netif_err(tp, drv, tp->dev, "%s == %d (loop: %d, delay: %d).\n",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   878
		  c->msg, !high, n, d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   879
	return false;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   880
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   881
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   882
static bool rtl_udelay_loop_wait_high(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   883
				      const struct rtl_cond *c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   884
				      unsigned int d, int n)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   885
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   886
	return rtl_loop_wait(tp, c, rtl_udelay, d, n, true);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   887
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   888
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   889
static bool rtl_udelay_loop_wait_low(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   890
				     const struct rtl_cond *c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   891
				     unsigned int d, int n)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   892
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   893
	return rtl_loop_wait(tp, c, rtl_udelay, d, n, false);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   894
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   895
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   896
static bool rtl_msleep_loop_wait_high(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   897
				      const struct rtl_cond *c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   898
				      unsigned int d, int n)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   899
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   900
	return rtl_loop_wait(tp, c, msleep, d, n, true);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   901
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   902
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   903
static bool rtl_msleep_loop_wait_low(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   904
				     const struct rtl_cond *c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   905
				     unsigned int d, int n)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   906
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   907
	return rtl_loop_wait(tp, c, msleep, d, n, false);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   908
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   909
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   910
#define DECLARE_RTL_COND(name)				\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   911
static bool name ## _check(struct rtl8169_private *);	\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   912
							\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   913
static const struct rtl_cond name = {			\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   914
	.check	= name ## _check,			\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   915
	.msg	= #name					\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   916
};							\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   917
							\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   918
static bool name ## _check(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   919
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   920
DECLARE_RTL_COND(rtl_ocpar_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   921
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   922
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   923
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   924
	return RTL_R32(OCPAR) & OCPAR_FLAG;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   925
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   926
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   927
static u32 ocp_read(struct rtl8169_private *tp, u8 mask, u16 reg)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   928
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   929
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   930
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   931
	RTL_W32(OCPAR, ((u32)mask & 0x0f) << 12 | (reg & 0x0fff));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   932
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   933
	return rtl_udelay_loop_wait_high(tp, &rtl_ocpar_cond, 100, 20) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   934
		RTL_R32(OCPDR) : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   935
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   936
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   937
static void ocp_write(struct rtl8169_private *tp, u8 mask, u16 reg, u32 data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   938
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   939
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   940
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   941
	RTL_W32(OCPDR, data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   942
	RTL_W32(OCPAR, OCPAR_FLAG | ((u32)mask & 0x0f) << 12 | (reg & 0x0fff));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   943
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   944
	rtl_udelay_loop_wait_low(tp, &rtl_ocpar_cond, 100, 20);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   945
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   946
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   947
DECLARE_RTL_COND(rtl_eriar_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   948
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   949
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   950
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   951
	return RTL_R32(ERIAR) & ERIAR_FLAG;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   952
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   953
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   954
static void rtl8168_oob_notify(struct rtl8169_private *tp, u8 cmd)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   955
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   956
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   957
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   958
	RTL_W8(ERIDR, cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   959
	RTL_W32(ERIAR, 0x800010e8);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   960
	msleep(2);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   961
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   962
	if (!rtl_udelay_loop_wait_low(tp, &rtl_eriar_cond, 100, 5))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   963
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   964
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   965
	ocp_write(tp, 0x1, 0x30, 0x00000001);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   966
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   967
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   968
#define OOB_CMD_RESET		0x00
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   969
#define OOB_CMD_DRIVER_START	0x05
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   970
#define OOB_CMD_DRIVER_STOP	0x06
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   971
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   972
static u16 rtl8168_get_ocp_reg(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   973
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   974
	return (tp->mac_version == RTL_GIGA_MAC_VER_31) ? 0xb8 : 0x10;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   975
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   976
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   977
DECLARE_RTL_COND(rtl_ocp_read_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   978
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   979
	u16 reg;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   980
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   981
	reg = rtl8168_get_ocp_reg(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   982
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   983
	return ocp_read(tp, 0x0f, reg) & 0x00000800;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   984
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   985
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   986
static void rtl8168_driver_start(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   987
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   988
	rtl8168_oob_notify(tp, OOB_CMD_DRIVER_START);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   989
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   990
	rtl_msleep_loop_wait_high(tp, &rtl_ocp_read_cond, 10, 10);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   991
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   992
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   993
static void rtl8168_driver_stop(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   994
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   995
	rtl8168_oob_notify(tp, OOB_CMD_DRIVER_STOP);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   996
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   997
	rtl_msleep_loop_wait_low(tp, &rtl_ocp_read_cond, 10, 10);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   998
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
   999
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1000
static int r8168dp_check_dash(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1001
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1002
	u16 reg = rtl8168_get_ocp_reg(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1003
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1004
	return (ocp_read(tp, 0x0f, reg) & 0x00008000) ? 1 : 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1005
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1006
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1007
static bool rtl_ocp_reg_failure(struct rtl8169_private *tp, u32 reg)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1008
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1009
	if (reg & 0xffff0001) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1010
		netif_err(tp, drv, tp->dev, "Invalid ocp reg %x!\n", reg);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1011
		return true;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1012
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1013
	return false;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1014
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1015
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1016
DECLARE_RTL_COND(rtl_ocp_gphy_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1017
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1018
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1019
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1020
	return RTL_R32(GPHY_OCP) & OCPAR_FLAG;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1021
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1022
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1023
static void r8168_phy_ocp_write(struct rtl8169_private *tp, u32 reg, u32 data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1024
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1025
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1026
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1027
	if (rtl_ocp_reg_failure(tp, reg))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1028
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1029
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1030
	RTL_W32(GPHY_OCP, OCPAR_FLAG | (reg << 15) | data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1031
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1032
	rtl_udelay_loop_wait_low(tp, &rtl_ocp_gphy_cond, 25, 10);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1033
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1034
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1035
static u16 r8168_phy_ocp_read(struct rtl8169_private *tp, u32 reg)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1036
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1037
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1038
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1039
	if (rtl_ocp_reg_failure(tp, reg))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1040
		return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1041
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1042
	RTL_W32(GPHY_OCP, reg << 15);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1043
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1044
	return rtl_udelay_loop_wait_high(tp, &rtl_ocp_gphy_cond, 25, 10) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1045
		(RTL_R32(GPHY_OCP) & 0xffff) : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1046
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1047
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1048
static void rtl_w1w0_phy_ocp(struct rtl8169_private *tp, int reg, int p, int m)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1049
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1050
	int val;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1051
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1052
	val = r8168_phy_ocp_read(tp, reg);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1053
	r8168_phy_ocp_write(tp, reg, (val | p) & ~m);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1054
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1055
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1056
static void r8168_mac_ocp_write(struct rtl8169_private *tp, u32 reg, u32 data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1057
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1058
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1059
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1060
	if (rtl_ocp_reg_failure(tp, reg))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1061
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1062
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1063
	RTL_W32(OCPDR, OCPAR_FLAG | (reg << 15) | data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1064
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1065
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1066
static u16 r8168_mac_ocp_read(struct rtl8169_private *tp, u32 reg)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1067
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1068
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1069
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1070
	if (rtl_ocp_reg_failure(tp, reg))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1071
		return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1072
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1073
	RTL_W32(OCPDR, reg << 15);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1074
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1075
	return RTL_R32(OCPDR);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1076
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1077
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1078
#define OCP_STD_PHY_BASE	0xa400
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1079
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1080
static void r8168g_mdio_write(struct rtl8169_private *tp, int reg, int value)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1081
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1082
	if (reg == 0x1f) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1083
		tp->ocp_base = value ? value << 4 : OCP_STD_PHY_BASE;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1084
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1085
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1086
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1087
	if (tp->ocp_base != OCP_STD_PHY_BASE)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1088
		reg -= 0x10;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1089
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1090
	r8168_phy_ocp_write(tp, tp->ocp_base + reg * 2, value);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1091
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1092
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1093
static int r8168g_mdio_read(struct rtl8169_private *tp, int reg)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1094
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1095
	if (tp->ocp_base != OCP_STD_PHY_BASE)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1096
		reg -= 0x10;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1097
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1098
	return r8168_phy_ocp_read(tp, tp->ocp_base + reg * 2);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1099
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1100
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1101
DECLARE_RTL_COND(rtl_phyar_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1102
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1103
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1104
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1105
	return RTL_R32(PHYAR) & 0x80000000;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1106
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1107
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1108
static void r8169_mdio_write(struct rtl8169_private *tp, int reg, int value)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1109
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1110
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1111
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1112
	RTL_W32(PHYAR, 0x80000000 | (reg & 0x1f) << 16 | (value & 0xffff));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1113
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1114
	rtl_udelay_loop_wait_low(tp, &rtl_phyar_cond, 25, 20);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1115
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1116
	 * According to hardware specs a 20us delay is required after write
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1117
	 * complete indication, but before sending next command.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1118
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1119
	udelay(20);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1120
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1121
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1122
static int r8169_mdio_read(struct rtl8169_private *tp, int reg)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1123
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1124
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1125
	int value;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1126
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1127
	RTL_W32(PHYAR, 0x0 | (reg & 0x1f) << 16);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1128
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1129
	value = rtl_udelay_loop_wait_high(tp, &rtl_phyar_cond, 25, 20) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1130
		RTL_R32(PHYAR) & 0xffff : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1131
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1132
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1133
	 * According to hardware specs a 20us delay is required after read
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1134
	 * complete indication, but before sending next command.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1135
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1136
	udelay(20);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1137
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1138
	return value;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1139
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1140
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1141
static void r8168dp_1_mdio_access(struct rtl8169_private *tp, int reg, u32 data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1142
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1143
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1144
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1145
	RTL_W32(OCPDR, data | ((reg & OCPDR_REG_MASK) << OCPDR_GPHY_REG_SHIFT));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1146
	RTL_W32(OCPAR, OCPAR_GPHY_WRITE_CMD);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1147
	RTL_W32(EPHY_RXER_NUM, 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1148
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1149
	rtl_udelay_loop_wait_low(tp, &rtl_ocpar_cond, 1000, 100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1150
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1151
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1152
static void r8168dp_1_mdio_write(struct rtl8169_private *tp, int reg, int value)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1153
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1154
	r8168dp_1_mdio_access(tp, reg,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1155
			      OCPDR_WRITE_CMD | (value & OCPDR_DATA_MASK));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1156
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1157
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1158
static int r8168dp_1_mdio_read(struct rtl8169_private *tp, int reg)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1159
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1160
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1161
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1162
	r8168dp_1_mdio_access(tp, reg, OCPDR_READ_CMD);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1163
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1164
	mdelay(1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1165
	RTL_W32(OCPAR, OCPAR_GPHY_READ_CMD);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1166
	RTL_W32(EPHY_RXER_NUM, 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1167
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1168
	return rtl_udelay_loop_wait_high(tp, &rtl_ocpar_cond, 1000, 100) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1169
		RTL_R32(OCPDR) & OCPDR_DATA_MASK : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1170
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1171
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1172
#define R8168DP_1_MDIO_ACCESS_BIT	0x00020000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1173
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1174
static void r8168dp_2_mdio_start(void __iomem *ioaddr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1175
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1176
	RTL_W32(0xd0, RTL_R32(0xd0) & ~R8168DP_1_MDIO_ACCESS_BIT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1177
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1178
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1179
static void r8168dp_2_mdio_stop(void __iomem *ioaddr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1180
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1181
	RTL_W32(0xd0, RTL_R32(0xd0) | R8168DP_1_MDIO_ACCESS_BIT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1182
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1183
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1184
static void r8168dp_2_mdio_write(struct rtl8169_private *tp, int reg, int value)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1185
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1186
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1187
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1188
	r8168dp_2_mdio_start(ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1189
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1190
	r8169_mdio_write(tp, reg, value);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1191
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1192
	r8168dp_2_mdio_stop(ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1193
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1194
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1195
static int r8168dp_2_mdio_read(struct rtl8169_private *tp, int reg)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1196
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1197
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1198
	int value;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1199
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1200
	r8168dp_2_mdio_start(ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1201
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1202
	value = r8169_mdio_read(tp, reg);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1203
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1204
	r8168dp_2_mdio_stop(ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1205
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1206
	return value;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1207
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1208
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1209
static void rtl_writephy(struct rtl8169_private *tp, int location, u32 val)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1210
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1211
	tp->mdio_ops.write(tp, location, val);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1212
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1213
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1214
static int rtl_readphy(struct rtl8169_private *tp, int location)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1215
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1216
	return tp->mdio_ops.read(tp, location);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1217
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1218
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1219
static void rtl_patchphy(struct rtl8169_private *tp, int reg_addr, int value)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1220
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1221
	rtl_writephy(tp, reg_addr, rtl_readphy(tp, reg_addr) | value);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1222
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1223
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1224
static void rtl_w1w0_phy(struct rtl8169_private *tp, int reg_addr, int p, int m)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1225
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1226
	int val;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1227
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1228
	val = rtl_readphy(tp, reg_addr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1229
	rtl_writephy(tp, reg_addr, (val | p) & ~m);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1230
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1231
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1232
static void rtl_mdio_write(struct net_device *dev, int phy_id, int location,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1233
			   int val)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1234
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1235
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1236
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1237
	rtl_writephy(tp, location, val);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1238
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1239
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1240
static int rtl_mdio_read(struct net_device *dev, int phy_id, int location)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1241
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1242
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1243
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1244
	return rtl_readphy(tp, location);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1245
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1246
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1247
DECLARE_RTL_COND(rtl_ephyar_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1248
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1249
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1250
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1251
	return RTL_R32(EPHYAR) & EPHYAR_FLAG;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1252
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1253
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1254
static void rtl_ephy_write(struct rtl8169_private *tp, int reg_addr, int value)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1255
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1256
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1257
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1258
	RTL_W32(EPHYAR, EPHYAR_WRITE_CMD | (value & EPHYAR_DATA_MASK) |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1259
		(reg_addr & EPHYAR_REG_MASK) << EPHYAR_REG_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1260
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1261
	rtl_udelay_loop_wait_low(tp, &rtl_ephyar_cond, 10, 100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1262
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1263
	udelay(10);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1264
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1265
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1266
static u16 rtl_ephy_read(struct rtl8169_private *tp, int reg_addr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1267
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1268
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1269
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1270
	RTL_W32(EPHYAR, (reg_addr & EPHYAR_REG_MASK) << EPHYAR_REG_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1271
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1272
	return rtl_udelay_loop_wait_high(tp, &rtl_ephyar_cond, 10, 100) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1273
		RTL_R32(EPHYAR) & EPHYAR_DATA_MASK : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1274
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1275
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1276
static void rtl_eri_write(struct rtl8169_private *tp, int addr, u32 mask,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1277
			  u32 val, int type)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1278
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1279
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1280
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1281
	BUG_ON((addr & 3) || (mask == 0));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1282
	RTL_W32(ERIDR, val);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1283
	RTL_W32(ERIAR, ERIAR_WRITE_CMD | type | mask | addr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1284
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1285
	rtl_udelay_loop_wait_low(tp, &rtl_eriar_cond, 100, 100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1286
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1287
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1288
static u32 rtl_eri_read(struct rtl8169_private *tp, int addr, int type)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1289
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1290
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1291
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1292
	RTL_W32(ERIAR, ERIAR_READ_CMD | type | ERIAR_MASK_1111 | addr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1293
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1294
	return rtl_udelay_loop_wait_high(tp, &rtl_eriar_cond, 100, 100) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1295
		RTL_R32(ERIDR) : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1296
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1297
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1298
static void rtl_w1w0_eri(struct rtl8169_private *tp, int addr, u32 mask, u32 p,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1299
			 u32 m, int type)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1300
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1301
	u32 val;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1302
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1303
	val = rtl_eri_read(tp, addr, type);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1304
	rtl_eri_write(tp, addr, mask, (val & ~m) | p, type);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1305
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1306
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1307
struct exgmac_reg {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1308
	u16 addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1309
	u16 mask;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1310
	u32 val;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1311
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1312
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1313
static void rtl_write_exgmac_batch(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1314
				   const struct exgmac_reg *r, int len)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1315
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1316
	while (len-- > 0) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1317
		rtl_eri_write(tp, r->addr, r->mask, r->val, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1318
		r++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1319
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1320
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1321
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1322
DECLARE_RTL_COND(rtl_efusear_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1323
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1324
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1325
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1326
	return RTL_R32(EFUSEAR) & EFUSEAR_FLAG;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1327
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1328
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1329
static u8 rtl8168d_efuse_read(struct rtl8169_private *tp, int reg_addr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1330
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1331
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1332
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1333
	RTL_W32(EFUSEAR, (reg_addr & EFUSEAR_REG_MASK) << EFUSEAR_REG_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1334
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1335
	return rtl_udelay_loop_wait_high(tp, &rtl_efusear_cond, 100, 300) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1336
		RTL_R32(EFUSEAR) & EFUSEAR_DATA_MASK : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1337
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1338
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1339
static u16 rtl_get_events(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1340
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1341
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1342
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1343
	return RTL_R16(IntrStatus);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1344
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1345
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1346
static void rtl_ack_events(struct rtl8169_private *tp, u16 bits)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1347
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1348
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1349
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1350
	RTL_W16(IntrStatus, bits);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1351
	mmiowb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1352
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1353
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1354
static void rtl_irq_disable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1355
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1356
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1357
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1358
	RTL_W16(IntrMask, 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1359
	mmiowb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1360
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1361
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1362
static void rtl_irq_enable(struct rtl8169_private *tp, u16 bits)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1363
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1364
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1365
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1366
	RTL_W16(IntrMask, bits);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1367
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1368
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1369
#define RTL_EVENT_NAPI_RX	(RxOK | RxErr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1370
#define RTL_EVENT_NAPI_TX	(TxOK | TxErr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1371
#define RTL_EVENT_NAPI		(RTL_EVENT_NAPI_RX | RTL_EVENT_NAPI_TX)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1372
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1373
static void rtl_irq_enable_all(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1374
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1375
	rtl_irq_enable(tp, RTL_EVENT_NAPI | tp->event_slow);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1376
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1377
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1378
static void rtl8169_irq_mask_and_ack(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1379
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1380
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1381
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1382
	rtl_irq_disable(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1383
	rtl_ack_events(tp, RTL_EVENT_NAPI | tp->event_slow);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1384
	RTL_R8(ChipCmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1385
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1386
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1387
static unsigned int rtl8169_tbi_reset_pending(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1388
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1389
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1390
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1391
	return RTL_R32(TBICSR) & TBIReset;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1392
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1393
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1394
static unsigned int rtl8169_xmii_reset_pending(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1395
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1396
	return rtl_readphy(tp, MII_BMCR) & BMCR_RESET;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1397
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1398
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1399
static unsigned int rtl8169_tbi_link_ok(void __iomem *ioaddr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1400
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1401
	return RTL_R32(TBICSR) & TBILinkOk;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1402
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1403
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1404
static unsigned int rtl8169_xmii_link_ok(void __iomem *ioaddr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1405
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1406
	return RTL_R8(PHYstatus) & LinkStatus;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1407
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1408
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1409
static void rtl8169_tbi_reset_enable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1410
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1411
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1412
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1413
	RTL_W32(TBICSR, RTL_R32(TBICSR) | TBIReset);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1414
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1415
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1416
static void rtl8169_xmii_reset_enable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1417
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1418
	unsigned int val;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1419
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1420
	val = rtl_readphy(tp, MII_BMCR) | BMCR_RESET;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1421
	rtl_writephy(tp, MII_BMCR, val & 0xffff);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1422
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1423
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1424
static void rtl_link_chg_patch(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1425
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1426
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1427
	struct net_device *dev = tp->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1428
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1429
	if (!netif_running(dev))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1430
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1431
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1432
	if (tp->mac_version == RTL_GIGA_MAC_VER_34 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1433
	    tp->mac_version == RTL_GIGA_MAC_VER_38) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1434
		if (RTL_R8(PHYstatus) & _1000bpsF) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1435
			rtl_eri_write(tp, 0x1bc, ERIAR_MASK_1111, 0x00000011,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1436
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1437
			rtl_eri_write(tp, 0x1dc, ERIAR_MASK_1111, 0x00000005,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1438
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1439
		} else if (RTL_R8(PHYstatus) & _100bps) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1440
			rtl_eri_write(tp, 0x1bc, ERIAR_MASK_1111, 0x0000001f,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1441
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1442
			rtl_eri_write(tp, 0x1dc, ERIAR_MASK_1111, 0x00000005,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1443
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1444
		} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1445
			rtl_eri_write(tp, 0x1bc, ERIAR_MASK_1111, 0x0000001f,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1446
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1447
			rtl_eri_write(tp, 0x1dc, ERIAR_MASK_1111, 0x0000003f,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1448
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1449
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1450
		/* Reset packet filter */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1451
		rtl_w1w0_eri(tp, 0xdc, ERIAR_MASK_0001, 0x00, 0x01,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1452
			     ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1453
		rtl_w1w0_eri(tp, 0xdc, ERIAR_MASK_0001, 0x01, 0x00,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1454
			     ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1455
	} else if (tp->mac_version == RTL_GIGA_MAC_VER_35 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1456
		   tp->mac_version == RTL_GIGA_MAC_VER_36) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1457
		if (RTL_R8(PHYstatus) & _1000bpsF) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1458
			rtl_eri_write(tp, 0x1bc, ERIAR_MASK_1111, 0x00000011,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1459
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1460
			rtl_eri_write(tp, 0x1dc, ERIAR_MASK_1111, 0x00000005,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1461
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1462
		} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1463
			rtl_eri_write(tp, 0x1bc, ERIAR_MASK_1111, 0x0000001f,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1464
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1465
			rtl_eri_write(tp, 0x1dc, ERIAR_MASK_1111, 0x0000003f,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1466
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1467
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1468
	} else if (tp->mac_version == RTL_GIGA_MAC_VER_37) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1469
		if (RTL_R8(PHYstatus) & _10bps) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1470
			rtl_eri_write(tp, 0x1d0, ERIAR_MASK_0011, 0x4d02,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1471
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1472
			rtl_eri_write(tp, 0x1dc, ERIAR_MASK_0011, 0x0060,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1473
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1474
		} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1475
			rtl_eri_write(tp, 0x1d0, ERIAR_MASK_0011, 0x0000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1476
				      ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1477
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1478
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1479
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1480
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1481
static void __rtl8169_check_link_status(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1482
					struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1483
					void __iomem *ioaddr, bool pm)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1484
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1485
	if (tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1486
		ecdev_set_link(tp->ecdev, tp->link_ok(ioaddr) ? 1 : 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1487
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1488
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1489
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1490
	if (tp->link_ok(ioaddr)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1491
		rtl_link_chg_patch(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1492
		/* This is to cancel a scheduled suspend if there's one. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1493
		if (pm)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1494
			pm_request_resume(&tp->pci_dev->dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1495
		netif_carrier_on(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1496
		if (net_ratelimit())
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1497
			netif_info(tp, ifup, dev, "link up\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1498
	} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1499
		netif_carrier_off(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1500
		netif_info(tp, ifdown, dev, "link down\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1501
		if (pm)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1502
			pm_schedule_suspend(&tp->pci_dev->dev, 5000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1503
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1504
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1505
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1506
static void rtl8169_check_link_status(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1507
				      struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1508
				      void __iomem *ioaddr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1509
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1510
	__rtl8169_check_link_status(dev, tp, ioaddr, false);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1511
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1512
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1513
#define WAKE_ANY (WAKE_PHY | WAKE_MAGIC | WAKE_UCAST | WAKE_BCAST | WAKE_MCAST)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1514
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1515
static u32 __rtl8169_get_wol(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1516
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1517
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1518
	u8 options;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1519
	u32 wolopts = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1520
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1521
	options = RTL_R8(Config1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1522
	if (!(options & PMEnable))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1523
		return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1524
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1525
	options = RTL_R8(Config3);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1526
	if (options & LinkUp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1527
		wolopts |= WAKE_PHY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1528
	if (options & MagicPacket)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1529
		wolopts |= WAKE_MAGIC;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1530
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1531
	options = RTL_R8(Config5);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1532
	if (options & UWF)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1533
		wolopts |= WAKE_UCAST;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1534
	if (options & BWF)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1535
		wolopts |= WAKE_BCAST;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1536
	if (options & MWF)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1537
		wolopts |= WAKE_MCAST;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1538
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1539
	return wolopts;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1540
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1541
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1542
static void rtl8169_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1543
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1544
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1545
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1546
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1547
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1548
	wol->supported = WAKE_ANY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1549
	wol->wolopts = __rtl8169_get_wol(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1550
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1551
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1552
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1553
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1554
static void __rtl8169_set_wol(struct rtl8169_private *tp, u32 wolopts)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1555
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1556
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1557
	unsigned int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1558
	static const struct {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1559
		u32 opt;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1560
		u16 reg;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1561
		u8  mask;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1562
	} cfg[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1563
		{ WAKE_PHY,   Config3, LinkUp },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1564
		{ WAKE_MAGIC, Config3, MagicPacket },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1565
		{ WAKE_UCAST, Config5, UWF },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1566
		{ WAKE_BCAST, Config5, BWF },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1567
		{ WAKE_MCAST, Config5, MWF },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1568
		{ WAKE_ANY,   Config5, LanWake }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1569
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1570
	u8 options;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1571
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1572
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1573
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1574
	for (i = 0; i < ARRAY_SIZE(cfg); i++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1575
		options = RTL_R8(cfg[i].reg) & ~cfg[i].mask;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1576
		if (wolopts & cfg[i].opt)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1577
			options |= cfg[i].mask;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1578
		RTL_W8(cfg[i].reg, options);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1579
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1580
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1581
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1582
	case RTL_GIGA_MAC_VER_01 ... RTL_GIGA_MAC_VER_17:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1583
		options = RTL_R8(Config1) & ~PMEnable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1584
		if (wolopts)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1585
			options |= PMEnable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1586
		RTL_W8(Config1, options);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1587
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1588
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1589
		options = RTL_R8(Config2) & ~PME_SIGNAL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1590
		if (wolopts)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1591
			options |= PME_SIGNAL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1592
		RTL_W8(Config2, options);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1593
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1594
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1595
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1596
	RTL_W8(Cfg9346, Cfg9346_Lock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1597
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1598
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1599
static int rtl8169_set_wol(struct net_device *dev, struct ethtool_wolinfo *wol)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1600
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1601
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1602
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1603
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1604
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1605
	if (wol->wolopts)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1606
		tp->features |= RTL_FEATURE_WOL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1607
	else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1608
		tp->features &= ~RTL_FEATURE_WOL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1609
	__rtl8169_set_wol(tp, wol->wolopts);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1610
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1611
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1612
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1613
	device_set_wakeup_enable(&tp->pci_dev->dev, wol->wolopts);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1614
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1615
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1616
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1617
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1618
static const char *rtl_lookup_firmware_name(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1619
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1620
	return rtl_chip_infos[tp->mac_version].fw_name;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1621
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1622
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1623
static void rtl8169_get_drvinfo(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1624
				struct ethtool_drvinfo *info)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1625
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1626
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1627
	struct rtl_fw *rtl_fw = tp->rtl_fw;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1628
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1629
	strlcpy(info->driver, MODULENAME, sizeof(info->driver));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1630
	strlcpy(info->version, RTL8169_VERSION, sizeof(info->version));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1631
	strlcpy(info->bus_info, pci_name(tp->pci_dev), sizeof(info->bus_info));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1632
	BUILD_BUG_ON(sizeof(info->fw_version) < sizeof(rtl_fw->version));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1633
	if (!IS_ERR_OR_NULL(rtl_fw))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1634
		strlcpy(info->fw_version, rtl_fw->version,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1635
			sizeof(info->fw_version));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1636
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1637
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1638
static int rtl8169_get_regs_len(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1639
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1640
	return R8169_REGS_SIZE;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1641
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1642
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1643
static int rtl8169_set_speed_tbi(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1644
				 u8 autoneg, u16 speed, u8 duplex, u32 ignored)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1645
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1646
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1647
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1648
	int ret = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1649
	u32 reg;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1650
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1651
	reg = RTL_R32(TBICSR);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1652
	if ((autoneg == AUTONEG_DISABLE) && (speed == SPEED_1000) &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1653
	    (duplex == DUPLEX_FULL)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1654
		RTL_W32(TBICSR, reg & ~(TBINwEnable | TBINwRestart));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1655
	} else if (autoneg == AUTONEG_ENABLE)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1656
		RTL_W32(TBICSR, reg | TBINwEnable | TBINwRestart);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1657
	else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1658
		netif_warn(tp, link, dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1659
			   "incorrect speed setting refused in TBI mode\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1660
		ret = -EOPNOTSUPP;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1661
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1662
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1663
	return ret;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1664
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1665
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1666
static int rtl8169_set_speed_xmii(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1667
				  u8 autoneg, u16 speed, u8 duplex, u32 adv)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1668
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1669
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1670
	int giga_ctrl, bmcr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1671
	int rc = -EINVAL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1672
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1673
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1674
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1675
	if (autoneg == AUTONEG_ENABLE) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1676
		int auto_nego;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1677
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1678
		auto_nego = rtl_readphy(tp, MII_ADVERTISE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1679
		auto_nego &= ~(ADVERTISE_10HALF | ADVERTISE_10FULL |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1680
				ADVERTISE_100HALF | ADVERTISE_100FULL);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1681
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1682
		if (adv & ADVERTISED_10baseT_Half)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1683
			auto_nego |= ADVERTISE_10HALF;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1684
		if (adv & ADVERTISED_10baseT_Full)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1685
			auto_nego |= ADVERTISE_10FULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1686
		if (adv & ADVERTISED_100baseT_Half)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1687
			auto_nego |= ADVERTISE_100HALF;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1688
		if (adv & ADVERTISED_100baseT_Full)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1689
			auto_nego |= ADVERTISE_100FULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1690
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1691
		auto_nego |= ADVERTISE_PAUSE_CAP | ADVERTISE_PAUSE_ASYM;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1692
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1693
		giga_ctrl = rtl_readphy(tp, MII_CTRL1000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1694
		giga_ctrl &= ~(ADVERTISE_1000FULL | ADVERTISE_1000HALF);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1695
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1696
		/* The 8100e/8101e/8102e do Fast Ethernet only. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1697
		if (tp->mii.supports_gmii) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1698
			if (adv & ADVERTISED_1000baseT_Half)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1699
				giga_ctrl |= ADVERTISE_1000HALF;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1700
			if (adv & ADVERTISED_1000baseT_Full)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1701
				giga_ctrl |= ADVERTISE_1000FULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1702
		} else if (adv & (ADVERTISED_1000baseT_Half |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1703
				  ADVERTISED_1000baseT_Full)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1704
			netif_info(tp, link, dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1705
				   "PHY does not support 1000Mbps\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1706
			goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1707
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1708
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1709
		bmcr = BMCR_ANENABLE | BMCR_ANRESTART;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1710
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1711
		rtl_writephy(tp, MII_ADVERTISE, auto_nego);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1712
		rtl_writephy(tp, MII_CTRL1000, giga_ctrl);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1713
	} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1714
		giga_ctrl = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1715
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1716
		if (speed == SPEED_10)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1717
			bmcr = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1718
		else if (speed == SPEED_100)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1719
			bmcr = BMCR_SPEED100;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1720
		else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1721
			goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1722
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1723
		if (duplex == DUPLEX_FULL)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1724
			bmcr |= BMCR_FULLDPLX;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1725
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1726
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1727
	rtl_writephy(tp, MII_BMCR, bmcr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1728
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1729
	if (tp->mac_version == RTL_GIGA_MAC_VER_02 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1730
	    tp->mac_version == RTL_GIGA_MAC_VER_03) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1731
		if ((speed == SPEED_100) && (autoneg != AUTONEG_ENABLE)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1732
			rtl_writephy(tp, 0x17, 0x2138);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1733
			rtl_writephy(tp, 0x0e, 0x0260);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1734
		} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1735
			rtl_writephy(tp, 0x17, 0x2108);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1736
			rtl_writephy(tp, 0x0e, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1737
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1738
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1739
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1740
	rc = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1741
out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1742
	return rc;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1743
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1744
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1745
static int rtl8169_set_speed(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1746
			     u8 autoneg, u16 speed, u8 duplex, u32 advertising)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1747
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1748
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1749
	int ret;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1750
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1751
	ret = tp->set_speed(dev, autoneg, speed, duplex, advertising);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1752
	if (ret < 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1753
		goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1754
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1755
	if (!tp->ecdev && netif_running(dev) && (autoneg == AUTONEG_ENABLE) &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1756
	    (advertising & ADVERTISED_1000baseT_Full)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1757
		mod_timer(&tp->timer, jiffies + RTL8169_PHY_TIMEOUT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1758
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1759
out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1760
	return ret;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1761
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1762
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1763
static int rtl8169_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1764
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1765
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1766
	int ret;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1767
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1768
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1769
		del_timer_sync(&tp->timer);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1770
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1771
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1772
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1773
	ret = rtl8169_set_speed(dev, cmd->autoneg, ethtool_cmd_speed(cmd),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1774
				cmd->duplex, cmd->advertising);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1775
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1776
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1777
	return ret;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1778
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1779
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1780
static netdev_features_t rtl8169_fix_features(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1781
	netdev_features_t features)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1782
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1783
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1784
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1785
	if (dev->mtu > TD_MSS_MAX)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1786
		features &= ~NETIF_F_ALL_TSO;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1787
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1788
	if (dev->mtu > JUMBO_1K &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1789
	    !rtl_chip_infos[tp->mac_version].jumbo_tx_csum)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1790
		features &= ~NETIF_F_IP_CSUM;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1791
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1792
	return features;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1793
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1794
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1795
static void __rtl8169_set_features(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1796
				   netdev_features_t features)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1797
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1798
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1799
	netdev_features_t changed = features ^ dev->features;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1800
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1801
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1802
	if (!(changed & (NETIF_F_RXALL | NETIF_F_RXCSUM | NETIF_F_HW_VLAN_RX)))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1803
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1804
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1805
	if (changed & (NETIF_F_RXCSUM | NETIF_F_HW_VLAN_RX)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1806
		if (features & NETIF_F_RXCSUM)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1807
			tp->cp_cmd |= RxChkSum;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1808
		else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1809
			tp->cp_cmd &= ~RxChkSum;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1810
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1811
		if (dev->features & NETIF_F_HW_VLAN_RX)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1812
			tp->cp_cmd |= RxVlan;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1813
		else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1814
			tp->cp_cmd &= ~RxVlan;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1815
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1816
		RTL_W16(CPlusCmd, tp->cp_cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1817
		RTL_R16(CPlusCmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1818
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1819
	if (changed & NETIF_F_RXALL) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1820
		int tmp = (RTL_R32(RxConfig) & ~(AcceptErr | AcceptRunt));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1821
		if (features & NETIF_F_RXALL)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1822
			tmp |= (AcceptErr | AcceptRunt);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1823
		RTL_W32(RxConfig, tmp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1824
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1825
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1826
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1827
static int rtl8169_set_features(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1828
				netdev_features_t features)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1829
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1830
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1831
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1832
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1833
	__rtl8169_set_features(dev, features);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1834
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1835
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1836
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1837
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1838
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1839
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1840
static inline u32 rtl8169_tx_vlan_tag(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1841
				      struct sk_buff *skb)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1842
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1843
	return (vlan_tx_tag_present(skb)) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1844
		TxVlanTag | swab16(vlan_tx_tag_get(skb)) : 0x00;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1845
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1846
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1847
static void rtl8169_rx_vlan_tag(struct RxDesc *desc, struct sk_buff *skb)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1848
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1849
	u32 opts2 = le32_to_cpu(desc->opts2);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1850
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1851
	if (opts2 & RxVlanTag)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1852
		__vlan_hwaccel_put_tag(skb, swab16(opts2 & 0xffff));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1853
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1854
	desc->opts2 = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1855
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1856
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1857
static int rtl8169_gset_tbi(struct net_device *dev, struct ethtool_cmd *cmd)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1858
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1859
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1860
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1861
	u32 status;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1862
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1863
	cmd->supported =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1864
		SUPPORTED_1000baseT_Full | SUPPORTED_Autoneg | SUPPORTED_FIBRE;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1865
	cmd->port = PORT_FIBRE;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1866
	cmd->transceiver = XCVR_INTERNAL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1867
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1868
	status = RTL_R32(TBICSR);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1869
	cmd->advertising = (status & TBINwEnable) ?  ADVERTISED_Autoneg : 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1870
	cmd->autoneg = !!(status & TBINwEnable);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1871
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1872
	ethtool_cmd_speed_set(cmd, SPEED_1000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1873
	cmd->duplex = DUPLEX_FULL; /* Always set */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1874
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1875
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1876
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1877
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1878
static int rtl8169_gset_xmii(struct net_device *dev, struct ethtool_cmd *cmd)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1879
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1880
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1881
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1882
	return mii_ethtool_gset(&tp->mii, cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1883
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1884
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1885
static int rtl8169_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1886
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1887
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1888
	int rc;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1889
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1890
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1891
	rc = tp->get_settings(dev, cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1892
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1893
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1894
	return rc;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1895
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1896
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1897
static void rtl8169_get_regs(struct net_device *dev, struct ethtool_regs *regs,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1898
			     void *p)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1899
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1900
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1901
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1902
	if (regs->len > R8169_REGS_SIZE)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1903
		regs->len = R8169_REGS_SIZE;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1904
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1905
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1906
	memcpy_fromio(p, tp->mmio_addr, regs->len);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1907
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1908
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1909
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1910
static u32 rtl8169_get_msglevel(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1911
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1912
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1913
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1914
	return tp->msg_enable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1915
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1916
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1917
static void rtl8169_set_msglevel(struct net_device *dev, u32 value)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1918
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1919
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1920
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1921
	tp->msg_enable = value;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1922
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1923
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1924
static const char rtl8169_gstrings[][ETH_GSTRING_LEN] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1925
	"tx_packets",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1926
	"rx_packets",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1927
	"tx_errors",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1928
	"rx_errors",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1929
	"rx_missed",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1930
	"align_errors",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1931
	"tx_single_collisions",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1932
	"tx_multi_collisions",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1933
	"unicast",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1934
	"broadcast",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1935
	"multicast",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1936
	"tx_aborted",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1937
	"tx_underrun",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1938
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1939
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1940
static int rtl8169_get_sset_count(struct net_device *dev, int sset)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1941
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1942
	switch (sset) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1943
	case ETH_SS_STATS:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1944
		return ARRAY_SIZE(rtl8169_gstrings);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1945
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1946
		return -EOPNOTSUPP;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1947
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1948
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1949
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1950
DECLARE_RTL_COND(rtl_counters_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1951
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1952
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1953
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1954
	return RTL_R32(CounterAddrLow) & CounterDump;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1955
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1956
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1957
static void rtl8169_update_counters(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1958
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1959
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1960
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1961
	struct device *d = &tp->pci_dev->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1962
	struct rtl8169_counters *counters;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1963
	dma_addr_t paddr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1964
	u32 cmd;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1965
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1966
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1967
	 * Some chips are unable to dump tally counters when the receiver
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1968
	 * is disabled.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1969
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1970
	if ((RTL_R8(ChipCmd) & CmdRxEnb) == 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1971
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1972
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1973
	counters = dma_alloc_coherent(d, sizeof(*counters), &paddr, GFP_KERNEL);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1974
	if (!counters)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1975
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1976
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1977
	RTL_W32(CounterAddrHigh, (u64)paddr >> 32);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1978
	cmd = (u64)paddr & DMA_BIT_MASK(32);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1979
	RTL_W32(CounterAddrLow, cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1980
	RTL_W32(CounterAddrLow, cmd | CounterDump);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1981
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1982
	if (rtl_udelay_loop_wait_low(tp, &rtl_counters_cond, 10, 1000))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1983
		memcpy(&tp->counters, counters, sizeof(*counters));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1984
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1985
	RTL_W32(CounterAddrLow, 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1986
	RTL_W32(CounterAddrHigh, 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1987
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1988
	dma_free_coherent(d, sizeof(*counters), counters, paddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1989
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1990
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1991
static void rtl8169_get_ethtool_stats(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1992
				      struct ethtool_stats *stats, u64 *data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1993
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1994
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1995
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1996
	ASSERT_RTNL();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1997
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1998
	rtl8169_update_counters(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  1999
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2000
	data[0] = le64_to_cpu(tp->counters.tx_packets);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2001
	data[1] = le64_to_cpu(tp->counters.rx_packets);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2002
	data[2] = le64_to_cpu(tp->counters.tx_errors);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2003
	data[3] = le32_to_cpu(tp->counters.rx_errors);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2004
	data[4] = le16_to_cpu(tp->counters.rx_missed);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2005
	data[5] = le16_to_cpu(tp->counters.align_errors);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2006
	data[6] = le32_to_cpu(tp->counters.tx_one_collision);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2007
	data[7] = le32_to_cpu(tp->counters.tx_multi_collision);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2008
	data[8] = le64_to_cpu(tp->counters.rx_unicast);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2009
	data[9] = le64_to_cpu(tp->counters.rx_broadcast);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2010
	data[10] = le32_to_cpu(tp->counters.rx_multicast);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2011
	data[11] = le16_to_cpu(tp->counters.tx_aborted);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2012
	data[12] = le16_to_cpu(tp->counters.tx_underun);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2013
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2014
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2015
static void rtl8169_get_strings(struct net_device *dev, u32 stringset, u8 *data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2016
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2017
	switch(stringset) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2018
	case ETH_SS_STATS:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2019
		memcpy(data, *rtl8169_gstrings, sizeof(rtl8169_gstrings));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2020
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2021
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2022
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2023
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2024
static const struct ethtool_ops rtl8169_ethtool_ops = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2025
	.get_drvinfo		= rtl8169_get_drvinfo,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2026
	.get_regs_len		= rtl8169_get_regs_len,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2027
	.get_link		= ethtool_op_get_link,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2028
	.get_settings		= rtl8169_get_settings,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2029
	.set_settings		= rtl8169_set_settings,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2030
	.get_msglevel		= rtl8169_get_msglevel,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2031
	.set_msglevel		= rtl8169_set_msglevel,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2032
	.get_regs		= rtl8169_get_regs,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2033
	.get_wol		= rtl8169_get_wol,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2034
	.set_wol		= rtl8169_set_wol,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2035
	.get_strings		= rtl8169_get_strings,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2036
	.get_sset_count		= rtl8169_get_sset_count,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2037
	.get_ethtool_stats	= rtl8169_get_ethtool_stats,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2038
	.get_ts_info		= ethtool_op_get_ts_info,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2039
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2040
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2041
static void rtl8169_get_mac_version(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2042
				    struct net_device *dev, u8 default_version)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2043
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2044
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2045
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2046
	 * The driver currently handles the 8168Bf and the 8168Be identically
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2047
	 * but they can be identified more specifically through the test below
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2048
	 * if needed:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2049
	 *
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2050
	 * (RTL_R32(TxConfig) & 0x700000) == 0x500000 ? 8168Bf : 8168Be
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2051
	 *
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2052
	 * Same thing for the 8101Eb and the 8101Ec:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2053
	 *
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2054
	 * (RTL_R32(TxConfig) & 0x700000) == 0x200000 ? 8101Eb : 8101Ec
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2055
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2056
	static const struct rtl_mac_info {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2057
		u32 mask;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2058
		u32 val;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2059
		int mac_version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2060
	} mac_info[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2061
		/* 8168G family. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2062
		{ 0x7cf00000, 0x4c100000,	RTL_GIGA_MAC_VER_41 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2063
		{ 0x7cf00000, 0x4c000000,	RTL_GIGA_MAC_VER_40 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2064
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2065
		/* 8168F family. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2066
		{ 0x7c800000, 0x48800000,	RTL_GIGA_MAC_VER_38 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2067
		{ 0x7cf00000, 0x48100000,	RTL_GIGA_MAC_VER_36 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2068
		{ 0x7cf00000, 0x48000000,	RTL_GIGA_MAC_VER_35 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2069
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2070
		/* 8168E family. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2071
		{ 0x7c800000, 0x2c800000,	RTL_GIGA_MAC_VER_34 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2072
		{ 0x7cf00000, 0x2c200000,	RTL_GIGA_MAC_VER_33 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2073
		{ 0x7cf00000, 0x2c100000,	RTL_GIGA_MAC_VER_32 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2074
		{ 0x7c800000, 0x2c000000,	RTL_GIGA_MAC_VER_33 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2075
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2076
		/* 8168D family. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2077
		{ 0x7cf00000, 0x28300000,	RTL_GIGA_MAC_VER_26 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2078
		{ 0x7cf00000, 0x28100000,	RTL_GIGA_MAC_VER_25 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2079
		{ 0x7c800000, 0x28000000,	RTL_GIGA_MAC_VER_26 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2080
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2081
		/* 8168DP family. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2082
		{ 0x7cf00000, 0x28800000,	RTL_GIGA_MAC_VER_27 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2083
		{ 0x7cf00000, 0x28a00000,	RTL_GIGA_MAC_VER_28 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2084
		{ 0x7cf00000, 0x28b00000,	RTL_GIGA_MAC_VER_31 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2085
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2086
		/* 8168C family. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2087
		{ 0x7cf00000, 0x3cb00000,	RTL_GIGA_MAC_VER_24 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2088
		{ 0x7cf00000, 0x3c900000,	RTL_GIGA_MAC_VER_23 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2089
		{ 0x7cf00000, 0x3c800000,	RTL_GIGA_MAC_VER_18 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2090
		{ 0x7c800000, 0x3c800000,	RTL_GIGA_MAC_VER_24 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2091
		{ 0x7cf00000, 0x3c000000,	RTL_GIGA_MAC_VER_19 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2092
		{ 0x7cf00000, 0x3c200000,	RTL_GIGA_MAC_VER_20 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2093
		{ 0x7cf00000, 0x3c300000,	RTL_GIGA_MAC_VER_21 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2094
		{ 0x7cf00000, 0x3c400000,	RTL_GIGA_MAC_VER_22 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2095
		{ 0x7c800000, 0x3c000000,	RTL_GIGA_MAC_VER_22 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2096
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2097
		/* 8168B family. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2098
		{ 0x7cf00000, 0x38000000,	RTL_GIGA_MAC_VER_12 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2099
		{ 0x7cf00000, 0x38500000,	RTL_GIGA_MAC_VER_17 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2100
		{ 0x7c800000, 0x38000000,	RTL_GIGA_MAC_VER_17 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2101
		{ 0x7c800000, 0x30000000,	RTL_GIGA_MAC_VER_11 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2102
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2103
		/* 8101 family. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2104
		{ 0x7cf00000, 0x44900000,	RTL_GIGA_MAC_VER_39 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2105
		{ 0x7c800000, 0x44800000,	RTL_GIGA_MAC_VER_39 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2106
		{ 0x7c800000, 0x44000000,	RTL_GIGA_MAC_VER_37 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2107
		{ 0x7cf00000, 0x40b00000,	RTL_GIGA_MAC_VER_30 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2108
		{ 0x7cf00000, 0x40a00000,	RTL_GIGA_MAC_VER_30 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2109
		{ 0x7cf00000, 0x40900000,	RTL_GIGA_MAC_VER_29 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2110
		{ 0x7c800000, 0x40800000,	RTL_GIGA_MAC_VER_30 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2111
		{ 0x7cf00000, 0x34a00000,	RTL_GIGA_MAC_VER_09 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2112
		{ 0x7cf00000, 0x24a00000,	RTL_GIGA_MAC_VER_09 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2113
		{ 0x7cf00000, 0x34900000,	RTL_GIGA_MAC_VER_08 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2114
		{ 0x7cf00000, 0x24900000,	RTL_GIGA_MAC_VER_08 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2115
		{ 0x7cf00000, 0x34800000,	RTL_GIGA_MAC_VER_07 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2116
		{ 0x7cf00000, 0x24800000,	RTL_GIGA_MAC_VER_07 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2117
		{ 0x7cf00000, 0x34000000,	RTL_GIGA_MAC_VER_13 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2118
		{ 0x7cf00000, 0x34300000,	RTL_GIGA_MAC_VER_10 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2119
		{ 0x7cf00000, 0x34200000,	RTL_GIGA_MAC_VER_16 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2120
		{ 0x7c800000, 0x34800000,	RTL_GIGA_MAC_VER_09 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2121
		{ 0x7c800000, 0x24800000,	RTL_GIGA_MAC_VER_09 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2122
		{ 0x7c800000, 0x34000000,	RTL_GIGA_MAC_VER_16 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2123
		/* FIXME: where did these entries come from ? -- FR */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2124
		{ 0xfc800000, 0x38800000,	RTL_GIGA_MAC_VER_15 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2125
		{ 0xfc800000, 0x30800000,	RTL_GIGA_MAC_VER_14 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2126
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2127
		/* 8110 family. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2128
		{ 0xfc800000, 0x98000000,	RTL_GIGA_MAC_VER_06 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2129
		{ 0xfc800000, 0x18000000,	RTL_GIGA_MAC_VER_05 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2130
		{ 0xfc800000, 0x10000000,	RTL_GIGA_MAC_VER_04 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2131
		{ 0xfc800000, 0x04000000,	RTL_GIGA_MAC_VER_03 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2132
		{ 0xfc800000, 0x00800000,	RTL_GIGA_MAC_VER_02 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2133
		{ 0xfc800000, 0x00000000,	RTL_GIGA_MAC_VER_01 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2134
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2135
		/* Catch-all */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2136
		{ 0x00000000, 0x00000000,	RTL_GIGA_MAC_NONE   }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2137
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2138
	const struct rtl_mac_info *p = mac_info;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2139
	u32 reg;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2140
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2141
	reg = RTL_R32(TxConfig);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2142
	while ((reg & p->mask) != p->val)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2143
		p++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2144
	tp->mac_version = p->mac_version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2145
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2146
	if (tp->mac_version == RTL_GIGA_MAC_NONE) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2147
		netif_notice(tp, probe, dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2148
			     "unknown MAC, using family default\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2149
		tp->mac_version = default_version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2150
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2151
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2152
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2153
static void rtl8169_print_mac_version(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2154
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2155
	dprintk("mac_version = 0x%02x\n", tp->mac_version);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2156
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2157
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2158
struct phy_reg {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2159
	u16 reg;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2160
	u16 val;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2161
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2162
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2163
static void rtl_writephy_batch(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2164
			       const struct phy_reg *regs, int len)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2165
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2166
	while (len-- > 0) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2167
		rtl_writephy(tp, regs->reg, regs->val);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2168
		regs++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2169
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2170
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2171
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2172
#define PHY_READ		0x00000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2173
#define PHY_DATA_OR		0x10000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2174
#define PHY_DATA_AND		0x20000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2175
#define PHY_BJMPN		0x30000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2176
#define PHY_READ_EFUSE		0x40000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2177
#define PHY_READ_MAC_BYTE	0x50000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2178
#define PHY_WRITE_MAC_BYTE	0x60000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2179
#define PHY_CLEAR_READCOUNT	0x70000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2180
#define PHY_WRITE		0x80000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2181
#define PHY_READCOUNT_EQ_SKIP	0x90000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2182
#define PHY_COMP_EQ_SKIPN	0xa0000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2183
#define PHY_COMP_NEQ_SKIPN	0xb0000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2184
#define PHY_WRITE_PREVIOUS	0xc0000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2185
#define PHY_SKIPN		0xd0000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2186
#define PHY_DELAY_MS		0xe0000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2187
#define PHY_WRITE_ERI_WORD	0xf0000000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2188
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2189
struct fw_info {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2190
	u32	magic;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2191
	char	version[RTL_VER_SIZE];
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2192
	__le32	fw_start;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2193
	__le32	fw_len;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2194
	u8	chksum;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2195
} __packed;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2196
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2197
#define FW_OPCODE_SIZE	sizeof(typeof(*((struct rtl_fw_phy_action *)0)->code))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2198
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2199
static bool rtl_fw_format_ok(struct rtl8169_private *tp, struct rtl_fw *rtl_fw)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2200
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2201
	const struct firmware *fw = rtl_fw->fw;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2202
	struct fw_info *fw_info = (struct fw_info *)fw->data;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2203
	struct rtl_fw_phy_action *pa = &rtl_fw->phy_action;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2204
	char *version = rtl_fw->version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2205
	bool rc = false;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2206
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2207
	if (fw->size < FW_OPCODE_SIZE)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2208
		goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2209
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2210
	if (!fw_info->magic) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2211
		size_t i, size, start;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2212
		u8 checksum = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2213
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2214
		if (fw->size < sizeof(*fw_info))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2215
			goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2216
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2217
		for (i = 0; i < fw->size; i++)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2218
			checksum += fw->data[i];
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2219
		if (checksum != 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2220
			goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2221
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2222
		start = le32_to_cpu(fw_info->fw_start);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2223
		if (start > fw->size)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2224
			goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2225
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2226
		size = le32_to_cpu(fw_info->fw_len);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2227
		if (size > (fw->size - start) / FW_OPCODE_SIZE)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2228
			goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2229
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2230
		memcpy(version, fw_info->version, RTL_VER_SIZE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2231
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2232
		pa->code = (__le32 *)(fw->data + start);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2233
		pa->size = size;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2234
	} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2235
		if (fw->size % FW_OPCODE_SIZE)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2236
			goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2237
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2238
		strlcpy(version, rtl_lookup_firmware_name(tp), RTL_VER_SIZE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2239
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2240
		pa->code = (__le32 *)fw->data;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2241
		pa->size = fw->size / FW_OPCODE_SIZE;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2242
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2243
	version[RTL_VER_SIZE - 1] = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2244
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2245
	rc = true;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2246
out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2247
	return rc;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2248
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2249
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2250
static bool rtl_fw_data_ok(struct rtl8169_private *tp, struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2251
			   struct rtl_fw_phy_action *pa)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2252
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2253
	bool rc = false;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2254
	size_t index;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2255
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2256
	for (index = 0; index < pa->size; index++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2257
		u32 action = le32_to_cpu(pa->code[index]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2258
		u32 regno = (action & 0x0fff0000) >> 16;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2259
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2260
		switch(action & 0xf0000000) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2261
		case PHY_READ:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2262
		case PHY_DATA_OR:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2263
		case PHY_DATA_AND:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2264
		case PHY_READ_EFUSE:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2265
		case PHY_CLEAR_READCOUNT:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2266
		case PHY_WRITE:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2267
		case PHY_WRITE_PREVIOUS:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2268
		case PHY_DELAY_MS:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2269
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2270
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2271
		case PHY_BJMPN:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2272
			if (regno > index) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2273
				netif_err(tp, ifup, tp->dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2274
					  "Out of range of firmware\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2275
				goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2276
			}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2277
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2278
		case PHY_READCOUNT_EQ_SKIP:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2279
			if (index + 2 >= pa->size) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2280
				netif_err(tp, ifup, tp->dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2281
					  "Out of range of firmware\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2282
				goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2283
			}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2284
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2285
		case PHY_COMP_EQ_SKIPN:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2286
		case PHY_COMP_NEQ_SKIPN:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2287
		case PHY_SKIPN:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2288
			if (index + 1 + regno >= pa->size) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2289
				netif_err(tp, ifup, tp->dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2290
					  "Out of range of firmware\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2291
				goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2292
			}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2293
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2294
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2295
		case PHY_READ_MAC_BYTE:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2296
		case PHY_WRITE_MAC_BYTE:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2297
		case PHY_WRITE_ERI_WORD:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2298
		default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2299
			netif_err(tp, ifup, tp->dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2300
				  "Invalid action 0x%08x\n", action);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2301
			goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2302
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2303
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2304
	rc = true;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2305
out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2306
	return rc;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2307
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2308
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2309
static int rtl_check_firmware(struct rtl8169_private *tp, struct rtl_fw *rtl_fw)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2310
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2311
	struct net_device *dev = tp->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2312
	int rc = -EINVAL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2313
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2314
	if (!rtl_fw_format_ok(tp, rtl_fw)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2315
		netif_err(tp, ifup, dev, "invalid firwmare\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2316
		goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2317
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2318
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2319
	if (rtl_fw_data_ok(tp, dev, &rtl_fw->phy_action))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2320
		rc = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2321
out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2322
	return rc;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2323
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2324
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2325
static void rtl_phy_write_fw(struct rtl8169_private *tp, struct rtl_fw *rtl_fw)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2326
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2327
	struct rtl_fw_phy_action *pa = &rtl_fw->phy_action;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2328
	u32 predata, count;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2329
	size_t index;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2330
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2331
	predata = count = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2332
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2333
	for (index = 0; index < pa->size; ) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2334
		u32 action = le32_to_cpu(pa->code[index]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2335
		u32 data = action & 0x0000ffff;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2336
		u32 regno = (action & 0x0fff0000) >> 16;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2337
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2338
		if (!action)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2339
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2340
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2341
		switch(action & 0xf0000000) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2342
		case PHY_READ:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2343
			predata = rtl_readphy(tp, regno);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2344
			count++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2345
			index++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2346
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2347
		case PHY_DATA_OR:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2348
			predata |= data;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2349
			index++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2350
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2351
		case PHY_DATA_AND:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2352
			predata &= data;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2353
			index++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2354
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2355
		case PHY_BJMPN:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2356
			index -= regno;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2357
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2358
		case PHY_READ_EFUSE:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2359
			predata = rtl8168d_efuse_read(tp, regno);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2360
			index++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2361
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2362
		case PHY_CLEAR_READCOUNT:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2363
			count = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2364
			index++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2365
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2366
		case PHY_WRITE:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2367
			rtl_writephy(tp, regno, data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2368
			index++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2369
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2370
		case PHY_READCOUNT_EQ_SKIP:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2371
			index += (count == data) ? 2 : 1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2372
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2373
		case PHY_COMP_EQ_SKIPN:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2374
			if (predata == data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2375
				index += regno;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2376
			index++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2377
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2378
		case PHY_COMP_NEQ_SKIPN:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2379
			if (predata != data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2380
				index += regno;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2381
			index++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2382
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2383
		case PHY_WRITE_PREVIOUS:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2384
			rtl_writephy(tp, regno, predata);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2385
			index++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2386
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2387
		case PHY_SKIPN:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2388
			index += regno + 1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2389
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2390
		case PHY_DELAY_MS:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2391
			mdelay(data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2392
			index++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2393
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2394
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2395
		case PHY_READ_MAC_BYTE:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2396
		case PHY_WRITE_MAC_BYTE:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2397
		case PHY_WRITE_ERI_WORD:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2398
		default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2399
			BUG();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2400
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2401
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2402
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2403
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2404
static void rtl_release_firmware(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2405
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2406
	if (!IS_ERR_OR_NULL(tp->rtl_fw)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2407
		release_firmware(tp->rtl_fw->fw);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2408
		kfree(tp->rtl_fw);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2409
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2410
	tp->rtl_fw = RTL_FIRMWARE_UNKNOWN;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2411
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2412
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2413
static void rtl_apply_firmware(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2414
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2415
	struct rtl_fw *rtl_fw = tp->rtl_fw;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2416
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2417
	/* TODO: release firmware once rtl_phy_write_fw signals failures. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2418
	if (!IS_ERR_OR_NULL(rtl_fw))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2419
		rtl_phy_write_fw(tp, rtl_fw);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2420
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2421
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2422
static void rtl_apply_firmware_cond(struct rtl8169_private *tp, u8 reg, u16 val)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2423
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2424
	if (rtl_readphy(tp, reg) != val)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2425
		netif_warn(tp, hw, tp->dev, "chipset not ready for firmware\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2426
	else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2427
		rtl_apply_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2428
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2429
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2430
static void rtl8169s_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2431
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2432
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2433
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2434
		{ 0x06, 0x006e },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2435
		{ 0x08, 0x0708 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2436
		{ 0x15, 0x4000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2437
		{ 0x18, 0x65c7 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2438
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2439
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2440
		{ 0x03, 0x00a1 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2441
		{ 0x02, 0x0008 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2442
		{ 0x01, 0x0120 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2443
		{ 0x00, 0x1000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2444
		{ 0x04, 0x0800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2445
		{ 0x04, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2446
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2447
		{ 0x03, 0xff41 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2448
		{ 0x02, 0xdf60 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2449
		{ 0x01, 0x0140 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2450
		{ 0x00, 0x0077 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2451
		{ 0x04, 0x7800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2452
		{ 0x04, 0x7000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2453
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2454
		{ 0x03, 0x802f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2455
		{ 0x02, 0x4f02 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2456
		{ 0x01, 0x0409 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2457
		{ 0x00, 0xf0f9 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2458
		{ 0x04, 0x9800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2459
		{ 0x04, 0x9000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2460
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2461
		{ 0x03, 0xdf01 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2462
		{ 0x02, 0xdf20 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2463
		{ 0x01, 0xff95 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2464
		{ 0x00, 0xba00 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2465
		{ 0x04, 0xa800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2466
		{ 0x04, 0xa000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2467
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2468
		{ 0x03, 0xff41 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2469
		{ 0x02, 0xdf20 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2470
		{ 0x01, 0x0140 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2471
		{ 0x00, 0x00bb },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2472
		{ 0x04, 0xb800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2473
		{ 0x04, 0xb000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2474
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2475
		{ 0x03, 0xdf41 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2476
		{ 0x02, 0xdc60 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2477
		{ 0x01, 0x6340 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2478
		{ 0x00, 0x007d },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2479
		{ 0x04, 0xd800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2480
		{ 0x04, 0xd000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2481
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2482
		{ 0x03, 0xdf01 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2483
		{ 0x02, 0xdf20 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2484
		{ 0x01, 0x100a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2485
		{ 0x00, 0xa0ff },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2486
		{ 0x04, 0xf800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2487
		{ 0x04, 0xf000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2488
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2489
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2490
		{ 0x0b, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2491
		{ 0x00, 0x9200 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2492
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2493
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2494
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2495
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2496
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2497
static void rtl8169sb_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2498
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2499
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2500
		{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2501
		{ 0x01, 0x90d0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2502
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2503
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2504
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2505
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2506
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2507
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2508
static void rtl8169scd_hw_phy_config_quirk(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2509
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2510
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2511
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2512
	if ((pdev->subsystem_vendor != PCI_VENDOR_ID_GIGABYTE) ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2513
	    (pdev->subsystem_device != 0xe000))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2514
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2515
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2516
	rtl_writephy(tp, 0x1f, 0x0001);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2517
	rtl_writephy(tp, 0x10, 0xf01b);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2518
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2519
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2520
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2521
static void rtl8169scd_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2522
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2523
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2524
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2525
		{ 0x04, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2526
		{ 0x03, 0x00a1 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2527
		{ 0x02, 0x0008 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2528
		{ 0x01, 0x0120 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2529
		{ 0x00, 0x1000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2530
		{ 0x04, 0x0800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2531
		{ 0x04, 0x9000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2532
		{ 0x03, 0x802f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2533
		{ 0x02, 0x4f02 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2534
		{ 0x01, 0x0409 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2535
		{ 0x00, 0xf099 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2536
		{ 0x04, 0x9800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2537
		{ 0x04, 0xa000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2538
		{ 0x03, 0xdf01 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2539
		{ 0x02, 0xdf20 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2540
		{ 0x01, 0xff95 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2541
		{ 0x00, 0xba00 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2542
		{ 0x04, 0xa800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2543
		{ 0x04, 0xf000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2544
		{ 0x03, 0xdf01 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2545
		{ 0x02, 0xdf20 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2546
		{ 0x01, 0x101a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2547
		{ 0x00, 0xa0ff },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2548
		{ 0x04, 0xf800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2549
		{ 0x04, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2550
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2551
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2552
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2553
		{ 0x10, 0xf41b },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2554
		{ 0x14, 0xfb54 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2555
		{ 0x18, 0xf5c7 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2556
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2557
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2558
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2559
		{ 0x17, 0x0cc0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2560
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2561
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2562
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2563
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2564
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2565
	rtl8169scd_hw_phy_config_quirk(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2566
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2567
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2568
static void rtl8169sce_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2569
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2570
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2571
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2572
		{ 0x04, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2573
		{ 0x03, 0x00a1 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2574
		{ 0x02, 0x0008 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2575
		{ 0x01, 0x0120 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2576
		{ 0x00, 0x1000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2577
		{ 0x04, 0x0800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2578
		{ 0x04, 0x9000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2579
		{ 0x03, 0x802f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2580
		{ 0x02, 0x4f02 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2581
		{ 0x01, 0x0409 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2582
		{ 0x00, 0xf099 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2583
		{ 0x04, 0x9800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2584
		{ 0x04, 0xa000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2585
		{ 0x03, 0xdf01 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2586
		{ 0x02, 0xdf20 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2587
		{ 0x01, 0xff95 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2588
		{ 0x00, 0xba00 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2589
		{ 0x04, 0xa800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2590
		{ 0x04, 0xf000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2591
		{ 0x03, 0xdf01 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2592
		{ 0x02, 0xdf20 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2593
		{ 0x01, 0x101a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2594
		{ 0x00, 0xa0ff },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2595
		{ 0x04, 0xf800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2596
		{ 0x04, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2597
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2598
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2599
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2600
		{ 0x0b, 0x8480 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2601
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2602
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2603
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2604
		{ 0x18, 0x67c7 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2605
		{ 0x04, 0x2000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2606
		{ 0x03, 0x002f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2607
		{ 0x02, 0x4360 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2608
		{ 0x01, 0x0109 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2609
		{ 0x00, 0x3022 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2610
		{ 0x04, 0x2800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2611
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2612
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2613
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2614
		{ 0x17, 0x0cc0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2615
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2616
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2617
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2618
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2619
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2620
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2621
static void rtl8168bb_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2622
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2623
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2624
		{ 0x10, 0xf41b },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2625
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2626
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2627
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2628
	rtl_writephy(tp, 0x1f, 0x0001);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2629
	rtl_patchphy(tp, 0x16, 1 << 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2630
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2631
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2632
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2633
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2634
static void rtl8168bef_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2635
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2636
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2637
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2638
		{ 0x10, 0xf41b },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2639
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2640
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2641
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2642
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2643
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2644
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2645
static void rtl8168cp_1_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2646
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2647
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2648
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2649
		{ 0x1d, 0x0f00 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2650
		{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2651
		{ 0x0c, 0x1ec8 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2652
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2653
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2654
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2655
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2656
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2657
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2658
static void rtl8168cp_2_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2659
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2660
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2661
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2662
		{ 0x1d, 0x3d98 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2663
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2664
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2665
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2666
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2667
	rtl_patchphy(tp, 0x14, 1 << 5);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2668
	rtl_patchphy(tp, 0x0d, 1 << 5);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2669
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2670
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2671
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2672
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2673
static void rtl8168c_1_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2674
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2675
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2676
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2677
		{ 0x12, 0x2300 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2678
		{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2679
		{ 0x00, 0x88d4 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2680
		{ 0x01, 0x82b1 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2681
		{ 0x03, 0x7002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2682
		{ 0x08, 0x9e30 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2683
		{ 0x09, 0x01f0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2684
		{ 0x0a, 0x5500 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2685
		{ 0x0c, 0x00c8 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2686
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2687
		{ 0x12, 0xc096 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2688
		{ 0x16, 0x000a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2689
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2690
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2691
		{ 0x09, 0x2000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2692
		{ 0x09, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2693
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2694
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2695
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2696
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2697
	rtl_patchphy(tp, 0x14, 1 << 5);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2698
	rtl_patchphy(tp, 0x0d, 1 << 5);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2699
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2700
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2701
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2702
static void rtl8168c_2_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2703
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2704
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2705
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2706
		{ 0x12, 0x2300 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2707
		{ 0x03, 0x802f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2708
		{ 0x02, 0x4f02 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2709
		{ 0x01, 0x0409 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2710
		{ 0x00, 0xf099 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2711
		{ 0x04, 0x9800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2712
		{ 0x04, 0x9000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2713
		{ 0x1d, 0x3d98 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2714
		{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2715
		{ 0x0c, 0x7eb8 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2716
		{ 0x06, 0x0761 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2717
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2718
		{ 0x16, 0x0f0a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2719
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2720
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2721
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2722
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2723
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2724
	rtl_patchphy(tp, 0x16, 1 << 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2725
	rtl_patchphy(tp, 0x14, 1 << 5);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2726
	rtl_patchphy(tp, 0x0d, 1 << 5);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2727
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2728
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2729
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2730
static void rtl8168c_3_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2731
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2732
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2733
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2734
		{ 0x12, 0x2300 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2735
		{ 0x1d, 0x3d98 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2736
		{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2737
		{ 0x0c, 0x7eb8 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2738
		{ 0x06, 0x5461 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2739
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2740
		{ 0x16, 0x0f0a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2741
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2742
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2743
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2744
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2745
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2746
	rtl_patchphy(tp, 0x16, 1 << 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2747
	rtl_patchphy(tp, 0x14, 1 << 5);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2748
	rtl_patchphy(tp, 0x0d, 1 << 5);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2749
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2750
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2751
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2752
static void rtl8168c_4_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2753
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2754
	rtl8168c_3_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2755
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2756
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2757
static void rtl8168d_1_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2758
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2759
	static const struct phy_reg phy_reg_init_0[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2760
		/* Channel Estimation */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2761
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2762
		{ 0x06, 0x4064 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2763
		{ 0x07, 0x2863 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2764
		{ 0x08, 0x059c },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2765
		{ 0x09, 0x26b4 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2766
		{ 0x0a, 0x6a19 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2767
		{ 0x0b, 0xdcc8 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2768
		{ 0x10, 0xf06d },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2769
		{ 0x14, 0x7f68 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2770
		{ 0x18, 0x7fd9 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2771
		{ 0x1c, 0xf0ff },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2772
		{ 0x1d, 0x3d9c },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2773
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2774
		{ 0x12, 0xf49f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2775
		{ 0x13, 0x070b },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2776
		{ 0x1a, 0x05ad },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2777
		{ 0x14, 0x94c0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2778
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2779
		/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2780
		 * Tx Error Issue
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2781
		 * Enhance line driver power
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2782
		 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2783
		{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2784
		{ 0x06, 0x5561 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2785
		{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2786
		{ 0x05, 0x8332 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2787
		{ 0x06, 0x5561 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2788
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2789
		/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2790
		 * Can not link to 1Gbps with bad cable
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2791
		 * Decrease SNR threshold form 21.07dB to 19.04dB
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2792
		 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2793
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2794
		{ 0x17, 0x0cc0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2795
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2796
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2797
		{ 0x0d, 0xf880 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2798
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2799
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2800
	rtl_writephy_batch(tp, phy_reg_init_0, ARRAY_SIZE(phy_reg_init_0));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2801
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2802
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2803
	 * Rx Error Issue
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2804
	 * Fine Tune Switching regulator parameter
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2805
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2806
	rtl_writephy(tp, 0x1f, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2807
	rtl_w1w0_phy(tp, 0x0b, 0x0010, 0x00ef);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2808
	rtl_w1w0_phy(tp, 0x0c, 0xa200, 0x5d00);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2809
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2810
	if (rtl8168d_efuse_read(tp, 0x01) == 0xb1) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2811
		static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2812
			{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2813
			{ 0x05, 0x669a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2814
			{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2815
			{ 0x05, 0x8330 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2816
			{ 0x06, 0x669a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2817
			{ 0x1f, 0x0002 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2818
		};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2819
		int val;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2820
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2821
		rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2822
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2823
		val = rtl_readphy(tp, 0x0d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2824
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2825
		if ((val & 0x00ff) != 0x006c) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2826
			static const u32 set[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2827
				0x0065, 0x0066, 0x0067, 0x0068,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2828
				0x0069, 0x006a, 0x006b, 0x006c
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2829
			};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2830
			int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2831
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2832
			rtl_writephy(tp, 0x1f, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2833
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2834
			val &= 0xff00;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2835
			for (i = 0; i < ARRAY_SIZE(set); i++)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2836
				rtl_writephy(tp, 0x0d, val | set[i]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2837
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2838
	} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2839
		static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2840
			{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2841
			{ 0x05, 0x6662 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2842
			{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2843
			{ 0x05, 0x8330 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2844
			{ 0x06, 0x6662 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2845
		};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2846
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2847
		rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2848
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2849
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2850
	/* RSET couple improve */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2851
	rtl_writephy(tp, 0x1f, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2852
	rtl_patchphy(tp, 0x0d, 0x0300);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2853
	rtl_patchphy(tp, 0x0f, 0x0010);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2854
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2855
	/* Fine tune PLL performance */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2856
	rtl_writephy(tp, 0x1f, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2857
	rtl_w1w0_phy(tp, 0x02, 0x0100, 0x0600);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2858
	rtl_w1w0_phy(tp, 0x03, 0x0000, 0xe000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2859
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2860
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2861
	rtl_writephy(tp, 0x05, 0x001b);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2862
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2863
	rtl_apply_firmware_cond(tp, MII_EXPANSION, 0xbf00);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2864
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2865
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2866
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2867
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2868
static void rtl8168d_2_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2869
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2870
	static const struct phy_reg phy_reg_init_0[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2871
		/* Channel Estimation */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2872
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2873
		{ 0x06, 0x4064 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2874
		{ 0x07, 0x2863 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2875
		{ 0x08, 0x059c },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2876
		{ 0x09, 0x26b4 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2877
		{ 0x0a, 0x6a19 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2878
		{ 0x0b, 0xdcc8 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2879
		{ 0x10, 0xf06d },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2880
		{ 0x14, 0x7f68 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2881
		{ 0x18, 0x7fd9 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2882
		{ 0x1c, 0xf0ff },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2883
		{ 0x1d, 0x3d9c },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2884
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2885
		{ 0x12, 0xf49f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2886
		{ 0x13, 0x070b },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2887
		{ 0x1a, 0x05ad },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2888
		{ 0x14, 0x94c0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2889
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2890
		/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2891
		 * Tx Error Issue
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2892
		 * Enhance line driver power
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2893
		 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2894
		{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2895
		{ 0x06, 0x5561 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2896
		{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2897
		{ 0x05, 0x8332 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2898
		{ 0x06, 0x5561 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2899
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2900
		/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2901
		 * Can not link to 1Gbps with bad cable
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2902
		 * Decrease SNR threshold form 21.07dB to 19.04dB
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2903
		 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2904
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2905
		{ 0x17, 0x0cc0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2906
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2907
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2908
		{ 0x0d, 0xf880 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2909
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2910
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2911
	rtl_writephy_batch(tp, phy_reg_init_0, ARRAY_SIZE(phy_reg_init_0));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2912
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2913
	if (rtl8168d_efuse_read(tp, 0x01) == 0xb1) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2914
		static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2915
			{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2916
			{ 0x05, 0x669a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2917
			{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2918
			{ 0x05, 0x8330 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2919
			{ 0x06, 0x669a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2920
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2921
			{ 0x1f, 0x0002 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2922
		};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2923
		int val;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2924
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2925
		rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2926
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2927
		val = rtl_readphy(tp, 0x0d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2928
		if ((val & 0x00ff) != 0x006c) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2929
			static const u32 set[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2930
				0x0065, 0x0066, 0x0067, 0x0068,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2931
				0x0069, 0x006a, 0x006b, 0x006c
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2932
			};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2933
			int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2934
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2935
			rtl_writephy(tp, 0x1f, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2936
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2937
			val &= 0xff00;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2938
			for (i = 0; i < ARRAY_SIZE(set); i++)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2939
				rtl_writephy(tp, 0x0d, val | set[i]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2940
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2941
	} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2942
		static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2943
			{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2944
			{ 0x05, 0x2642 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2945
			{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2946
			{ 0x05, 0x8330 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2947
			{ 0x06, 0x2642 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2948
		};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2949
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2950
		rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2951
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2952
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2953
	/* Fine tune PLL performance */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2954
	rtl_writephy(tp, 0x1f, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2955
	rtl_w1w0_phy(tp, 0x02, 0x0100, 0x0600);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2956
	rtl_w1w0_phy(tp, 0x03, 0x0000, 0xe000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2957
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2958
	/* Switching regulator Slew rate */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2959
	rtl_writephy(tp, 0x1f, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2960
	rtl_patchphy(tp, 0x0f, 0x0017);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2961
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2962
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2963
	rtl_writephy(tp, 0x05, 0x001b);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2964
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2965
	rtl_apply_firmware_cond(tp, MII_EXPANSION, 0xb300);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2966
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2967
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2968
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2969
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2970
static void rtl8168d_3_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2971
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2972
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2973
		{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2974
		{ 0x10, 0x0008 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2975
		{ 0x0d, 0x006c },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2976
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2977
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2978
		{ 0x0d, 0xf880 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2979
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2980
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2981
		{ 0x17, 0x0cc0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2982
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2983
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2984
		{ 0x0b, 0xa4d8 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2985
		{ 0x09, 0x281c },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2986
		{ 0x07, 0x2883 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2987
		{ 0x0a, 0x6b35 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2988
		{ 0x1d, 0x3da4 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2989
		{ 0x1c, 0xeffd },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2990
		{ 0x14, 0x7f52 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2991
		{ 0x18, 0x7fc6 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2992
		{ 0x08, 0x0601 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2993
		{ 0x06, 0x4063 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2994
		{ 0x10, 0xf074 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2995
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2996
		{ 0x13, 0x0789 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2997
		{ 0x12, 0xf4bd },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2998
		{ 0x1a, 0x04fd },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  2999
		{ 0x14, 0x84b0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3000
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3001
		{ 0x00, 0x9200 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3002
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3003
		{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3004
		{ 0x01, 0x0340 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3005
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3006
		{ 0x04, 0x4000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3007
		{ 0x03, 0x1d21 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3008
		{ 0x02, 0x0c32 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3009
		{ 0x01, 0x0200 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3010
		{ 0x00, 0x5554 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3011
		{ 0x04, 0x4800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3012
		{ 0x04, 0x4000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3013
		{ 0x04, 0xf000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3014
		{ 0x03, 0xdf01 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3015
		{ 0x02, 0xdf20 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3016
		{ 0x01, 0x101a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3017
		{ 0x00, 0xa0ff },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3018
		{ 0x04, 0xf800 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3019
		{ 0x04, 0xf000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3020
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3021
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3022
		{ 0x1f, 0x0007 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3023
		{ 0x1e, 0x0023 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3024
		{ 0x16, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3025
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3026
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3027
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3028
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3029
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3030
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3031
static void rtl8168d_4_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3032
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3033
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3034
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3035
		{ 0x17, 0x0cc0 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3036
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3037
		{ 0x1f, 0x0007 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3038
		{ 0x1e, 0x002d },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3039
		{ 0x18, 0x0040 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3040
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3041
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3042
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3043
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3044
	rtl_patchphy(tp, 0x0d, 1 << 5);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3045
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3046
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3047
static void rtl8168e_1_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3048
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3049
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3050
		/* Enable Delay cap */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3051
		{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3052
		{ 0x05, 0x8b80 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3053
		{ 0x06, 0xc896 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3054
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3055
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3056
		/* Channel estimation fine tune */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3057
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3058
		{ 0x0b, 0x6c20 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3059
		{ 0x07, 0x2872 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3060
		{ 0x1c, 0xefff },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3061
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3062
		{ 0x14, 0x6420 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3063
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3064
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3065
		/* Update PFM & 10M TX idle timer */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3066
		{ 0x1f, 0x0007 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3067
		{ 0x1e, 0x002f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3068
		{ 0x15, 0x1919 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3069
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3070
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3071
		{ 0x1f, 0x0007 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3072
		{ 0x1e, 0x00ac },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3073
		{ 0x18, 0x0006 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3074
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3075
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3076
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3077
	rtl_apply_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3078
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3079
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3080
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3081
	/* DCO enable for 10M IDLE Power */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3082
	rtl_writephy(tp, 0x1f, 0x0007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3083
	rtl_writephy(tp, 0x1e, 0x0023);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3084
	rtl_w1w0_phy(tp, 0x17, 0x0006, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3085
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3086
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3087
	/* For impedance matching */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3088
	rtl_writephy(tp, 0x1f, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3089
	rtl_w1w0_phy(tp, 0x08, 0x8000, 0x7f00);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3090
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3091
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3092
	/* PHY auto speed down */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3093
	rtl_writephy(tp, 0x1f, 0x0007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3094
	rtl_writephy(tp, 0x1e, 0x002d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3095
	rtl_w1w0_phy(tp, 0x18, 0x0050, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3096
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3097
	rtl_w1w0_phy(tp, 0x14, 0x8000, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3098
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3099
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3100
	rtl_writephy(tp, 0x05, 0x8b86);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3101
	rtl_w1w0_phy(tp, 0x06, 0x0001, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3102
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3103
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3104
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3105
	rtl_writephy(tp, 0x05, 0x8b85);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3106
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x2000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3107
	rtl_writephy(tp, 0x1f, 0x0007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3108
	rtl_writephy(tp, 0x1e, 0x0020);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3109
	rtl_w1w0_phy(tp, 0x15, 0x0000, 0x1100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3110
	rtl_writephy(tp, 0x1f, 0x0006);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3111
	rtl_writephy(tp, 0x00, 0x5a00);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3112
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3113
	rtl_writephy(tp, 0x0d, 0x0007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3114
	rtl_writephy(tp, 0x0e, 0x003c);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3115
	rtl_writephy(tp, 0x0d, 0x4007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3116
	rtl_writephy(tp, 0x0e, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3117
	rtl_writephy(tp, 0x0d, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3118
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3119
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3120
static void rtl8168e_2_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3121
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3122
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3123
		/* Enable Delay cap */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3124
		{ 0x1f, 0x0004 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3125
		{ 0x1f, 0x0007 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3126
		{ 0x1e, 0x00ac },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3127
		{ 0x18, 0x0006 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3128
		{ 0x1f, 0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3129
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3130
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3131
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3132
		/* Channel estimation fine tune */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3133
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3134
		{ 0x09, 0xa20f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3135
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3136
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3137
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3138
		/* Green Setting */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3139
		{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3140
		{ 0x05, 0x8b5b },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3141
		{ 0x06, 0x9222 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3142
		{ 0x05, 0x8b6d },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3143
		{ 0x06, 0x8000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3144
		{ 0x05, 0x8b76 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3145
		{ 0x06, 0x8000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3146
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3147
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3148
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3149
	rtl_apply_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3150
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3151
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3152
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3153
	/* For 4-corner performance improve */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3154
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3155
	rtl_writephy(tp, 0x05, 0x8b80);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3156
	rtl_w1w0_phy(tp, 0x17, 0x0006, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3157
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3158
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3159
	/* PHY auto speed down */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3160
	rtl_writephy(tp, 0x1f, 0x0004);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3161
	rtl_writephy(tp, 0x1f, 0x0007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3162
	rtl_writephy(tp, 0x1e, 0x002d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3163
	rtl_w1w0_phy(tp, 0x18, 0x0010, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3164
	rtl_writephy(tp, 0x1f, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3165
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3166
	rtl_w1w0_phy(tp, 0x14, 0x8000, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3167
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3168
	/* improve 10M EEE waveform */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3169
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3170
	rtl_writephy(tp, 0x05, 0x8b86);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3171
	rtl_w1w0_phy(tp, 0x06, 0x0001, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3172
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3173
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3174
	/* Improve 2-pair detection performance */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3175
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3176
	rtl_writephy(tp, 0x05, 0x8b85);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3177
	rtl_w1w0_phy(tp, 0x06, 0x4000, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3178
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3179
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3180
	/* EEE setting */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3181
	rtl_w1w0_eri(tp, 0x1b0, ERIAR_MASK_1111, 0x0000, 0x0003, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3182
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3183
	rtl_writephy(tp, 0x05, 0x8b85);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3184
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x2000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3185
	rtl_writephy(tp, 0x1f, 0x0004);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3186
	rtl_writephy(tp, 0x1f, 0x0007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3187
	rtl_writephy(tp, 0x1e, 0x0020);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3188
	rtl_w1w0_phy(tp, 0x15, 0x0000, 0x0100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3189
	rtl_writephy(tp, 0x1f, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3190
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3191
	rtl_writephy(tp, 0x0d, 0x0007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3192
	rtl_writephy(tp, 0x0e, 0x003c);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3193
	rtl_writephy(tp, 0x0d, 0x4007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3194
	rtl_writephy(tp, 0x0e, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3195
	rtl_writephy(tp, 0x0d, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3196
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3197
	/* Green feature */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3198
	rtl_writephy(tp, 0x1f, 0x0003);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3199
	rtl_w1w0_phy(tp, 0x19, 0x0000, 0x0001);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3200
	rtl_w1w0_phy(tp, 0x10, 0x0000, 0x0400);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3201
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3202
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3203
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3204
static void rtl8168f_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3205
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3206
	/* For 4-corner performance improve */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3207
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3208
	rtl_writephy(tp, 0x05, 0x8b80);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3209
	rtl_w1w0_phy(tp, 0x06, 0x0006, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3210
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3211
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3212
	/* PHY auto speed down */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3213
	rtl_writephy(tp, 0x1f, 0x0007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3214
	rtl_writephy(tp, 0x1e, 0x002d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3215
	rtl_w1w0_phy(tp, 0x18, 0x0010, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3216
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3217
	rtl_w1w0_phy(tp, 0x14, 0x8000, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3218
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3219
	/* Improve 10M EEE waveform */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3220
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3221
	rtl_writephy(tp, 0x05, 0x8b86);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3222
	rtl_w1w0_phy(tp, 0x06, 0x0001, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3223
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3224
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3225
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3226
static void rtl8168f_1_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3227
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3228
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3229
		/* Channel estimation fine tune */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3230
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3231
		{ 0x09, 0xa20f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3232
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3233
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3234
		/* Modify green table for giga & fnet */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3235
		{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3236
		{ 0x05, 0x8b55 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3237
		{ 0x06, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3238
		{ 0x05, 0x8b5e },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3239
		{ 0x06, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3240
		{ 0x05, 0x8b67 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3241
		{ 0x06, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3242
		{ 0x05, 0x8b70 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3243
		{ 0x06, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3244
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3245
		{ 0x1f, 0x0007 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3246
		{ 0x1e, 0x0078 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3247
		{ 0x17, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3248
		{ 0x19, 0x00fb },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3249
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3250
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3251
		/* Modify green table for 10M */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3252
		{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3253
		{ 0x05, 0x8b79 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3254
		{ 0x06, 0xaa00 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3255
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3256
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3257
		/* Disable hiimpedance detection (RTCT) */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3258
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3259
		{ 0x01, 0x328a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3260
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3261
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3262
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3263
	rtl_apply_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3264
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3265
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3266
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3267
	rtl8168f_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3268
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3269
	/* Improve 2-pair detection performance */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3270
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3271
	rtl_writephy(tp, 0x05, 0x8b85);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3272
	rtl_w1w0_phy(tp, 0x06, 0x4000, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3273
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3274
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3275
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3276
static void rtl8168f_2_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3277
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3278
	rtl_apply_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3279
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3280
	rtl8168f_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3281
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3282
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3283
static void rtl8411_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3284
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3285
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3286
		/* Channel estimation fine tune */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3287
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3288
		{ 0x09, 0xa20f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3289
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3290
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3291
		/* Modify green table for giga & fnet */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3292
		{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3293
		{ 0x05, 0x8b55 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3294
		{ 0x06, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3295
		{ 0x05, 0x8b5e },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3296
		{ 0x06, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3297
		{ 0x05, 0x8b67 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3298
		{ 0x06, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3299
		{ 0x05, 0x8b70 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3300
		{ 0x06, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3301
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3302
		{ 0x1f, 0x0007 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3303
		{ 0x1e, 0x0078 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3304
		{ 0x17, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3305
		{ 0x19, 0x00aa },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3306
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3307
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3308
		/* Modify green table for 10M */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3309
		{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3310
		{ 0x05, 0x8b79 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3311
		{ 0x06, 0xaa00 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3312
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3313
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3314
		/* Disable hiimpedance detection (RTCT) */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3315
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3316
		{ 0x01, 0x328a },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3317
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3318
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3319
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3320
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3321
	rtl_apply_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3322
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3323
	rtl8168f_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3324
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3325
	/* Improve 2-pair detection performance */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3326
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3327
	rtl_writephy(tp, 0x05, 0x8b85);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3328
	rtl_w1w0_phy(tp, 0x06, 0x4000, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3329
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3330
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3331
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3332
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3333
	/* Modify green table for giga */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3334
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3335
	rtl_writephy(tp, 0x05, 0x8b54);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3336
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x0800);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3337
	rtl_writephy(tp, 0x05, 0x8b5d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3338
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x0800);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3339
	rtl_writephy(tp, 0x05, 0x8a7c);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3340
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x0100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3341
	rtl_writephy(tp, 0x05, 0x8a7f);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3342
	rtl_w1w0_phy(tp, 0x06, 0x0100, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3343
	rtl_writephy(tp, 0x05, 0x8a82);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3344
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x0100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3345
	rtl_writephy(tp, 0x05, 0x8a85);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3346
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x0100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3347
	rtl_writephy(tp, 0x05, 0x8a88);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3348
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x0100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3349
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3350
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3351
	/* uc same-seed solution */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3352
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3353
	rtl_writephy(tp, 0x05, 0x8b85);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3354
	rtl_w1w0_phy(tp, 0x06, 0x8000, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3355
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3356
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3357
	/* eee setting */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3358
	rtl_w1w0_eri(tp, 0x1b0, ERIAR_MASK_0001, 0x00, 0x03, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3359
	rtl_writephy(tp, 0x1f, 0x0005);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3360
	rtl_writephy(tp, 0x05, 0x8b85);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3361
	rtl_w1w0_phy(tp, 0x06, 0x0000, 0x2000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3362
	rtl_writephy(tp, 0x1f, 0x0004);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3363
	rtl_writephy(tp, 0x1f, 0x0007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3364
	rtl_writephy(tp, 0x1e, 0x0020);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3365
	rtl_w1w0_phy(tp, 0x15, 0x0000, 0x0100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3366
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3367
	rtl_writephy(tp, 0x0d, 0x0007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3368
	rtl_writephy(tp, 0x0e, 0x003c);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3369
	rtl_writephy(tp, 0x0d, 0x4007);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3370
	rtl_writephy(tp, 0x0e, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3371
	rtl_writephy(tp, 0x0d, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3372
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3373
	/* Green feature */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3374
	rtl_writephy(tp, 0x1f, 0x0003);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3375
	rtl_w1w0_phy(tp, 0x19, 0x0000, 0x0001);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3376
	rtl_w1w0_phy(tp, 0x10, 0x0000, 0x0400);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3377
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3378
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3379
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3380
static void rtl8168g_1_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3381
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3382
	static const u16 mac_ocp_patch[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3383
		0xe008, 0xe01b, 0xe01d, 0xe01f,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3384
		0xe021, 0xe023, 0xe025, 0xe027,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3385
		0x49d2, 0xf10d, 0x766c, 0x49e2,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3386
		0xf00a, 0x1ec0, 0x8ee1, 0xc60a,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3387
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3388
		0x77c0, 0x4870, 0x9fc0, 0x1ea0,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3389
		0xc707, 0x8ee1, 0x9d6c, 0xc603,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3390
		0xbe00, 0xb416, 0x0076, 0xe86c,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3391
		0xc602, 0xbe00, 0x0000, 0xc602,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3392
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3393
		0xbe00, 0x0000, 0xc602, 0xbe00,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3394
		0x0000, 0xc602, 0xbe00, 0x0000,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3395
		0xc602, 0xbe00, 0x0000, 0xc602,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3396
		0xbe00, 0x0000, 0xc602, 0xbe00,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3397
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3398
		0x0000, 0x0000, 0x0000, 0x0000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3399
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3400
	u32 i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3401
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3402
	/* Patch code for GPHY reset */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3403
	for (i = 0; i < ARRAY_SIZE(mac_ocp_patch); i++)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3404
		r8168_mac_ocp_write(tp, 0xf800 + 2*i, mac_ocp_patch[i]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3405
	r8168_mac_ocp_write(tp, 0xfc26, 0x8000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3406
	r8168_mac_ocp_write(tp, 0xfc28, 0x0075);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3407
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3408
	rtl_apply_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3409
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3410
	if (r8168_phy_ocp_read(tp, 0xa460) & 0x0100)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3411
		rtl_w1w0_phy_ocp(tp, 0xbcc4, 0x0000, 0x8000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3412
	else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3413
		rtl_w1w0_phy_ocp(tp, 0xbcc4, 0x8000, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3414
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3415
	if (r8168_phy_ocp_read(tp, 0xa466) & 0x0100)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3416
		rtl_w1w0_phy_ocp(tp, 0xc41a, 0x0002, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3417
	else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3418
		rtl_w1w0_phy_ocp(tp, 0xbcc4, 0x0000, 0x0002);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3419
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3420
	rtl_w1w0_phy_ocp(tp, 0xa442, 0x000c, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3421
	rtl_w1w0_phy_ocp(tp, 0xa4b2, 0x0004, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3422
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3423
	r8168_phy_ocp_write(tp, 0xa436, 0x8012);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3424
	rtl_w1w0_phy_ocp(tp, 0xa438, 0x8000, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3425
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3426
	rtl_w1w0_phy_ocp(tp, 0xc422, 0x4000, 0x2000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3427
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3428
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3429
static void rtl8102e_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3430
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3431
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3432
		{ 0x1f, 0x0003 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3433
		{ 0x08, 0x441d },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3434
		{ 0x01, 0x9100 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3435
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3436
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3437
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3438
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3439
	rtl_patchphy(tp, 0x11, 1 << 12);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3440
	rtl_patchphy(tp, 0x19, 1 << 13);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3441
	rtl_patchphy(tp, 0x10, 1 << 15);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3442
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3443
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3444
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3445
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3446
static void rtl8105e_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3447
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3448
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3449
		{ 0x1f, 0x0005 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3450
		{ 0x1a, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3451
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3452
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3453
		{ 0x1f, 0x0004 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3454
		{ 0x1c, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3455
		{ 0x1f, 0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3456
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3457
		{ 0x1f, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3458
		{ 0x15, 0x7701 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3459
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3460
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3461
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3462
	/* Disable ALDPS before ram code */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3463
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3464
	rtl_writephy(tp, 0x18, 0x0310);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3465
	msleep(100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3466
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3467
	rtl_apply_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3468
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3469
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3470
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3471
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3472
static void rtl8402_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3473
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3474
	/* Disable ALDPS before setting firmware */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3475
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3476
	rtl_writephy(tp, 0x18, 0x0310);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3477
	msleep(20);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3478
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3479
	rtl_apply_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3480
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3481
	/* EEE setting */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3482
	rtl_eri_write(tp, 0x1b0, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3483
	rtl_writephy(tp, 0x1f, 0x0004);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3484
	rtl_writephy(tp, 0x10, 0x401f);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3485
	rtl_writephy(tp, 0x19, 0x7030);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3486
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3487
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3488
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3489
static void rtl8106e_hw_phy_config(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3490
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3491
	static const struct phy_reg phy_reg_init[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3492
		{ 0x1f, 0x0004 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3493
		{ 0x10, 0xc07f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3494
		{ 0x19, 0x7030 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3495
		{ 0x1f, 0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3496
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3497
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3498
	/* Disable ALDPS before ram code */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3499
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3500
	rtl_writephy(tp, 0x18, 0x0310);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3501
	msleep(100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3502
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3503
	rtl_apply_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3504
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3505
	rtl_eri_write(tp, 0x1b0, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3506
	rtl_writephy_batch(tp, phy_reg_init, ARRAY_SIZE(phy_reg_init));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3507
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3508
	rtl_eri_write(tp, 0x1d0, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3509
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3510
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3511
static void rtl_hw_phy_config(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3512
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3513
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3514
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3515
	rtl8169_print_mac_version(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3516
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3517
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3518
	case RTL_GIGA_MAC_VER_01:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3519
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3520
	case RTL_GIGA_MAC_VER_02:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3521
	case RTL_GIGA_MAC_VER_03:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3522
		rtl8169s_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3523
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3524
	case RTL_GIGA_MAC_VER_04:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3525
		rtl8169sb_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3526
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3527
	case RTL_GIGA_MAC_VER_05:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3528
		rtl8169scd_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3529
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3530
	case RTL_GIGA_MAC_VER_06:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3531
		rtl8169sce_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3532
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3533
	case RTL_GIGA_MAC_VER_07:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3534
	case RTL_GIGA_MAC_VER_08:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3535
	case RTL_GIGA_MAC_VER_09:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3536
		rtl8102e_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3537
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3538
	case RTL_GIGA_MAC_VER_11:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3539
		rtl8168bb_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3540
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3541
	case RTL_GIGA_MAC_VER_12:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3542
		rtl8168bef_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3543
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3544
	case RTL_GIGA_MAC_VER_17:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3545
		rtl8168bef_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3546
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3547
	case RTL_GIGA_MAC_VER_18:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3548
		rtl8168cp_1_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3549
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3550
	case RTL_GIGA_MAC_VER_19:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3551
		rtl8168c_1_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3552
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3553
	case RTL_GIGA_MAC_VER_20:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3554
		rtl8168c_2_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3555
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3556
	case RTL_GIGA_MAC_VER_21:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3557
		rtl8168c_3_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3558
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3559
	case RTL_GIGA_MAC_VER_22:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3560
		rtl8168c_4_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3561
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3562
	case RTL_GIGA_MAC_VER_23:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3563
	case RTL_GIGA_MAC_VER_24:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3564
		rtl8168cp_2_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3565
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3566
	case RTL_GIGA_MAC_VER_25:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3567
		rtl8168d_1_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3568
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3569
	case RTL_GIGA_MAC_VER_26:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3570
		rtl8168d_2_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3571
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3572
	case RTL_GIGA_MAC_VER_27:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3573
		rtl8168d_3_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3574
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3575
	case RTL_GIGA_MAC_VER_28:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3576
		rtl8168d_4_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3577
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3578
	case RTL_GIGA_MAC_VER_29:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3579
	case RTL_GIGA_MAC_VER_30:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3580
		rtl8105e_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3581
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3582
	case RTL_GIGA_MAC_VER_31:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3583
		/* None. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3584
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3585
	case RTL_GIGA_MAC_VER_32:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3586
	case RTL_GIGA_MAC_VER_33:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3587
		rtl8168e_1_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3588
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3589
	case RTL_GIGA_MAC_VER_34:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3590
		rtl8168e_2_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3591
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3592
	case RTL_GIGA_MAC_VER_35:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3593
		rtl8168f_1_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3594
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3595
	case RTL_GIGA_MAC_VER_36:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3596
		rtl8168f_2_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3597
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3598
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3599
	case RTL_GIGA_MAC_VER_37:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3600
		rtl8402_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3601
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3602
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3603
	case RTL_GIGA_MAC_VER_38:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3604
		rtl8411_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3605
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3606
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3607
	case RTL_GIGA_MAC_VER_39:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3608
		rtl8106e_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3609
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3610
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3611
	case RTL_GIGA_MAC_VER_40:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3612
		rtl8168g_1_hw_phy_config(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3613
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3614
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3615
	case RTL_GIGA_MAC_VER_41:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3616
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3617
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3618
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3619
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3620
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3621
static void rtl_phy_work(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3622
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3623
	struct timer_list *timer = &tp->timer;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3624
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3625
	unsigned long timeout = RTL8169_PHY_TIMEOUT;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3626
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3627
	assert(tp->mac_version > RTL_GIGA_MAC_VER_01);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3628
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3629
	if (tp->phy_reset_pending(tp)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3630
		/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3631
		 * A busy loop could burn quite a few cycles on nowadays CPU.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3632
		 * Let's delay the execution of the timer for a few ticks.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3633
		 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3634
		timeout = HZ/10;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3635
		goto out_mod_timer;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3636
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3637
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3638
	if (tp->link_ok(ioaddr))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3639
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3640
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3641
	netif_warn(tp, link, tp->dev, "PHY reset until link up\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3642
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3643
	tp->phy_reset_enable(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3644
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3645
out_mod_timer:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3646
	mod_timer(timer, jiffies + timeout);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3647
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3648
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3649
static void rtl_schedule_task(struct rtl8169_private *tp, enum rtl_flag flag)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3650
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3651
	if (!test_and_set_bit(flag, tp->wk.flags))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3652
		schedule_work(&tp->wk.work);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3653
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3654
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3655
static void rtl8169_phy_timer(unsigned long __opaque)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3656
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3657
	struct net_device *dev = (struct net_device *)__opaque;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3658
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3659
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3660
	rtl_schedule_task(tp, RTL_FLAG_TASK_PHY_PENDING);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3661
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3662
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3663
static void rtl8169_release_board(struct pci_dev *pdev, struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3664
				  void __iomem *ioaddr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3665
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3666
	iounmap(ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3667
	pci_release_regions(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3668
	pci_clear_mwi(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3669
	pci_disable_device(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3670
	free_netdev(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3671
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3672
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3673
DECLARE_RTL_COND(rtl_phy_reset_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3674
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3675
	return tp->phy_reset_pending(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3676
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3677
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3678
static void rtl8169_phy_reset(struct net_device *dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3679
			      struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3680
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3681
	tp->phy_reset_enable(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3682
	rtl_msleep_loop_wait_low(tp, &rtl_phy_reset_cond, 1, 100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3683
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3684
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3685
static bool rtl_tbi_enabled(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3686
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3687
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3688
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3689
	return (tp->mac_version == RTL_GIGA_MAC_VER_01) &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3690
	    (RTL_R8(PHYstatus) & TBI_Enable);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3691
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3692
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3693
static void rtl8169_init_phy(struct net_device *dev, struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3694
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3695
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3696
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3697
	rtl_hw_phy_config(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3698
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3699
	if (tp->mac_version <= RTL_GIGA_MAC_VER_06) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3700
		dprintk("Set MAC Reg C+CR Offset 0x82h = 0x01h\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3701
		RTL_W8(0x82, 0x01);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3702
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3703
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3704
	pci_write_config_byte(tp->pci_dev, PCI_LATENCY_TIMER, 0x40);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3705
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3706
	if (tp->mac_version <= RTL_GIGA_MAC_VER_06)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3707
		pci_write_config_byte(tp->pci_dev, PCI_CACHE_LINE_SIZE, 0x08);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3708
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3709
	if (tp->mac_version == RTL_GIGA_MAC_VER_02) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3710
		dprintk("Set MAC Reg C+CR Offset 0x82h = 0x01h\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3711
		RTL_W8(0x82, 0x01);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3712
		dprintk("Set PHY Reg 0x0bh = 0x00h\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3713
		rtl_writephy(tp, 0x0b, 0x0000); //w 0x0b 15 0 0
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3714
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3715
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3716
	rtl8169_phy_reset(dev, tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3717
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3718
	rtl8169_set_speed(dev, AUTONEG_ENABLE, SPEED_1000, DUPLEX_FULL,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3719
			  ADVERTISED_10baseT_Half | ADVERTISED_10baseT_Full |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3720
			  ADVERTISED_100baseT_Half | ADVERTISED_100baseT_Full |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3721
			  (tp->mii.supports_gmii ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3722
			   ADVERTISED_1000baseT_Half |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3723
			   ADVERTISED_1000baseT_Full : 0));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3724
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3725
	if (rtl_tbi_enabled(tp))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3726
		netif_info(tp, link, dev, "TBI auto-negotiating\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3727
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3728
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3729
static void rtl_rar_set(struct rtl8169_private *tp, u8 *addr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3730
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3731
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3732
	u32 high;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3733
	u32 low;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3734
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3735
	low  = addr[0] | (addr[1] << 8) | (addr[2] << 16) | (addr[3] << 24);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3736
	high = addr[4] | (addr[5] << 8);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3737
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3738
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3739
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3740
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3741
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3742
	RTL_W32(MAC4, high);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3743
	RTL_R32(MAC4);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3744
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3745
	RTL_W32(MAC0, low);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3746
	RTL_R32(MAC0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3747
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3748
	if (tp->mac_version == RTL_GIGA_MAC_VER_34) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3749
		const struct exgmac_reg e[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3750
			{ .addr = 0xe0, ERIAR_MASK_1111, .val = low },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3751
			{ .addr = 0xe4, ERIAR_MASK_1111, .val = high },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3752
			{ .addr = 0xf0, ERIAR_MASK_1111, .val = low << 16 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3753
			{ .addr = 0xf4, ERIAR_MASK_1111, .val = high << 16 |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3754
								low  >> 16 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3755
		};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3756
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3757
		rtl_write_exgmac_batch(tp, e, ARRAY_SIZE(e));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3758
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3759
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3760
	RTL_W8(Cfg9346, Cfg9346_Lock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3761
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3762
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3763
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3764
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3765
static int rtl_set_mac_address(struct net_device *dev, void *p)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3766
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3767
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3768
	struct sockaddr *addr = p;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3769
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3770
	if (!is_valid_ether_addr(addr->sa_data))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3771
		return -EADDRNOTAVAIL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3772
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3773
	memcpy(dev->dev_addr, addr->sa_data, dev->addr_len);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3774
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3775
	rtl_rar_set(tp, dev->dev_addr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3776
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3777
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3778
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3779
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3780
static int rtl8169_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3781
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3782
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3783
	struct mii_ioctl_data *data = if_mii(ifr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3784
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3785
	return netif_running(dev) ? tp->do_ioctl(tp, data, cmd) : -ENODEV;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3786
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3787
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3788
static int rtl_xmii_ioctl(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3789
			  struct mii_ioctl_data *data, int cmd)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3790
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3791
	switch (cmd) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3792
	case SIOCGMIIPHY:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3793
		data->phy_id = 32; /* Internal PHY */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3794
		return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3795
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3796
	case SIOCGMIIREG:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3797
		data->val_out = rtl_readphy(tp, data->reg_num & 0x1f);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3798
		return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3799
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3800
	case SIOCSMIIREG:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3801
		rtl_writephy(tp, data->reg_num & 0x1f, data->val_in);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3802
		return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3803
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3804
	return -EOPNOTSUPP;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3805
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3806
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3807
static int rtl_tbi_ioctl(struct rtl8169_private *tp, struct mii_ioctl_data *data, int cmd)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3808
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3809
	return -EOPNOTSUPP;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3810
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3811
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3812
static void rtl_disable_msi(struct pci_dev *pdev, struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3813
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3814
	if (tp->features & RTL_FEATURE_MSI) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3815
		pci_disable_msi(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3816
		tp->features &= ~RTL_FEATURE_MSI;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3817
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3818
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3819
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3820
static void __devinit rtl_init_mdio_ops(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3821
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3822
	struct mdio_ops *ops = &tp->mdio_ops;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3823
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3824
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3825
	case RTL_GIGA_MAC_VER_27:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3826
		ops->write	= r8168dp_1_mdio_write;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3827
		ops->read	= r8168dp_1_mdio_read;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3828
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3829
	case RTL_GIGA_MAC_VER_28:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3830
	case RTL_GIGA_MAC_VER_31:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3831
		ops->write	= r8168dp_2_mdio_write;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3832
		ops->read	= r8168dp_2_mdio_read;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3833
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3834
	case RTL_GIGA_MAC_VER_40:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3835
	case RTL_GIGA_MAC_VER_41:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3836
		ops->write	= r8168g_mdio_write;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3837
		ops->read	= r8168g_mdio_read;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3838
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3839
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3840
		ops->write	= r8169_mdio_write;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3841
		ops->read	= r8169_mdio_read;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3842
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3843
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3844
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3845
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3846
static void rtl_wol_suspend_quirk(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3847
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3848
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3849
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3850
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3851
	case RTL_GIGA_MAC_VER_25:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3852
	case RTL_GIGA_MAC_VER_26:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3853
	case RTL_GIGA_MAC_VER_29:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3854
	case RTL_GIGA_MAC_VER_30:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3855
	case RTL_GIGA_MAC_VER_32:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3856
	case RTL_GIGA_MAC_VER_33:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3857
	case RTL_GIGA_MAC_VER_34:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3858
	case RTL_GIGA_MAC_VER_37:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3859
	case RTL_GIGA_MAC_VER_38:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3860
	case RTL_GIGA_MAC_VER_39:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3861
	case RTL_GIGA_MAC_VER_40:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3862
	case RTL_GIGA_MAC_VER_41:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3863
		RTL_W32(RxConfig, RTL_R32(RxConfig) |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3864
			AcceptBroadcast | AcceptMulticast | AcceptMyPhys);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3865
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3866
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3867
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3868
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3869
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3870
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3871
static bool rtl_wol_pll_power_down(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3872
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3873
	if (!(__rtl8169_get_wol(tp) & WAKE_ANY))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3874
		return false;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3875
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3876
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3877
	rtl_writephy(tp, MII_BMCR, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3878
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3879
	rtl_wol_suspend_quirk(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3880
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3881
	return true;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3882
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3883
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3884
static void r810x_phy_power_down(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3885
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3886
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3887
	rtl_writephy(tp, MII_BMCR, BMCR_PDOWN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3888
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3889
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3890
static void r810x_phy_power_up(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3891
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3892
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3893
	rtl_writephy(tp, MII_BMCR, BMCR_ANENABLE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3894
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3895
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3896
static void r810x_pll_power_down(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3897
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3898
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3899
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3900
	if (rtl_wol_pll_power_down(tp))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3901
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3902
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3903
	r810x_phy_power_down(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3904
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3905
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3906
	case RTL_GIGA_MAC_VER_07:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3907
	case RTL_GIGA_MAC_VER_08:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3908
	case RTL_GIGA_MAC_VER_09:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3909
	case RTL_GIGA_MAC_VER_10:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3910
	case RTL_GIGA_MAC_VER_13:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3911
	case RTL_GIGA_MAC_VER_16:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3912
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3913
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3914
		RTL_W8(PMCH, RTL_R8(PMCH) & ~0x80);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3915
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3916
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3917
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3918
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3919
static void r810x_pll_power_up(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3920
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3921
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3922
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3923
	r810x_phy_power_up(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3924
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3925
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3926
	case RTL_GIGA_MAC_VER_07:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3927
	case RTL_GIGA_MAC_VER_08:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3928
	case RTL_GIGA_MAC_VER_09:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3929
	case RTL_GIGA_MAC_VER_10:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3930
	case RTL_GIGA_MAC_VER_13:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3931
	case RTL_GIGA_MAC_VER_16:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3932
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3933
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3934
		RTL_W8(PMCH, RTL_R8(PMCH) | 0x80);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3935
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3936
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3937
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3938
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3939
static void r8168_phy_power_up(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3940
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3941
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3942
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3943
	case RTL_GIGA_MAC_VER_11:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3944
	case RTL_GIGA_MAC_VER_12:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3945
	case RTL_GIGA_MAC_VER_17:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3946
	case RTL_GIGA_MAC_VER_18:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3947
	case RTL_GIGA_MAC_VER_19:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3948
	case RTL_GIGA_MAC_VER_20:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3949
	case RTL_GIGA_MAC_VER_21:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3950
	case RTL_GIGA_MAC_VER_22:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3951
	case RTL_GIGA_MAC_VER_23:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3952
	case RTL_GIGA_MAC_VER_24:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3953
	case RTL_GIGA_MAC_VER_25:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3954
	case RTL_GIGA_MAC_VER_26:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3955
	case RTL_GIGA_MAC_VER_27:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3956
	case RTL_GIGA_MAC_VER_28:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3957
	case RTL_GIGA_MAC_VER_31:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3958
		rtl_writephy(tp, 0x0e, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3959
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3960
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3961
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3962
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3963
	rtl_writephy(tp, MII_BMCR, BMCR_ANENABLE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3964
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3965
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3966
static void r8168_phy_power_down(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3967
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3968
	rtl_writephy(tp, 0x1f, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3969
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3970
	case RTL_GIGA_MAC_VER_32:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3971
	case RTL_GIGA_MAC_VER_33:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3972
		rtl_writephy(tp, MII_BMCR, BMCR_ANENABLE | BMCR_PDOWN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3973
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3974
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3975
	case RTL_GIGA_MAC_VER_11:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3976
	case RTL_GIGA_MAC_VER_12:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3977
	case RTL_GIGA_MAC_VER_17:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3978
	case RTL_GIGA_MAC_VER_18:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3979
	case RTL_GIGA_MAC_VER_19:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3980
	case RTL_GIGA_MAC_VER_20:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3981
	case RTL_GIGA_MAC_VER_21:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3982
	case RTL_GIGA_MAC_VER_22:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3983
	case RTL_GIGA_MAC_VER_23:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3984
	case RTL_GIGA_MAC_VER_24:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3985
	case RTL_GIGA_MAC_VER_25:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3986
	case RTL_GIGA_MAC_VER_26:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3987
	case RTL_GIGA_MAC_VER_27:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3988
	case RTL_GIGA_MAC_VER_28:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3989
	case RTL_GIGA_MAC_VER_31:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3990
		rtl_writephy(tp, 0x0e, 0x0200);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3991
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3992
		rtl_writephy(tp, MII_BMCR, BMCR_PDOWN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3993
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3994
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3995
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3996
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3997
static void r8168_pll_power_down(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3998
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  3999
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4000
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4001
	if ((tp->mac_version == RTL_GIGA_MAC_VER_27 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4002
	     tp->mac_version == RTL_GIGA_MAC_VER_28 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4003
	     tp->mac_version == RTL_GIGA_MAC_VER_31) &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4004
	    r8168dp_check_dash(tp)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4005
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4006
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4007
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4008
	if ((tp->mac_version == RTL_GIGA_MAC_VER_23 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4009
	     tp->mac_version == RTL_GIGA_MAC_VER_24) &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4010
	    (RTL_R16(CPlusCmd) & ASF)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4011
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4012
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4013
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4014
	if (tp->mac_version == RTL_GIGA_MAC_VER_32 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4015
	    tp->mac_version == RTL_GIGA_MAC_VER_33)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4016
		rtl_ephy_write(tp, 0x19, 0xff64);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4017
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4018
	if (rtl_wol_pll_power_down(tp))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4019
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4020
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4021
	r8168_phy_power_down(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4022
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4023
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4024
	case RTL_GIGA_MAC_VER_25:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4025
	case RTL_GIGA_MAC_VER_26:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4026
	case RTL_GIGA_MAC_VER_27:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4027
	case RTL_GIGA_MAC_VER_28:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4028
	case RTL_GIGA_MAC_VER_31:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4029
	case RTL_GIGA_MAC_VER_32:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4030
	case RTL_GIGA_MAC_VER_33:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4031
		RTL_W8(PMCH, RTL_R8(PMCH) & ~0x80);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4032
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4033
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4034
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4035
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4036
static void r8168_pll_power_up(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4037
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4038
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4039
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4040
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4041
	case RTL_GIGA_MAC_VER_25:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4042
	case RTL_GIGA_MAC_VER_26:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4043
	case RTL_GIGA_MAC_VER_27:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4044
	case RTL_GIGA_MAC_VER_28:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4045
	case RTL_GIGA_MAC_VER_31:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4046
	case RTL_GIGA_MAC_VER_32:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4047
	case RTL_GIGA_MAC_VER_33:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4048
		RTL_W8(PMCH, RTL_R8(PMCH) | 0x80);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4049
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4050
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4051
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4052
	r8168_phy_power_up(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4053
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4054
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4055
static void rtl_generic_op(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4056
			   void (*op)(struct rtl8169_private *))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4057
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4058
	if (op)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4059
		op(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4060
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4061
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4062
static void rtl_pll_power_down(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4063
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4064
	rtl_generic_op(tp, tp->pll_power_ops.down);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4065
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4066
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4067
static void rtl_pll_power_up(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4068
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4069
	rtl_generic_op(tp, tp->pll_power_ops.up);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4070
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4071
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4072
static void __devinit rtl_init_pll_power_ops(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4073
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4074
	struct pll_power_ops *ops = &tp->pll_power_ops;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4075
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4076
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4077
	case RTL_GIGA_MAC_VER_07:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4078
	case RTL_GIGA_MAC_VER_08:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4079
	case RTL_GIGA_MAC_VER_09:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4080
	case RTL_GIGA_MAC_VER_10:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4081
	case RTL_GIGA_MAC_VER_16:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4082
	case RTL_GIGA_MAC_VER_29:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4083
	case RTL_GIGA_MAC_VER_30:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4084
	case RTL_GIGA_MAC_VER_37:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4085
	case RTL_GIGA_MAC_VER_39:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4086
		ops->down	= r810x_pll_power_down;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4087
		ops->up		= r810x_pll_power_up;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4088
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4089
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4090
	case RTL_GIGA_MAC_VER_11:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4091
	case RTL_GIGA_MAC_VER_12:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4092
	case RTL_GIGA_MAC_VER_17:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4093
	case RTL_GIGA_MAC_VER_18:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4094
	case RTL_GIGA_MAC_VER_19:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4095
	case RTL_GIGA_MAC_VER_20:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4096
	case RTL_GIGA_MAC_VER_21:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4097
	case RTL_GIGA_MAC_VER_22:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4098
	case RTL_GIGA_MAC_VER_23:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4099
	case RTL_GIGA_MAC_VER_24:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4100
	case RTL_GIGA_MAC_VER_25:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4101
	case RTL_GIGA_MAC_VER_26:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4102
	case RTL_GIGA_MAC_VER_27:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4103
	case RTL_GIGA_MAC_VER_28:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4104
	case RTL_GIGA_MAC_VER_31:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4105
	case RTL_GIGA_MAC_VER_32:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4106
	case RTL_GIGA_MAC_VER_33:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4107
	case RTL_GIGA_MAC_VER_34:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4108
	case RTL_GIGA_MAC_VER_35:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4109
	case RTL_GIGA_MAC_VER_36:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4110
	case RTL_GIGA_MAC_VER_38:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4111
	case RTL_GIGA_MAC_VER_40:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4112
	case RTL_GIGA_MAC_VER_41:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4113
		ops->down	= r8168_pll_power_down;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4114
		ops->up		= r8168_pll_power_up;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4115
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4116
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4117
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4118
		ops->down	= NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4119
		ops->up		= NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4120
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4121
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4122
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4123
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4124
static void rtl_init_rxcfg(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4125
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4126
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4127
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4128
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4129
	case RTL_GIGA_MAC_VER_01:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4130
	case RTL_GIGA_MAC_VER_02:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4131
	case RTL_GIGA_MAC_VER_03:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4132
	case RTL_GIGA_MAC_VER_04:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4133
	case RTL_GIGA_MAC_VER_05:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4134
	case RTL_GIGA_MAC_VER_06:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4135
	case RTL_GIGA_MAC_VER_10:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4136
	case RTL_GIGA_MAC_VER_11:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4137
	case RTL_GIGA_MAC_VER_12:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4138
	case RTL_GIGA_MAC_VER_13:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4139
	case RTL_GIGA_MAC_VER_14:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4140
	case RTL_GIGA_MAC_VER_15:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4141
	case RTL_GIGA_MAC_VER_16:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4142
	case RTL_GIGA_MAC_VER_17:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4143
		RTL_W32(RxConfig, RX_FIFO_THRESH | RX_DMA_BURST);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4144
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4145
	case RTL_GIGA_MAC_VER_18:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4146
	case RTL_GIGA_MAC_VER_19:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4147
	case RTL_GIGA_MAC_VER_20:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4148
	case RTL_GIGA_MAC_VER_21:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4149
	case RTL_GIGA_MAC_VER_22:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4150
	case RTL_GIGA_MAC_VER_23:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4151
	case RTL_GIGA_MAC_VER_24:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4152
	case RTL_GIGA_MAC_VER_34:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4153
		RTL_W32(RxConfig, RX128_INT_EN | RX_MULTI_EN | RX_DMA_BURST);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4154
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4155
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4156
		RTL_W32(RxConfig, RX128_INT_EN | RX_DMA_BURST);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4157
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4158
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4159
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4160
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4161
static void rtl8169_init_ring_indexes(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4162
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4163
	tp->dirty_tx = tp->dirty_rx = tp->cur_tx = tp->cur_rx = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4164
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4165
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4166
static void rtl_hw_jumbo_enable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4167
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4168
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4169
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4170
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4171
	rtl_generic_op(tp, tp->jumbo_ops.enable);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4172
	RTL_W8(Cfg9346, Cfg9346_Lock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4173
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4174
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4175
static void rtl_hw_jumbo_disable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4176
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4177
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4178
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4179
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4180
	rtl_generic_op(tp, tp->jumbo_ops.disable);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4181
	RTL_W8(Cfg9346, Cfg9346_Lock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4182
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4183
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4184
static void r8168c_hw_jumbo_enable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4185
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4186
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4187
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4188
	RTL_W8(Config3, RTL_R8(Config3) | Jumbo_En0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4189
	RTL_W8(Config4, RTL_R8(Config4) | Jumbo_En1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4190
	rtl_tx_performance_tweak(tp->pci_dev, 0x2 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4191
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4192
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4193
static void r8168c_hw_jumbo_disable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4194
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4195
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4196
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4197
	RTL_W8(Config3, RTL_R8(Config3) & ~Jumbo_En0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4198
	RTL_W8(Config4, RTL_R8(Config4) & ~Jumbo_En1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4199
	rtl_tx_performance_tweak(tp->pci_dev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4200
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4201
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4202
static void r8168dp_hw_jumbo_enable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4203
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4204
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4205
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4206
	RTL_W8(Config3, RTL_R8(Config3) | Jumbo_En0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4207
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4208
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4209
static void r8168dp_hw_jumbo_disable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4210
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4211
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4212
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4213
	RTL_W8(Config3, RTL_R8(Config3) & ~Jumbo_En0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4214
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4215
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4216
static void r8168e_hw_jumbo_enable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4217
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4218
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4219
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4220
	RTL_W8(MaxTxPacketSize, 0x3f);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4221
	RTL_W8(Config3, RTL_R8(Config3) | Jumbo_En0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4222
	RTL_W8(Config4, RTL_R8(Config4) | 0x01);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4223
	rtl_tx_performance_tweak(tp->pci_dev, 0x2 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4224
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4225
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4226
static void r8168e_hw_jumbo_disable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4227
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4228
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4229
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4230
	RTL_W8(MaxTxPacketSize, 0x0c);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4231
	RTL_W8(Config3, RTL_R8(Config3) & ~Jumbo_En0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4232
	RTL_W8(Config4, RTL_R8(Config4) & ~0x01);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4233
	rtl_tx_performance_tweak(tp->pci_dev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4234
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4235
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4236
static void r8168b_0_hw_jumbo_enable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4237
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4238
	rtl_tx_performance_tweak(tp->pci_dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4239
		(0x2 << MAX_READ_REQUEST_SHIFT) | PCI_EXP_DEVCTL_NOSNOOP_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4240
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4241
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4242
static void r8168b_0_hw_jumbo_disable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4243
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4244
	rtl_tx_performance_tweak(tp->pci_dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4245
		(0x5 << MAX_READ_REQUEST_SHIFT) | PCI_EXP_DEVCTL_NOSNOOP_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4246
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4247
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4248
static void r8168b_1_hw_jumbo_enable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4249
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4250
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4251
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4252
	r8168b_0_hw_jumbo_enable(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4253
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4254
	RTL_W8(Config4, RTL_R8(Config4) | (1 << 0));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4255
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4256
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4257
static void r8168b_1_hw_jumbo_disable(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4258
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4259
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4260
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4261
	r8168b_0_hw_jumbo_disable(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4262
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4263
	RTL_W8(Config4, RTL_R8(Config4) & ~(1 << 0));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4264
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4265
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4266
static void __devinit rtl_init_jumbo_ops(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4267
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4268
	struct jumbo_ops *ops = &tp->jumbo_ops;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4269
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4270
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4271
	case RTL_GIGA_MAC_VER_11:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4272
		ops->disable	= r8168b_0_hw_jumbo_disable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4273
		ops->enable	= r8168b_0_hw_jumbo_enable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4274
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4275
	case RTL_GIGA_MAC_VER_12:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4276
	case RTL_GIGA_MAC_VER_17:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4277
		ops->disable	= r8168b_1_hw_jumbo_disable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4278
		ops->enable	= r8168b_1_hw_jumbo_enable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4279
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4280
	case RTL_GIGA_MAC_VER_18: /* Wild guess. Needs info from Realtek. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4281
	case RTL_GIGA_MAC_VER_19:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4282
	case RTL_GIGA_MAC_VER_20:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4283
	case RTL_GIGA_MAC_VER_21: /* Wild guess. Needs info from Realtek. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4284
	case RTL_GIGA_MAC_VER_22:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4285
	case RTL_GIGA_MAC_VER_23:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4286
	case RTL_GIGA_MAC_VER_24:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4287
	case RTL_GIGA_MAC_VER_25:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4288
	case RTL_GIGA_MAC_VER_26:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4289
		ops->disable	= r8168c_hw_jumbo_disable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4290
		ops->enable	= r8168c_hw_jumbo_enable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4291
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4292
	case RTL_GIGA_MAC_VER_27:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4293
	case RTL_GIGA_MAC_VER_28:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4294
		ops->disable	= r8168dp_hw_jumbo_disable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4295
		ops->enable	= r8168dp_hw_jumbo_enable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4296
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4297
	case RTL_GIGA_MAC_VER_31: /* Wild guess. Needs info from Realtek. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4298
	case RTL_GIGA_MAC_VER_32:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4299
	case RTL_GIGA_MAC_VER_33:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4300
	case RTL_GIGA_MAC_VER_34:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4301
		ops->disable	= r8168e_hw_jumbo_disable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4302
		ops->enable	= r8168e_hw_jumbo_enable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4303
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4304
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4305
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4306
	 * No action needed for jumbo frames with 8169.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4307
	 * No jumbo for 810x at all.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4308
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4309
	case RTL_GIGA_MAC_VER_40:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4310
	case RTL_GIGA_MAC_VER_41:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4311
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4312
		ops->disable	= NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4313
		ops->enable	= NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4314
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4315
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4316
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4317
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4318
DECLARE_RTL_COND(rtl_chipcmd_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4319
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4320
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4321
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4322
	return RTL_R8(ChipCmd) & CmdReset;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4323
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4324
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4325
static void rtl_hw_reset(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4326
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4327
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4328
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4329
	RTL_W8(ChipCmd, CmdReset);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4330
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4331
	rtl_udelay_loop_wait_low(tp, &rtl_chipcmd_cond, 100, 100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4332
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4333
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4334
static void rtl_request_uncached_firmware(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4335
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4336
	struct rtl_fw *rtl_fw;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4337
	const char *name;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4338
	int rc = -ENOMEM;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4339
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4340
	name = rtl_lookup_firmware_name(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4341
	if (!name)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4342
		goto out_no_firmware;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4343
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4344
	rtl_fw = kzalloc(sizeof(*rtl_fw), GFP_KERNEL);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4345
	if (!rtl_fw)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4346
		goto err_warn;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4347
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4348
	rc = request_firmware(&rtl_fw->fw, name, &tp->pci_dev->dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4349
	if (rc < 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4350
		goto err_free;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4351
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4352
	rc = rtl_check_firmware(tp, rtl_fw);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4353
	if (rc < 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4354
		goto err_release_firmware;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4355
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4356
	tp->rtl_fw = rtl_fw;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4357
out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4358
	return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4359
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4360
err_release_firmware:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4361
	release_firmware(rtl_fw->fw);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4362
err_free:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4363
	kfree(rtl_fw);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4364
err_warn:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4365
	netif_warn(tp, ifup, tp->dev, "unable to load firmware patch %s (%d)\n",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4366
		   name, rc);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4367
out_no_firmware:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4368
	tp->rtl_fw = NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4369
	goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4370
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4371
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4372
static void rtl_request_firmware(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4373
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4374
	if (IS_ERR(tp->rtl_fw))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4375
		rtl_request_uncached_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4376
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4377
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4378
static void rtl_rx_close(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4379
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4380
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4381
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4382
	RTL_W32(RxConfig, RTL_R32(RxConfig) & ~RX_CONFIG_ACCEPT_MASK);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4383
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4384
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4385
DECLARE_RTL_COND(rtl_npq_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4386
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4387
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4388
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4389
	return RTL_R8(TxPoll) & NPQ;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4390
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4391
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4392
DECLARE_RTL_COND(rtl_txcfg_empty_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4393
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4394
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4395
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4396
	return RTL_R32(TxConfig) & TXCFG_EMPTY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4397
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4398
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4399
static void rtl8169_hw_reset(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4400
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4401
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4402
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4403
	/* Disable interrupts */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4404
	rtl8169_irq_mask_and_ack(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4405
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4406
	rtl_rx_close(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4407
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4408
	if (tp->mac_version == RTL_GIGA_MAC_VER_27 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4409
	    tp->mac_version == RTL_GIGA_MAC_VER_28 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4410
	    tp->mac_version == RTL_GIGA_MAC_VER_31) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4411
		rtl_udelay_loop_wait_low(tp, &rtl_npq_cond, 20, 42*42);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4412
	} else if (tp->mac_version == RTL_GIGA_MAC_VER_34 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4413
	           tp->mac_version == RTL_GIGA_MAC_VER_35 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4414
	           tp->mac_version == RTL_GIGA_MAC_VER_36 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4415
	           tp->mac_version == RTL_GIGA_MAC_VER_37 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4416
	           tp->mac_version == RTL_GIGA_MAC_VER_40 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4417
	           tp->mac_version == RTL_GIGA_MAC_VER_41 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4418
	           tp->mac_version == RTL_GIGA_MAC_VER_38) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4419
		RTL_W8(ChipCmd, RTL_R8(ChipCmd) | StopReq);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4420
		rtl_udelay_loop_wait_high(tp, &rtl_txcfg_empty_cond, 100, 666);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4421
	} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4422
		RTL_W8(ChipCmd, RTL_R8(ChipCmd) | StopReq);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4423
		udelay(100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4424
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4425
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4426
	rtl_hw_reset(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4427
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4428
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4429
static void rtl_set_rx_tx_config_registers(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4430
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4431
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4432
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4433
	/* Set DMA burst size and Interframe Gap Time */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4434
	RTL_W32(TxConfig, (TX_DMA_BURST << TxDMAShift) |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4435
		(InterFrameGap << TxInterFrameGapShift));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4436
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4437
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4438
static void rtl_hw_start(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4439
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4440
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4441
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4442
	tp->hw_start(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4443
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4444
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4445
		rtl_irq_enable_all(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4446
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4447
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4448
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4449
static void rtl_set_rx_tx_desc_registers(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4450
					 void __iomem *ioaddr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4451
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4452
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4453
	 * Magic spell: some iop3xx ARM board needs the TxDescAddrHigh
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4454
	 * register to be written before TxDescAddrLow to work.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4455
	 * Switching from MMIO to I/O access fixes the issue as well.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4456
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4457
	RTL_W32(TxDescStartAddrHigh, ((u64) tp->TxPhyAddr) >> 32);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4458
	RTL_W32(TxDescStartAddrLow, ((u64) tp->TxPhyAddr) & DMA_BIT_MASK(32));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4459
	RTL_W32(RxDescAddrHigh, ((u64) tp->RxPhyAddr) >> 32);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4460
	RTL_W32(RxDescAddrLow, ((u64) tp->RxPhyAddr) & DMA_BIT_MASK(32));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4461
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4462
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4463
static u16 rtl_rw_cpluscmd(void __iomem *ioaddr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4464
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4465
	u16 cmd;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4466
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4467
	cmd = RTL_R16(CPlusCmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4468
	RTL_W16(CPlusCmd, cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4469
	return cmd;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4470
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4471
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4472
static void rtl_set_rx_max_size(void __iomem *ioaddr, unsigned int rx_buf_sz)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4473
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4474
	/* Low hurts. Let's disable the filtering. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4475
	RTL_W16(RxMaxSize, rx_buf_sz + 1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4476
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4477
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4478
static void rtl8169_set_magic_reg(void __iomem *ioaddr, unsigned mac_version)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4479
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4480
	static const struct rtl_cfg2_info {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4481
		u32 mac_version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4482
		u32 clk;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4483
		u32 val;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4484
	} cfg2_info [] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4485
		{ RTL_GIGA_MAC_VER_05, PCI_Clock_33MHz, 0x000fff00 }, // 8110SCd
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4486
		{ RTL_GIGA_MAC_VER_05, PCI_Clock_66MHz, 0x000fffff },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4487
		{ RTL_GIGA_MAC_VER_06, PCI_Clock_33MHz, 0x00ffff00 }, // 8110SCe
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4488
		{ RTL_GIGA_MAC_VER_06, PCI_Clock_66MHz, 0x00ffffff }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4489
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4490
	const struct rtl_cfg2_info *p = cfg2_info;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4491
	unsigned int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4492
	u32 clk;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4493
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4494
	clk = RTL_R8(Config2) & PCI_Clock_66MHz;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4495
	for (i = 0; i < ARRAY_SIZE(cfg2_info); i++, p++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4496
		if ((p->mac_version == mac_version) && (p->clk == clk)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4497
			RTL_W32(0x7c, p->val);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4498
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4499
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4500
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4501
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4502
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4503
static void rtl_set_rx_mode(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4504
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4505
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4506
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4507
	u32 mc_filter[2];	/* Multicast hash filter */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4508
	int rx_mode;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4509
	u32 tmp = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4510
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4511
	if (dev->flags & IFF_PROMISC) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4512
		/* Unconditionally log net taps. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4513
		netif_notice(tp, link, dev, "Promiscuous mode enabled\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4514
		rx_mode =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4515
		    AcceptBroadcast | AcceptMulticast | AcceptMyPhys |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4516
		    AcceptAllPhys;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4517
		mc_filter[1] = mc_filter[0] = 0xffffffff;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4518
	} else if ((netdev_mc_count(dev) > multicast_filter_limit) ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4519
		   (dev->flags & IFF_ALLMULTI)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4520
		/* Too many to filter perfectly -- accept all multicasts. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4521
		rx_mode = AcceptBroadcast | AcceptMulticast | AcceptMyPhys;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4522
		mc_filter[1] = mc_filter[0] = 0xffffffff;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4523
	} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4524
		struct netdev_hw_addr *ha;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4525
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4526
		rx_mode = AcceptBroadcast | AcceptMyPhys;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4527
		mc_filter[1] = mc_filter[0] = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4528
		netdev_for_each_mc_addr(ha, dev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4529
			int bit_nr = ether_crc(ETH_ALEN, ha->addr) >> 26;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4530
			mc_filter[bit_nr >> 5] |= 1 << (bit_nr & 31);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4531
			rx_mode |= AcceptMulticast;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4532
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4533
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4534
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4535
	if (dev->features & NETIF_F_RXALL)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4536
		rx_mode |= (AcceptErr | AcceptRunt);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4537
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4538
	tmp = (RTL_R32(RxConfig) & ~RX_CONFIG_ACCEPT_MASK) | rx_mode;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4539
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4540
	if (tp->mac_version > RTL_GIGA_MAC_VER_06) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4541
		u32 data = mc_filter[0];
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4542
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4543
		mc_filter[0] = swab32(mc_filter[1]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4544
		mc_filter[1] = swab32(data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4545
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4546
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4547
	if (tp->mac_version == RTL_GIGA_MAC_VER_35)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4548
		mc_filter[1] = mc_filter[0] = 0xffffffff;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4549
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4550
	RTL_W32(MAR0 + 4, mc_filter[1]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4551
	RTL_W32(MAR0 + 0, mc_filter[0]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4552
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4553
	RTL_W32(RxConfig, tmp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4554
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4555
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4556
static void rtl_hw_start_8169(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4557
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4558
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4559
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4560
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4561
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4562
	if (tp->mac_version == RTL_GIGA_MAC_VER_05) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4563
		RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) | PCIMulRW);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4564
		pci_write_config_byte(pdev, PCI_CACHE_LINE_SIZE, 0x08);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4565
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4566
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4567
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4568
	if (tp->mac_version == RTL_GIGA_MAC_VER_01 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4569
	    tp->mac_version == RTL_GIGA_MAC_VER_02 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4570
	    tp->mac_version == RTL_GIGA_MAC_VER_03 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4571
	    tp->mac_version == RTL_GIGA_MAC_VER_04)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4572
		RTL_W8(ChipCmd, CmdTxEnb | CmdRxEnb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4573
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4574
	rtl_init_rxcfg(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4575
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4576
	RTL_W8(EarlyTxThres, NoEarlyTx);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4577
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4578
	rtl_set_rx_max_size(ioaddr, rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4579
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4580
	if (tp->mac_version == RTL_GIGA_MAC_VER_01 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4581
	    tp->mac_version == RTL_GIGA_MAC_VER_02 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4582
	    tp->mac_version == RTL_GIGA_MAC_VER_03 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4583
	    tp->mac_version == RTL_GIGA_MAC_VER_04)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4584
		rtl_set_rx_tx_config_registers(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4585
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4586
	tp->cp_cmd |= rtl_rw_cpluscmd(ioaddr) | PCIMulRW;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4587
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4588
	if (tp->mac_version == RTL_GIGA_MAC_VER_02 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4589
	    tp->mac_version == RTL_GIGA_MAC_VER_03) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4590
		dprintk("Set MAC Reg C+CR Offset 0xE0. "
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4591
			"Bit-3 and bit-14 MUST be 1\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4592
		tp->cp_cmd |= (1 << 14);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4593
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4594
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4595
	RTL_W16(CPlusCmd, tp->cp_cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4596
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4597
	rtl8169_set_magic_reg(ioaddr, tp->mac_version);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4598
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4599
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4600
	 * Undocumented corner. Supposedly:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4601
	 * (TxTimer << 12) | (TxPackets << 8) | (RxTimer << 4) | RxPackets
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4602
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4603
	RTL_W16(IntrMitigate, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4604
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4605
	rtl_set_rx_tx_desc_registers(tp, ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4606
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4607
	if (tp->mac_version != RTL_GIGA_MAC_VER_01 &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4608
	    tp->mac_version != RTL_GIGA_MAC_VER_02 &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4609
	    tp->mac_version != RTL_GIGA_MAC_VER_03 &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4610
	    tp->mac_version != RTL_GIGA_MAC_VER_04) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4611
		RTL_W8(ChipCmd, CmdTxEnb | CmdRxEnb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4612
		rtl_set_rx_tx_config_registers(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4613
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4614
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4615
	RTL_W8(Cfg9346, Cfg9346_Lock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4616
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4617
	/* Initially a 10 us delay. Turned it into a PCI commit. - FR */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4618
	RTL_R8(IntrMask);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4619
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4620
	RTL_W32(RxMissed, 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4621
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4622
	rtl_set_rx_mode(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4623
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4624
	/* no early-rx interrupts */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4625
	RTL_W16(MultiIntr, RTL_R16(MultiIntr) & 0xF000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4626
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4627
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4628
static void rtl_csi_write(struct rtl8169_private *tp, int addr, int value)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4629
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4630
	if (tp->csi_ops.write)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4631
		tp->csi_ops.write(tp, addr, value);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4632
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4633
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4634
static u32 rtl_csi_read(struct rtl8169_private *tp, int addr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4635
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4636
	return tp->csi_ops.read ? tp->csi_ops.read(tp, addr) : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4637
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4638
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4639
static void rtl_csi_access_enable(struct rtl8169_private *tp, u32 bits)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4640
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4641
	u32 csi;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4642
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4643
	csi = rtl_csi_read(tp, 0x070c) & 0x00ffffff;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4644
	rtl_csi_write(tp, 0x070c, csi | bits);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4645
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4646
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4647
static void rtl_csi_access_enable_1(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4648
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4649
	rtl_csi_access_enable(tp, 0x17000000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4650
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4651
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4652
static void rtl_csi_access_enable_2(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4653
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4654
	rtl_csi_access_enable(tp, 0x27000000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4655
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4656
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4657
DECLARE_RTL_COND(rtl_csiar_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4658
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4659
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4660
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4661
	return RTL_R32(CSIAR) & CSIAR_FLAG;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4662
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4663
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4664
static void r8169_csi_write(struct rtl8169_private *tp, int addr, int value)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4665
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4666
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4667
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4668
	RTL_W32(CSIDR, value);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4669
	RTL_W32(CSIAR, CSIAR_WRITE_CMD | (addr & CSIAR_ADDR_MASK) |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4670
		CSIAR_BYTE_ENABLE << CSIAR_BYTE_ENABLE_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4671
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4672
	rtl_udelay_loop_wait_low(tp, &rtl_csiar_cond, 10, 100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4673
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4674
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4675
static u32 r8169_csi_read(struct rtl8169_private *tp, int addr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4676
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4677
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4678
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4679
	RTL_W32(CSIAR, (addr & CSIAR_ADDR_MASK) |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4680
		CSIAR_BYTE_ENABLE << CSIAR_BYTE_ENABLE_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4681
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4682
	return rtl_udelay_loop_wait_high(tp, &rtl_csiar_cond, 10, 100) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4683
		RTL_R32(CSIDR) : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4684
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4685
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4686
static void r8402_csi_write(struct rtl8169_private *tp, int addr, int value)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4687
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4688
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4689
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4690
	RTL_W32(CSIDR, value);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4691
	RTL_W32(CSIAR, CSIAR_WRITE_CMD | (addr & CSIAR_ADDR_MASK) |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4692
		CSIAR_BYTE_ENABLE << CSIAR_BYTE_ENABLE_SHIFT |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4693
		CSIAR_FUNC_NIC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4694
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4695
	rtl_udelay_loop_wait_low(tp, &rtl_csiar_cond, 10, 100);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4696
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4697
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4698
static u32 r8402_csi_read(struct rtl8169_private *tp, int addr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4699
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4700
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4701
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4702
	RTL_W32(CSIAR, (addr & CSIAR_ADDR_MASK) | CSIAR_FUNC_NIC |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4703
		CSIAR_BYTE_ENABLE << CSIAR_BYTE_ENABLE_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4704
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4705
	return rtl_udelay_loop_wait_high(tp, &rtl_csiar_cond, 10, 100) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4706
		RTL_R32(CSIDR) : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4707
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4708
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4709
static void __devinit rtl_init_csi_ops(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4710
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4711
	struct csi_ops *ops = &tp->csi_ops;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4712
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4713
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4714
	case RTL_GIGA_MAC_VER_01:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4715
	case RTL_GIGA_MAC_VER_02:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4716
	case RTL_GIGA_MAC_VER_03:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4717
	case RTL_GIGA_MAC_VER_04:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4718
	case RTL_GIGA_MAC_VER_05:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4719
	case RTL_GIGA_MAC_VER_06:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4720
	case RTL_GIGA_MAC_VER_10:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4721
	case RTL_GIGA_MAC_VER_11:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4722
	case RTL_GIGA_MAC_VER_12:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4723
	case RTL_GIGA_MAC_VER_13:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4724
	case RTL_GIGA_MAC_VER_14:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4725
	case RTL_GIGA_MAC_VER_15:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4726
	case RTL_GIGA_MAC_VER_16:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4727
	case RTL_GIGA_MAC_VER_17:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4728
		ops->write	= NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4729
		ops->read	= NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4730
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4731
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4732
	case RTL_GIGA_MAC_VER_37:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4733
	case RTL_GIGA_MAC_VER_38:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4734
		ops->write	= r8402_csi_write;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4735
		ops->read	= r8402_csi_read;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4736
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4737
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4738
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4739
		ops->write	= r8169_csi_write;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4740
		ops->read	= r8169_csi_read;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4741
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4742
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4743
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4744
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4745
struct ephy_info {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4746
	unsigned int offset;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4747
	u16 mask;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4748
	u16 bits;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4749
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4750
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4751
static void rtl_ephy_init(struct rtl8169_private *tp, const struct ephy_info *e,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4752
			  int len)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4753
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4754
	u16 w;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4755
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4756
	while (len-- > 0) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4757
		w = (rtl_ephy_read(tp, e->offset) & ~e->mask) | e->bits;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4758
		rtl_ephy_write(tp, e->offset, w);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4759
		e++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4760
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4761
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4762
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4763
static void rtl_disable_clock_request(struct pci_dev *pdev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4764
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4765
	int cap = pci_pcie_cap(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4766
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4767
	if (cap) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4768
		u16 ctl;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4769
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4770
		pci_read_config_word(pdev, cap + PCI_EXP_LNKCTL, &ctl);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4771
		ctl &= ~PCI_EXP_LNKCTL_CLKREQ_EN;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4772
		pci_write_config_word(pdev, cap + PCI_EXP_LNKCTL, ctl);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4773
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4774
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4775
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4776
static void rtl_enable_clock_request(struct pci_dev *pdev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4777
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4778
	int cap = pci_pcie_cap(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4779
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4780
	if (cap) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4781
		u16 ctl;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4782
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4783
		pci_read_config_word(pdev, cap + PCI_EXP_LNKCTL, &ctl);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4784
		ctl |= PCI_EXP_LNKCTL_CLKREQ_EN;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4785
		pci_write_config_word(pdev, cap + PCI_EXP_LNKCTL, ctl);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4786
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4787
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4788
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4789
#define R8168_CPCMD_QUIRK_MASK (\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4790
	EnableBist | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4791
	Mac_dbgo_oe | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4792
	Force_half_dup | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4793
	Force_rxflow_en | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4794
	Force_txflow_en | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4795
	Cxpl_dbg_sel | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4796
	ASF | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4797
	PktCntrDisable | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4798
	Mac_dbgo_sel)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4799
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4800
static void rtl_hw_start_8168bb(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4801
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4802
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4803
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4804
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4805
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4806
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4807
	RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) & ~R8168_CPCMD_QUIRK_MASK);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4808
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4809
	rtl_tx_performance_tweak(pdev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4810
		(0x5 << MAX_READ_REQUEST_SHIFT) | PCI_EXP_DEVCTL_NOSNOOP_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4811
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4812
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4813
static void rtl_hw_start_8168bef(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4814
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4815
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4816
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4817
	rtl_hw_start_8168bb(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4818
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4819
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4820
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4821
	RTL_W8(Config4, RTL_R8(Config4) & ~(1 << 0));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4822
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4823
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4824
static void __rtl_hw_start_8168cp(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4825
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4826
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4827
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4828
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4829
	RTL_W8(Config1, RTL_R8(Config1) | Speed_down);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4830
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4831
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4832
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4833
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4834
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4835
	rtl_disable_clock_request(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4836
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4837
	RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) & ~R8168_CPCMD_QUIRK_MASK);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4838
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4839
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4840
static void rtl_hw_start_8168cp_1(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4841
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4842
	static const struct ephy_info e_info_8168cp[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4843
		{ 0x01, 0,	0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4844
		{ 0x02, 0x0800,	0x1000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4845
		{ 0x03, 0,	0x0042 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4846
		{ 0x06, 0x0080,	0x0000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4847
		{ 0x07, 0,	0x2000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4848
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4849
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4850
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4851
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4852
	rtl_ephy_init(tp, e_info_8168cp, ARRAY_SIZE(e_info_8168cp));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4853
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4854
	__rtl_hw_start_8168cp(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4855
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4856
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4857
static void rtl_hw_start_8168cp_2(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4858
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4859
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4860
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4861
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4862
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4863
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4864
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4865
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4866
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4867
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4868
	RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) & ~R8168_CPCMD_QUIRK_MASK);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4869
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4870
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4871
static void rtl_hw_start_8168cp_3(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4872
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4873
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4874
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4875
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4876
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4877
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4878
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4879
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4880
	/* Magic. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4881
	RTL_W8(DBG_REG, 0x20);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4882
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4883
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4884
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4885
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4886
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4887
	RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) & ~R8168_CPCMD_QUIRK_MASK);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4888
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4889
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4890
static void rtl_hw_start_8168c_1(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4891
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4892
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4893
	static const struct ephy_info e_info_8168c_1[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4894
		{ 0x02, 0x0800,	0x1000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4895
		{ 0x03, 0,	0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4896
		{ 0x06, 0x0080,	0x0000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4897
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4898
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4899
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4900
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4901
	RTL_W8(DBG_REG, 0x06 | FIX_NAK_1 | FIX_NAK_2);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4902
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4903
	rtl_ephy_init(tp, e_info_8168c_1, ARRAY_SIZE(e_info_8168c_1));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4904
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4905
	__rtl_hw_start_8168cp(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4906
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4907
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4908
static void rtl_hw_start_8168c_2(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4909
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4910
	static const struct ephy_info e_info_8168c_2[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4911
		{ 0x01, 0,	0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4912
		{ 0x03, 0x0400,	0x0220 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4913
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4914
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4915
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4916
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4917
	rtl_ephy_init(tp, e_info_8168c_2, ARRAY_SIZE(e_info_8168c_2));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4918
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4919
	__rtl_hw_start_8168cp(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4920
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4921
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4922
static void rtl_hw_start_8168c_3(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4923
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4924
	rtl_hw_start_8168c_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4925
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4926
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4927
static void rtl_hw_start_8168c_4(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4928
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4929
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4930
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4931
	__rtl_hw_start_8168cp(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4932
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4933
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4934
static void rtl_hw_start_8168d(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4935
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4936
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4937
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4938
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4939
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4940
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4941
	rtl_disable_clock_request(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4942
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4943
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4944
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4945
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4946
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4947
	RTL_W16(CPlusCmd, RTL_R16(CPlusCmd) & ~R8168_CPCMD_QUIRK_MASK);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4948
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4949
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4950
static void rtl_hw_start_8168dp(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4951
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4952
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4953
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4954
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4955
	rtl_csi_access_enable_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4956
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4957
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4958
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4959
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4960
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4961
	rtl_disable_clock_request(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4962
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4963
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4964
static void rtl_hw_start_8168d_4(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4965
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4966
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4967
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4968
	static const struct ephy_info e_info_8168d_4[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4969
		{ 0x0b, ~0,	0x48 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4970
		{ 0x19, 0x20,	0x50 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4971
		{ 0x0c, ~0,	0x20 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4972
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4973
	int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4974
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4975
	rtl_csi_access_enable_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4976
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4977
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4978
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4979
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4980
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4981
	for (i = 0; i < ARRAY_SIZE(e_info_8168d_4); i++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4982
		const struct ephy_info *e = e_info_8168d_4 + i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4983
		u16 w;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4984
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4985
		w = rtl_ephy_read(tp, e->offset);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4986
		rtl_ephy_write(tp, 0x03, (w & e->mask) | e->bits);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4987
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4988
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4989
	rtl_enable_clock_request(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4990
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4991
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4992
static void rtl_hw_start_8168e_1(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4993
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4994
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4995
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4996
	static const struct ephy_info e_info_8168e_1[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4997
		{ 0x00, 0x0200,	0x0100 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4998
		{ 0x00, 0x0000,	0x0004 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  4999
		{ 0x06, 0x0002,	0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5000
		{ 0x06, 0x0000,	0x0030 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5001
		{ 0x07, 0x0000,	0x2000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5002
		{ 0x00, 0x0000,	0x0020 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5003
		{ 0x03, 0x5800,	0x2000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5004
		{ 0x03, 0x0000,	0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5005
		{ 0x01, 0x0800,	0x1000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5006
		{ 0x07, 0x0000,	0x4000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5007
		{ 0x1e, 0x0000,	0x2000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5008
		{ 0x19, 0xffff,	0xfe6c },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5009
		{ 0x0a, 0x0000,	0x0040 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5010
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5011
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5012
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5013
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5014
	rtl_ephy_init(tp, e_info_8168e_1, ARRAY_SIZE(e_info_8168e_1));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5015
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5016
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5017
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5018
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5019
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5020
	rtl_disable_clock_request(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5021
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5022
	/* Reset tx FIFO pointer */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5023
	RTL_W32(MISC, RTL_R32(MISC) | TXPLA_RST);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5024
	RTL_W32(MISC, RTL_R32(MISC) & ~TXPLA_RST);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5025
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5026
	RTL_W8(Config5, RTL_R8(Config5) & ~Spi_en);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5027
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5028
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5029
static void rtl_hw_start_8168e_2(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5030
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5031
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5032
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5033
	static const struct ephy_info e_info_8168e_2[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5034
		{ 0x09, 0x0000,	0x0080 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5035
		{ 0x19, 0x0000,	0x0224 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5036
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5037
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5038
	rtl_csi_access_enable_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5039
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5040
	rtl_ephy_init(tp, e_info_8168e_2, ARRAY_SIZE(e_info_8168e_2));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5041
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5042
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5043
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5044
	rtl_eri_write(tp, 0xc0, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5045
	rtl_eri_write(tp, 0xb8, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5046
	rtl_eri_write(tp, 0xc8, ERIAR_MASK_1111, 0x00100002, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5047
	rtl_eri_write(tp, 0xe8, ERIAR_MASK_1111, 0x00100006, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5048
	rtl_eri_write(tp, 0xcc, ERIAR_MASK_1111, 0x00000050, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5049
	rtl_eri_write(tp, 0xd0, ERIAR_MASK_1111, 0x07ff0060, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5050
	rtl_w1w0_eri(tp, 0x1b0, ERIAR_MASK_0001, 0x10, 0x00, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5051
	rtl_w1w0_eri(tp, 0x0d4, ERIAR_MASK_0011, 0x0c00, 0xff00, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5052
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5053
	RTL_W8(MaxTxPacketSize, EarlySize);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5054
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5055
	rtl_disable_clock_request(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5056
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5057
	RTL_W32(TxConfig, RTL_R32(TxConfig) | TXCFG_AUTO_FIFO);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5058
	RTL_W8(MCU, RTL_R8(MCU) & ~NOW_IS_OOB);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5059
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5060
	/* Adjust EEE LED frequency */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5061
	RTL_W8(EEE_LED, RTL_R8(EEE_LED) & ~0x07);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5062
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5063
	RTL_W8(DLLPR, RTL_R8(DLLPR) | PFM_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5064
	RTL_W32(MISC, RTL_R32(MISC) | PWM_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5065
	RTL_W8(Config5, RTL_R8(Config5) & ~Spi_en);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5066
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5067
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5068
static void rtl_hw_start_8168f(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5069
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5070
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5071
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5072
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5073
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5074
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5075
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5076
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5077
	rtl_eri_write(tp, 0xc0, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5078
	rtl_eri_write(tp, 0xb8, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5079
	rtl_eri_write(tp, 0xc8, ERIAR_MASK_1111, 0x00100002, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5080
	rtl_eri_write(tp, 0xe8, ERIAR_MASK_1111, 0x00100006, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5081
	rtl_w1w0_eri(tp, 0xdc, ERIAR_MASK_0001, 0x00, 0x01, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5082
	rtl_w1w0_eri(tp, 0xdc, ERIAR_MASK_0001, 0x01, 0x00, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5083
	rtl_w1w0_eri(tp, 0x1b0, ERIAR_MASK_0001, 0x10, 0x00, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5084
	rtl_w1w0_eri(tp, 0x1d0, ERIAR_MASK_0001, 0x10, 0x00, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5085
	rtl_eri_write(tp, 0xcc, ERIAR_MASK_1111, 0x00000050, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5086
	rtl_eri_write(tp, 0xd0, ERIAR_MASK_1111, 0x00000060, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5087
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5088
	RTL_W8(MaxTxPacketSize, EarlySize);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5089
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5090
	rtl_disable_clock_request(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5091
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5092
	RTL_W32(TxConfig, RTL_R32(TxConfig) | TXCFG_AUTO_FIFO);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5093
	RTL_W8(MCU, RTL_R8(MCU) & ~NOW_IS_OOB);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5094
	RTL_W8(DLLPR, RTL_R8(DLLPR) | PFM_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5095
	RTL_W32(MISC, RTL_R32(MISC) | PWM_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5096
	RTL_W8(Config5, RTL_R8(Config5) & ~Spi_en);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5097
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5098
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5099
static void rtl_hw_start_8168f_1(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5100
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5101
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5102
	static const struct ephy_info e_info_8168f_1[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5103
		{ 0x06, 0x00c0,	0x0020 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5104
		{ 0x08, 0x0001,	0x0002 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5105
		{ 0x09, 0x0000,	0x0080 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5106
		{ 0x19, 0x0000,	0x0224 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5107
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5108
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5109
	rtl_hw_start_8168f(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5110
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5111
	rtl_ephy_init(tp, e_info_8168f_1, ARRAY_SIZE(e_info_8168f_1));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5112
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5113
	rtl_w1w0_eri(tp, 0x0d4, ERIAR_MASK_0011, 0x0c00, 0xff00, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5114
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5115
	/* Adjust EEE LED frequency */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5116
	RTL_W8(EEE_LED, RTL_R8(EEE_LED) & ~0x07);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5117
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5118
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5119
static void rtl_hw_start_8411(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5120
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5121
	static const struct ephy_info e_info_8168f_1[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5122
		{ 0x06, 0x00c0,	0x0020 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5123
		{ 0x0f, 0xffff,	0x5200 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5124
		{ 0x1e, 0x0000,	0x4000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5125
		{ 0x19, 0x0000,	0x0224 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5126
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5127
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5128
	rtl_hw_start_8168f(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5129
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5130
	rtl_ephy_init(tp, e_info_8168f_1, ARRAY_SIZE(e_info_8168f_1));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5131
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5132
	rtl_w1w0_eri(tp, 0x0d4, ERIAR_MASK_0011, 0x0c00, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5133
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5134
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5135
static void rtl_hw_start_8168g_1(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5136
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5137
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5138
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5139
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5140
	rtl_eri_write(tp, 0xc8, ERIAR_MASK_0101, 0x080002, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5141
	rtl_eri_write(tp, 0xcc, ERIAR_MASK_0001, 0x38, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5142
	rtl_eri_write(tp, 0xd0, ERIAR_MASK_0001, 0x48, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5143
	rtl_eri_write(tp, 0xe8, ERIAR_MASK_1111, 0x00100006, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5144
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5145
	rtl_csi_access_enable_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5146
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5147
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5148
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5149
	rtl_w1w0_eri(tp, 0xdc, ERIAR_MASK_0001, 0x00, 0x01, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5150
	rtl_w1w0_eri(tp, 0xdc, ERIAR_MASK_0001, 0x01, 0x00, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5151
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5152
	RTL_W8(ChipCmd, CmdTxEnb | CmdRxEnb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5153
	RTL_W32(MISC, RTL_R32(MISC) & ~RXDV_GATED_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5154
	RTL_W8(MaxTxPacketSize, EarlySize);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5155
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5156
	rtl_eri_write(tp, 0xc0, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5157
	rtl_eri_write(tp, 0xb8, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5158
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5159
	/* Adjust EEE LED frequency */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5160
	RTL_W8(EEE_LED, RTL_R8(EEE_LED) & ~0x07);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5161
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5162
	rtl_w1w0_eri(tp, 0x2fc, ERIAR_MASK_0001, 0x01, 0x02, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5163
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5164
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5165
static void rtl_hw_start_8168(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5166
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5167
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5168
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5169
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5170
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5171
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5172
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5173
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5174
	rtl_set_rx_max_size(ioaddr, rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5175
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5176
	tp->cp_cmd |= RTL_R16(CPlusCmd) | PktCntrDisable | INTT_1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5177
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5178
	RTL_W16(CPlusCmd, tp->cp_cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5179
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5180
	RTL_W16(IntrMitigate, 0x5151);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5181
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5182
	/* Work around for RxFIFO overflow. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5183
	if (tp->mac_version == RTL_GIGA_MAC_VER_11) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5184
		tp->event_slow |= RxFIFOOver | PCSTimeout;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5185
		tp->event_slow &= ~RxOverflow;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5186
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5187
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5188
	rtl_set_rx_tx_desc_registers(tp, ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5189
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5190
	rtl_set_rx_mode(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5191
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5192
	RTL_W32(TxConfig, (TX_DMA_BURST << TxDMAShift) |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5193
		(InterFrameGap << TxInterFrameGapShift));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5194
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5195
	RTL_R8(IntrMask);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5196
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5197
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5198
	case RTL_GIGA_MAC_VER_11:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5199
		rtl_hw_start_8168bb(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5200
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5201
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5202
	case RTL_GIGA_MAC_VER_12:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5203
	case RTL_GIGA_MAC_VER_17:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5204
		rtl_hw_start_8168bef(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5205
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5206
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5207
	case RTL_GIGA_MAC_VER_18:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5208
		rtl_hw_start_8168cp_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5209
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5210
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5211
	case RTL_GIGA_MAC_VER_19:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5212
		rtl_hw_start_8168c_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5213
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5214
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5215
	case RTL_GIGA_MAC_VER_20:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5216
		rtl_hw_start_8168c_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5217
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5218
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5219
	case RTL_GIGA_MAC_VER_21:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5220
		rtl_hw_start_8168c_3(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5221
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5222
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5223
	case RTL_GIGA_MAC_VER_22:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5224
		rtl_hw_start_8168c_4(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5225
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5226
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5227
	case RTL_GIGA_MAC_VER_23:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5228
		rtl_hw_start_8168cp_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5229
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5230
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5231
	case RTL_GIGA_MAC_VER_24:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5232
		rtl_hw_start_8168cp_3(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5233
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5234
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5235
	case RTL_GIGA_MAC_VER_25:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5236
	case RTL_GIGA_MAC_VER_26:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5237
	case RTL_GIGA_MAC_VER_27:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5238
		rtl_hw_start_8168d(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5239
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5240
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5241
	case RTL_GIGA_MAC_VER_28:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5242
		rtl_hw_start_8168d_4(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5243
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5244
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5245
	case RTL_GIGA_MAC_VER_31:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5246
		rtl_hw_start_8168dp(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5247
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5248
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5249
	case RTL_GIGA_MAC_VER_32:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5250
	case RTL_GIGA_MAC_VER_33:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5251
		rtl_hw_start_8168e_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5252
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5253
	case RTL_GIGA_MAC_VER_34:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5254
		rtl_hw_start_8168e_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5255
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5256
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5257
	case RTL_GIGA_MAC_VER_35:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5258
	case RTL_GIGA_MAC_VER_36:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5259
		rtl_hw_start_8168f_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5260
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5261
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5262
	case RTL_GIGA_MAC_VER_38:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5263
		rtl_hw_start_8411(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5264
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5265
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5266
	case RTL_GIGA_MAC_VER_40:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5267
	case RTL_GIGA_MAC_VER_41:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5268
		rtl_hw_start_8168g_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5269
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5270
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5271
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5272
		printk(KERN_ERR PFX "%s: unknown chipset (mac_version = %d).\n",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5273
			dev->name, tp->mac_version);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5274
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5275
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5276
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5277
	RTL_W8(ChipCmd, CmdTxEnb | CmdRxEnb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5278
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5279
	RTL_W8(Cfg9346, Cfg9346_Lock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5280
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5281
	RTL_W16(MultiIntr, RTL_R16(MultiIntr) & 0xF000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5282
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5283
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5284
#define R810X_CPCMD_QUIRK_MASK (\
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5285
	EnableBist | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5286
	Mac_dbgo_oe | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5287
	Force_half_dup | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5288
	Force_rxflow_en | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5289
	Force_txflow_en | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5290
	Cxpl_dbg_sel | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5291
	ASF | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5292
	PktCntrDisable | \
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5293
	Mac_dbgo_sel)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5294
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5295
static void rtl_hw_start_8102e_1(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5296
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5297
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5298
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5299
	static const struct ephy_info e_info_8102e_1[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5300
		{ 0x01,	0, 0x6e65 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5301
		{ 0x02,	0, 0x091f },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5302
		{ 0x03,	0, 0xc2f9 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5303
		{ 0x06,	0, 0xafb5 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5304
		{ 0x07,	0, 0x0e00 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5305
		{ 0x19,	0, 0xec80 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5306
		{ 0x01,	0, 0x2e65 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5307
		{ 0x01,	0, 0x6e65 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5308
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5309
	u8 cfg1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5310
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5311
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5312
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5313
	RTL_W8(DBG_REG, FIX_NAK_1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5314
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5315
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5316
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5317
	RTL_W8(Config1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5318
	       LEDS1 | LEDS0 | Speed_down | MEMMAP | IOMAP | VPD | PMEnable);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5319
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5320
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5321
	cfg1 = RTL_R8(Config1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5322
	if ((cfg1 & LEDS0) && (cfg1 & LEDS1))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5323
		RTL_W8(Config1, cfg1 & ~LEDS0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5324
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5325
	rtl_ephy_init(tp, e_info_8102e_1, ARRAY_SIZE(e_info_8102e_1));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5326
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5327
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5328
static void rtl_hw_start_8102e_2(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5329
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5330
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5331
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5332
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5333
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5334
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5335
	rtl_tx_performance_tweak(pdev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5336
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5337
	RTL_W8(Config1, MEMMAP | IOMAP | VPD | PMEnable);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5338
	RTL_W8(Config3, RTL_R8(Config3) & ~Beacon_en);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5339
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5340
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5341
static void rtl_hw_start_8102e_3(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5342
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5343
	rtl_hw_start_8102e_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5344
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5345
	rtl_ephy_write(tp, 0x03, 0xc2f9);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5346
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5347
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5348
static void rtl_hw_start_8105e_1(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5349
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5350
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5351
	static const struct ephy_info e_info_8105e_1[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5352
		{ 0x07,	0, 0x4000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5353
		{ 0x19,	0, 0x0200 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5354
		{ 0x19,	0, 0x0020 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5355
		{ 0x1e,	0, 0x2000 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5356
		{ 0x03,	0, 0x0001 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5357
		{ 0x19,	0, 0x0100 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5358
		{ 0x19,	0, 0x0004 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5359
		{ 0x0a,	0, 0x0020 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5360
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5361
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5362
	/* Force LAN exit from ASPM if Rx/Tx are not idle */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5363
	RTL_W32(FuncEvent, RTL_R32(FuncEvent) | 0x002800);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5364
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5365
	/* Disable Early Tally Counter */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5366
	RTL_W32(FuncEvent, RTL_R32(FuncEvent) & ~0x010000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5367
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5368
	RTL_W8(MCU, RTL_R8(MCU) | EN_NDP | EN_OOB_RESET);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5369
	RTL_W8(DLLPR, RTL_R8(DLLPR) | PFM_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5370
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5371
	rtl_ephy_init(tp, e_info_8105e_1, ARRAY_SIZE(e_info_8105e_1));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5372
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5373
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5374
static void rtl_hw_start_8105e_2(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5375
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5376
	rtl_hw_start_8105e_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5377
	rtl_ephy_write(tp, 0x1e, rtl_ephy_read(tp, 0x1e) | 0x8000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5378
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5379
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5380
static void rtl_hw_start_8402(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5381
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5382
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5383
	static const struct ephy_info e_info_8402[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5384
		{ 0x19,	0xffff, 0xff64 },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5385
		{ 0x1e,	0, 0x4000 }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5386
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5387
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5388
	rtl_csi_access_enable_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5389
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5390
	/* Force LAN exit from ASPM if Rx/Tx are not idle */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5391
	RTL_W32(FuncEvent, RTL_R32(FuncEvent) | 0x002800);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5392
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5393
	RTL_W32(TxConfig, RTL_R32(TxConfig) | TXCFG_AUTO_FIFO);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5394
	RTL_W8(MCU, RTL_R8(MCU) & ~NOW_IS_OOB);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5395
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5396
	rtl_ephy_init(tp, e_info_8402, ARRAY_SIZE(e_info_8402));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5397
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5398
	rtl_tx_performance_tweak(tp->pci_dev, 0x5 << MAX_READ_REQUEST_SHIFT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5399
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5400
	rtl_eri_write(tp, 0xc8, ERIAR_MASK_1111, 0x00000002, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5401
	rtl_eri_write(tp, 0xe8, ERIAR_MASK_1111, 0x00000006, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5402
	rtl_w1w0_eri(tp, 0xdc, ERIAR_MASK_0001, 0x00, 0x01, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5403
	rtl_w1w0_eri(tp, 0xdc, ERIAR_MASK_0001, 0x01, 0x00, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5404
	rtl_eri_write(tp, 0xc0, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5405
	rtl_eri_write(tp, 0xb8, ERIAR_MASK_0011, 0x0000, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5406
	rtl_w1w0_eri(tp, 0x0d4, ERIAR_MASK_0011, 0x0e00, 0xff00, ERIAR_EXGMAC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5407
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5408
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5409
static void rtl_hw_start_8106(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5410
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5411
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5412
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5413
	/* Force LAN exit from ASPM if Rx/Tx are not idle */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5414
	RTL_W32(FuncEvent, RTL_R32(FuncEvent) | 0x002800);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5415
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5416
	RTL_W32(MISC, (RTL_R32(MISC) | DISABLE_LAN_EN) & ~EARLY_TALLY_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5417
	RTL_W8(MCU, RTL_R8(MCU) | EN_NDP | EN_OOB_RESET);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5418
	RTL_W8(DLLPR, RTL_R8(DLLPR) & ~PFM_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5419
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5420
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5421
static void rtl_hw_start_8101(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5422
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5423
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5424
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5425
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5426
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5427
	if (tp->mac_version >= RTL_GIGA_MAC_VER_30)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5428
		tp->event_slow &= ~RxFIFOOver;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5429
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5430
	if (tp->mac_version == RTL_GIGA_MAC_VER_13 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5431
	    tp->mac_version == RTL_GIGA_MAC_VER_16) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5432
		int cap = pci_pcie_cap(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5433
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5434
		if (cap) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5435
			pci_write_config_word(pdev, cap + PCI_EXP_DEVCTL,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5436
					      PCI_EXP_DEVCTL_NOSNOOP_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5437
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5438
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5439
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5440
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5441
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5442
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5443
	case RTL_GIGA_MAC_VER_07:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5444
		rtl_hw_start_8102e_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5445
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5446
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5447
	case RTL_GIGA_MAC_VER_08:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5448
		rtl_hw_start_8102e_3(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5449
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5450
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5451
	case RTL_GIGA_MAC_VER_09:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5452
		rtl_hw_start_8102e_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5453
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5454
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5455
	case RTL_GIGA_MAC_VER_29:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5456
		rtl_hw_start_8105e_1(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5457
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5458
	case RTL_GIGA_MAC_VER_30:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5459
		rtl_hw_start_8105e_2(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5460
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5461
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5462
	case RTL_GIGA_MAC_VER_37:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5463
		rtl_hw_start_8402(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5464
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5465
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5466
	case RTL_GIGA_MAC_VER_39:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5467
		rtl_hw_start_8106(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5468
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5469
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5470
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5471
	RTL_W8(Cfg9346, Cfg9346_Lock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5472
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5473
	RTL_W8(MaxTxPacketSize, TxPacketMax);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5474
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5475
	rtl_set_rx_max_size(ioaddr, rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5476
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5477
	tp->cp_cmd &= ~R810X_CPCMD_QUIRK_MASK;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5478
	RTL_W16(CPlusCmd, tp->cp_cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5479
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5480
	RTL_W16(IntrMitigate, 0x0000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5481
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5482
	rtl_set_rx_tx_desc_registers(tp, ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5483
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5484
	RTL_W8(ChipCmd, CmdTxEnb | CmdRxEnb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5485
	rtl_set_rx_tx_config_registers(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5486
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5487
	RTL_R8(IntrMask);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5488
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5489
	rtl_set_rx_mode(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5490
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5491
	RTL_W16(MultiIntr, RTL_R16(MultiIntr) & 0xf000);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5492
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5493
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5494
static int rtl8169_change_mtu(struct net_device *dev, int new_mtu)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5495
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5496
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5497
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5498
	if (new_mtu < ETH_ZLEN ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5499
	    new_mtu > rtl_chip_infos[tp->mac_version].jumbo_max)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5500
		return -EINVAL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5501
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5502
	if (new_mtu > ETH_DATA_LEN)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5503
		rtl_hw_jumbo_enable(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5504
	else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5505
		rtl_hw_jumbo_disable(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5506
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5507
	dev->mtu = new_mtu;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5508
	netdev_update_features(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5509
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5510
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5511
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5512
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5513
static inline void rtl8169_make_unusable_by_asic(struct RxDesc *desc)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5514
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5515
	desc->addr = cpu_to_le64(0x0badbadbadbadbadull);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5516
	desc->opts1 &= ~cpu_to_le32(DescOwn | RsvdMask);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5517
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5518
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5519
static void rtl8169_free_rx_databuff(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5520
				     void **data_buff, struct RxDesc *desc)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5521
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5522
	dma_unmap_single(&tp->pci_dev->dev, le64_to_cpu(desc->addr), rx_buf_sz,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5523
			 DMA_FROM_DEVICE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5524
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5525
	kfree(*data_buff);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5526
	*data_buff = NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5527
	rtl8169_make_unusable_by_asic(desc);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5528
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5529
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5530
static inline void rtl8169_mark_to_asic(struct RxDesc *desc, u32 rx_buf_sz)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5531
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5532
	u32 eor = le32_to_cpu(desc->opts1) & RingEnd;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5533
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5534
	desc->opts1 = cpu_to_le32(DescOwn | eor | rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5535
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5536
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5537
static inline void rtl8169_map_to_asic(struct RxDesc *desc, dma_addr_t mapping,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5538
				       u32 rx_buf_sz)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5539
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5540
	desc->addr = cpu_to_le64(mapping);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5541
	wmb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5542
	rtl8169_mark_to_asic(desc, rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5543
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5544
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5545
static inline void *rtl8169_align(void *data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5546
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5547
	return (void *)ALIGN((long)data, 16);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5548
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5549
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5550
static struct sk_buff *rtl8169_alloc_rx_data(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5551
					     struct RxDesc *desc)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5552
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5553
	void *data;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5554
	dma_addr_t mapping;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5555
	struct device *d = &tp->pci_dev->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5556
	struct net_device *dev = tp->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5557
	int node = dev->dev.parent ? dev_to_node(dev->dev.parent) : -1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5558
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5559
	data = kmalloc_node(rx_buf_sz, GFP_KERNEL, node);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5560
	if (!data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5561
		return NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5562
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5563
	if (rtl8169_align(data) != data) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5564
		kfree(data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5565
		data = kmalloc_node(rx_buf_sz + 15, GFP_KERNEL, node);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5566
		if (!data)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5567
			return NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5568
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5569
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5570
	mapping = dma_map_single(d, rtl8169_align(data), rx_buf_sz,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5571
				 DMA_FROM_DEVICE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5572
	if (unlikely(dma_mapping_error(d, mapping))) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5573
		if (net_ratelimit())
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5574
			netif_err(tp, drv, tp->dev, "Failed to map RX DMA!\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5575
		goto err_out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5576
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5577
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5578
	rtl8169_map_to_asic(desc, mapping, rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5579
	return data;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5580
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5581
err_out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5582
	kfree(data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5583
	return NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5584
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5585
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5586
static void rtl8169_rx_clear(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5587
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5588
	unsigned int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5589
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5590
	for (i = 0; i < NUM_RX_DESC; i++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5591
		if (tp->Rx_databuff[i]) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5592
			rtl8169_free_rx_databuff(tp, tp->Rx_databuff + i,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5593
					    tp->RxDescArray + i);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5594
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5595
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5596
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5597
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5598
static inline void rtl8169_mark_as_last_descriptor(struct RxDesc *desc)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5599
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5600
	desc->opts1 |= cpu_to_le32(RingEnd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5601
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5602
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5603
static int rtl8169_rx_fill(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5604
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5605
	unsigned int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5606
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5607
	for (i = 0; i < NUM_RX_DESC; i++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5608
		void *data;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5609
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5610
		if (tp->Rx_databuff[i])
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5611
			continue;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5612
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5613
		data = rtl8169_alloc_rx_data(tp, tp->RxDescArray + i);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5614
		if (!data) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5615
			rtl8169_make_unusable_by_asic(tp->RxDescArray + i);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5616
			goto err_out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5617
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5618
		tp->Rx_databuff[i] = data;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5619
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5620
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5621
	rtl8169_mark_as_last_descriptor(tp->RxDescArray + NUM_RX_DESC - 1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5622
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5623
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5624
err_out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5625
	rtl8169_rx_clear(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5626
	return -ENOMEM;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5627
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5628
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5629
static int rtl8169_init_ring(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5630
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5631
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5632
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5633
	rtl8169_init_ring_indexes(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5634
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5635
	memset(tp->tx_skb, 0x0, NUM_TX_DESC * sizeof(struct ring_info));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5636
	memset(tp->Rx_databuff, 0x0, NUM_RX_DESC * sizeof(void *));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5637
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5638
	return rtl8169_rx_fill(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5639
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5640
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5641
static void rtl8169_unmap_tx_skb(struct device *d, struct ring_info *tx_skb,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5642
				 struct TxDesc *desc)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5643
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5644
	unsigned int len = tx_skb->len;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5645
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5646
	dma_unmap_single(d, le64_to_cpu(desc->addr), len, DMA_TO_DEVICE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5647
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5648
	desc->opts1 = 0x00;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5649
	desc->opts2 = 0x00;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5650
	desc->addr = 0x00;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5651
	tx_skb->len = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5652
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5653
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5654
static void rtl8169_tx_clear_range(struct rtl8169_private *tp, u32 start,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5655
				   unsigned int n)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5656
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5657
	unsigned int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5658
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5659
	for (i = 0; i < n; i++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5660
		unsigned int entry = (start + i) % NUM_TX_DESC;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5661
		struct ring_info *tx_skb = tp->tx_skb + entry;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5662
		unsigned int len = tx_skb->len;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5663
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5664
		if (len) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5665
			struct sk_buff *skb = tx_skb->skb;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5666
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5667
			rtl8169_unmap_tx_skb(&tp->pci_dev->dev, tx_skb,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5668
					     tp->TxDescArray + entry);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5669
			if (skb) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5670
				tp->dev->stats.tx_dropped++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5671
				if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5672
					dev_kfree_skb(skb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5673
				}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5674
				tx_skb->skb = NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5675
			}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5676
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5677
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5678
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5679
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5680
static void rtl8169_tx_clear(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5681
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5682
	rtl8169_tx_clear_range(tp, tp->dirty_tx, NUM_TX_DESC);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5683
	tp->cur_tx = tp->dirty_tx = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5684
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5685
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5686
static void rtl_reset_work(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5687
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5688
	struct net_device *dev = tp->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5689
	int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5690
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5691
	napi_disable(&tp->napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5692
	netif_stop_queue(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5693
	synchronize_sched();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5694
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5695
	rtl8169_hw_reset(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5696
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5697
	for (i = 0; i < NUM_RX_DESC; i++)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5698
		rtl8169_mark_to_asic(tp->RxDescArray + i, rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5699
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5700
	rtl8169_tx_clear(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5701
	rtl8169_init_ring_indexes(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5702
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5703
	napi_enable(&tp->napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5704
	rtl_hw_start(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5705
	netif_wake_queue(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5706
	rtl8169_check_link_status(dev, tp, tp->mmio_addr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5707
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5708
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5709
static void rtl8169_tx_timeout(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5710
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5711
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5712
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5713
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5714
		rtl_schedule_task(tp, RTL_FLAG_TASK_RESET_PENDING);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5715
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5716
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5717
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5718
static int rtl8169_xmit_frags(struct rtl8169_private *tp, struct sk_buff *skb,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5719
			      u32 *opts)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5720
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5721
	struct skb_shared_info *info = skb_shinfo(skb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5722
	unsigned int cur_frag, entry;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5723
	struct TxDesc * uninitialized_var(txd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5724
	struct device *d = &tp->pci_dev->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5725
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5726
	entry = tp->cur_tx;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5727
	for (cur_frag = 0; cur_frag < info->nr_frags; cur_frag++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5728
		const skb_frag_t *frag = info->frags + cur_frag;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5729
		dma_addr_t mapping;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5730
		u32 status, len;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5731
		void *addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5732
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5733
		entry = (entry + 1) % NUM_TX_DESC;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5734
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5735
		txd = tp->TxDescArray + entry;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5736
		len = skb_frag_size(frag);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5737
		addr = skb_frag_address(frag);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5738
		mapping = dma_map_single(d, addr, len, DMA_TO_DEVICE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5739
		if (unlikely(dma_mapping_error(d, mapping))) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5740
			if (net_ratelimit())
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5741
				netif_err(tp, drv, tp->dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5742
					  "Failed to map TX fragments DMA!\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5743
			goto err_out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5744
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5745
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5746
		/* Anti gcc 2.95.3 bugware (sic) */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5747
		status = opts[0] | len |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5748
			(RingEnd * !((entry + 1) % NUM_TX_DESC));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5749
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5750
		txd->opts1 = cpu_to_le32(status);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5751
		txd->opts2 = cpu_to_le32(opts[1]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5752
		txd->addr = cpu_to_le64(mapping);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5753
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5754
		tp->tx_skb[entry].len = len;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5755
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5756
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5757
	if (cur_frag) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5758
		tp->tx_skb[entry].skb = skb;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5759
		txd->opts1 |= cpu_to_le32(LastFrag);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5760
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5761
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5762
	return cur_frag;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5763
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5764
err_out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5765
	rtl8169_tx_clear_range(tp, tp->cur_tx + 1, cur_frag);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5766
	return -EIO;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5767
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5768
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5769
static inline void rtl8169_tso_csum(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5770
				    struct sk_buff *skb, u32 *opts)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5771
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5772
	const struct rtl_tx_desc_info *info = tx_desc_info + tp->txd_version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5773
	u32 mss = skb_shinfo(skb)->gso_size;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5774
	int offset = info->opts_offset;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5775
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5776
	if (mss) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5777
		opts[0] |= TD_LSO;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5778
		opts[offset] |= min(mss, TD_MSS_MAX) << info->mss_shift;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5779
	} else if (skb->ip_summed == CHECKSUM_PARTIAL) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5780
		const struct iphdr *ip = ip_hdr(skb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5781
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5782
		if (ip->protocol == IPPROTO_TCP)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5783
			opts[offset] |= info->checksum.tcp;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5784
		else if (ip->protocol == IPPROTO_UDP)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5785
			opts[offset] |= info->checksum.udp;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5786
		else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5787
			WARN_ON_ONCE(1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5788
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5789
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5790
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5791
static netdev_tx_t rtl8169_start_xmit(struct sk_buff *skb,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5792
				      struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5793
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5794
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5795
	unsigned int entry = tp->cur_tx % NUM_TX_DESC;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5796
	struct TxDesc *txd = tp->TxDescArray + entry;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5797
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5798
	struct device *d = &tp->pci_dev->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5799
	dma_addr_t mapping;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5800
	u32 status, len;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5801
	u32 opts[2];
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5802
	int frags;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5803
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5804
	if (unlikely(!TX_FRAGS_READY_FOR(tp, skb_shinfo(skb)->nr_frags))) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5805
		netif_err(tp, drv, dev, "BUG! Tx Ring full when queue awake!\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5806
		goto err_stop_0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5807
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5808
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5809
	if (unlikely(le32_to_cpu(txd->opts1) & DescOwn))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5810
		goto err_stop_0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5811
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5812
	len = skb_headlen(skb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5813
	mapping = dma_map_single(d, skb->data, len, DMA_TO_DEVICE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5814
	if (unlikely(dma_mapping_error(d, mapping))) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5815
		if (net_ratelimit())
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5816
			netif_err(tp, drv, dev, "Failed to map TX DMA!\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5817
		goto err_dma_0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5818
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5819
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5820
	tp->tx_skb[entry].len = len;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5821
	txd->addr = cpu_to_le64(mapping);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5822
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5823
	opts[1] = cpu_to_le32(rtl8169_tx_vlan_tag(tp, skb));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5824
	opts[0] = DescOwn;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5825
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5826
	rtl8169_tso_csum(tp, skb, opts);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5827
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5828
	frags = rtl8169_xmit_frags(tp, skb, opts);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5829
	if (frags < 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5830
		goto err_dma_1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5831
	else if (frags)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5832
		opts[0] |= FirstFrag;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5833
	else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5834
		opts[0] |= FirstFrag | LastFrag;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5835
		tp->tx_skb[entry].skb = skb;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5836
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5837
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5838
	txd->opts2 = cpu_to_le32(opts[1]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5839
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5840
	skb_tx_timestamp(skb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5841
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5842
	wmb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5843
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5844
	/* Anti gcc 2.95.3 bugware (sic) */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5845
	status = opts[0] | len | (RingEnd * !((entry + 1) % NUM_TX_DESC));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5846
	txd->opts1 = cpu_to_le32(status);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5847
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5848
	tp->cur_tx += frags + 1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5849
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5850
	wmb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5851
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5852
	RTL_W8(TxPoll, NPQ);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5853
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5854
	mmiowb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5855
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5856
	if (!TX_FRAGS_READY_FOR(tp, MAX_SKB_FRAGS)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5857
		/* Avoid wrongly optimistic queue wake-up: rtl_tx thread must
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5858
		 * not miss a ring update when it notices a stopped queue.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5859
		 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5860
		smp_wmb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5861
		if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5862
			netif_stop_queue(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5863
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5864
		/* Sync with rtl_tx:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5865
		 * - publish queue status and cur_tx ring index (write barrier)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5866
		 * - refresh dirty_tx ring index (read barrier).
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5867
		 * May the current thread have a pessimistic view of the ring
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5868
		 * status and forget to wake up queue, a racing rtl_tx thread
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5869
		 * can't.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5870
		 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5871
		smp_mb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5872
		if (!tp->ecdev && TX_FRAGS_READY_FOR(tp, MAX_SKB_FRAGS))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5873
			netif_wake_queue(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5874
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5875
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5876
	return NETDEV_TX_OK;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5877
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5878
err_dma_1:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5879
	rtl8169_unmap_tx_skb(d, tp->tx_skb + entry, txd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5880
err_dma_0:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5881
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5882
		dev_kfree_skb(skb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5883
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5884
	dev->stats.tx_dropped++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5885
	return NETDEV_TX_OK;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5886
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5887
err_stop_0:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5888
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5889
		netif_stop_queue(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5890
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5891
	dev->stats.tx_dropped++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5892
	return NETDEV_TX_BUSY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5893
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5894
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5895
static void rtl8169_pcierr_interrupt(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5896
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5897
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5898
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5899
	u16 pci_status, pci_cmd;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5900
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5901
	pci_read_config_word(pdev, PCI_COMMAND, &pci_cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5902
	pci_read_config_word(pdev, PCI_STATUS, &pci_status);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5903
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5904
	netif_err(tp, intr, dev, "PCI error (cmd = 0x%04x, status = 0x%04x)\n",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5905
		  pci_cmd, pci_status);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5906
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5907
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5908
	 * The recovery sequence below admits a very elaborated explanation:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5909
	 * - it seems to work;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5910
	 * - I did not see what else could be done;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5911
	 * - it makes iop3xx happy.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5912
	 *
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5913
	 * Feel free to adjust to your needs.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5914
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5915
	if (pdev->broken_parity_status)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5916
		pci_cmd &= ~PCI_COMMAND_PARITY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5917
	else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5918
		pci_cmd |= PCI_COMMAND_SERR | PCI_COMMAND_PARITY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5919
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5920
	pci_write_config_word(pdev, PCI_COMMAND, pci_cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5921
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5922
	pci_write_config_word(pdev, PCI_STATUS,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5923
		pci_status & (PCI_STATUS_DETECTED_PARITY |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5924
		PCI_STATUS_SIG_SYSTEM_ERROR | PCI_STATUS_REC_MASTER_ABORT |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5925
		PCI_STATUS_REC_TARGET_ABORT | PCI_STATUS_SIG_TARGET_ABORT));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5926
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5927
	/* The infamous DAC f*ckup only happens at boot time */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5928
	if ((tp->cp_cmd & PCIDAC) && !tp->dirty_rx && !tp->cur_rx) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5929
		void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5930
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5931
		netif_info(tp, intr, dev, "disabling PCI DAC\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5932
		tp->cp_cmd &= ~PCIDAC;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5933
		RTL_W16(CPlusCmd, tp->cp_cmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5934
		dev->features &= ~NETIF_F_HIGHDMA;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5935
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5936
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5937
	rtl8169_hw_reset(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5938
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5939
	rtl_schedule_task(tp, RTL_FLAG_TASK_RESET_PENDING);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5940
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5941
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5942
static void rtl_tx(struct net_device *dev, struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5943
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5944
	unsigned int dirty_tx, tx_left;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5945
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5946
	dirty_tx = tp->dirty_tx;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5947
	smp_rmb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5948
	tx_left = tp->cur_tx - dirty_tx;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5949
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5950
	while (tx_left > 0) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5951
		unsigned int entry = dirty_tx % NUM_TX_DESC;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5952
		struct ring_info *tx_skb = tp->tx_skb + entry;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5953
		u32 status;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5954
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5955
		rmb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5956
		status = le32_to_cpu(tp->TxDescArray[entry].opts1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5957
		if (status & DescOwn)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5958
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5959
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5960
		rtl8169_unmap_tx_skb(&tp->pci_dev->dev, tx_skb,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5961
				     tp->TxDescArray + entry);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5962
		if (status & LastFrag) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5963
			u64_stats_update_begin(&tp->tx_stats.syncp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5964
			tp->tx_stats.packets++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5965
			tp->tx_stats.bytes += tx_skb->skb->len;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5966
			u64_stats_update_end(&tp->tx_stats.syncp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5967
			if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5968
				dev_kfree_skb(tx_skb->skb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5969
			}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5970
			tx_skb->skb = NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5971
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5972
		dirty_tx++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5973
		tx_left--;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5974
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5975
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5976
	if (tp->dirty_tx != dirty_tx) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5977
		tp->dirty_tx = dirty_tx;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5978
		/* Sync with rtl8169_start_xmit:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5979
		 * - publish dirty_tx ring index (write barrier)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5980
		 * - refresh cur_tx ring index and queue status (read barrier)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5981
		 * May the current thread miss the stopped queue condition,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5982
		 * a racing xmit thread can only have a right view of the
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5983
		 * ring status.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5984
		 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5985
		smp_mb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5986
		if (!tp->ecdev && netif_queue_stopped(dev) &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5987
		    TX_FRAGS_READY_FOR(tp, MAX_SKB_FRAGS)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5988
			netif_wake_queue(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5989
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5990
		/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5991
		 * 8168 hack: TxPoll requests are lost when the Tx packets are
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5992
		 * too close. Let's kick an extra TxPoll request when a burst
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5993
		 * of start_xmit activity is detected (if it is not detected,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5994
		 * it is slow enough). -- FR
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5995
		 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5996
		if (tp->cur_tx != dirty_tx) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5997
			void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5998
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  5999
			RTL_W8(TxPoll, NPQ);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6000
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6001
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6002
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6003
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6004
static inline int rtl8169_fragmented_frame(u32 status)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6005
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6006
	return (status & (FirstFrag | LastFrag)) != (FirstFrag | LastFrag);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6007
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6008
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6009
static inline void rtl8169_rx_csum(struct sk_buff *skb, u32 opts1)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6010
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6011
	u32 status = opts1 & RxProtoMask;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6012
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6013
	if (((status == RxProtoTCP) && !(opts1 & TCPFail)) ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6014
	    ((status == RxProtoUDP) && !(opts1 & UDPFail)))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6015
		skb->ip_summed = CHECKSUM_UNNECESSARY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6016
	else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6017
		skb_checksum_none_assert(skb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6018
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6019
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6020
static struct sk_buff *rtl8169_try_rx_copy(void *data,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6021
					   struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6022
					   int pkt_size,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6023
					   dma_addr_t addr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6024
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6025
	struct sk_buff *skb;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6026
	struct device *d = &tp->pci_dev->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6027
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6028
	data = rtl8169_align(data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6029
	dma_sync_single_for_cpu(d, addr, pkt_size, DMA_FROM_DEVICE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6030
	prefetch(data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6031
	skb = netdev_alloc_skb_ip_align(tp->dev, pkt_size);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6032
	if (skb)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6033
		memcpy(skb->data, data, pkt_size);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6034
	dma_sync_single_for_device(d, addr, pkt_size, DMA_FROM_DEVICE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6035
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6036
	return skb;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6037
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6038
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6039
static int rtl_rx(struct net_device *dev, struct rtl8169_private *tp, u32 budget)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6040
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6041
	unsigned int cur_rx, rx_left;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6042
	unsigned int count;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6043
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6044
	cur_rx = tp->cur_rx;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6045
	rx_left = NUM_RX_DESC + tp->dirty_rx - cur_rx;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6046
	rx_left = min(rx_left, budget);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6047
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6048
	for (; rx_left > 0; rx_left--, cur_rx++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6049
		unsigned int entry = cur_rx % NUM_RX_DESC;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6050
		struct RxDesc *desc = tp->RxDescArray + entry;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6051
		u32 status;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6052
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6053
		rmb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6054
		status = le32_to_cpu(desc->opts1) & tp->opts1_mask;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6055
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6056
		if (status & DescOwn)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6057
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6058
		if (unlikely(status & RxRES)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6059
			netif_info(tp, rx_err, dev, "Rx ERROR. status = %08x\n",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6060
				   status);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6061
			dev->stats.rx_errors++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6062
			if (status & (RxRWT | RxRUNT))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6063
				dev->stats.rx_length_errors++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6064
			if (status & RxCRC)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6065
				dev->stats.rx_crc_errors++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6066
			if (status & RxFOVF) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6067
				if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6068
					rtl_schedule_task(tp, RTL_FLAG_TASK_RESET_PENDING);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6069
				}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6070
				dev->stats.rx_fifo_errors++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6071
			}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6072
			if ((status & (RxRUNT | RxCRC)) &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6073
			    !(status & (RxRWT | RxFOVF)) &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6074
			    (dev->features & NETIF_F_RXALL))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6075
				goto process_pkt;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6076
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6077
			rtl8169_mark_to_asic(desc, rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6078
		} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6079
			struct sk_buff *skb;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6080
			dma_addr_t addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6081
			int pkt_size;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6082
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6083
process_pkt:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6084
			addr = le64_to_cpu(desc->addr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6085
			if (likely(!(dev->features & NETIF_F_RXFCS)))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6086
				pkt_size = (status & 0x00003fff) - 4;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6087
			else
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6088
				pkt_size = status & 0x00003fff;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6089
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6090
			/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6091
			 * The driver does not support incoming fragmented
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6092
			 * frames. They are seen as a symptom of over-mtu
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6093
			 * sized frames.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6094
			 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6095
			if (unlikely(rtl8169_fragmented_frame(status))) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6096
				dev->stats.rx_dropped++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6097
				dev->stats.rx_length_errors++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6098
				rtl8169_mark_to_asic(desc, rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6099
				continue;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6100
			}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6101
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6102
			if (tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6103
				struct device *d = &tp->pci_dev->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6104
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6105
				/* reusing parts of rtl8169_try_rx_copy() */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6106
				tp->Rx_databuff[entry] = rtl8169_align(tp->Rx_databuff[entry]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6107
				dma_sync_single_for_cpu(d, addr, pkt_size, DMA_FROM_DEVICE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6108
				prefetch(tp->Rx_databuff[entry]);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6109
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6110
				ecdev_receive(tp->ecdev, tp->Rx_databuff[entry], pkt_size);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6111
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6112
				dma_sync_single_for_device(d, addr, pkt_size, DMA_FROM_DEVICE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6113
				rtl8169_mark_to_asic(desc, rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6114
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6115
				rtl8169_rx_csum(tp->Rx_databuff[entry], status);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6116
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6117
				// No need to detect link status as
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6118
				// long as frames are received: Reset watchdog.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6119
				tp->ec_watchdog_jiffies = jiffies;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6120
			}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6121
			else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6122
				skb = rtl8169_try_rx_copy(tp->Rx_databuff[entry],
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6123
							  tp, pkt_size, addr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6124
				rtl8169_mark_to_asic(desc, rx_buf_sz);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6125
				if (!skb) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6126
					dev->stats.rx_dropped++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6127
					continue;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6128
				}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6129
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6130
				rtl8169_rx_csum(skb, status);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6131
				skb_put(skb, pkt_size);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6132
				skb->protocol = eth_type_trans(skb, dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6133
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6134
				rtl8169_rx_vlan_tag(desc, skb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6135
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6136
				napi_gro_receive(&tp->napi, skb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6137
			}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6138
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6139
			u64_stats_update_begin(&tp->rx_stats.syncp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6140
			tp->rx_stats.packets++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6141
			tp->rx_stats.bytes += pkt_size;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6142
			u64_stats_update_end(&tp->rx_stats.syncp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6143
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6144
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6145
		/* Work around for AMD plateform. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6146
		if ((desc->opts2 & cpu_to_le32(0xfffe000)) &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6147
		    (tp->mac_version == RTL_GIGA_MAC_VER_05)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6148
			desc->opts2 = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6149
			cur_rx++;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6150
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6151
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6152
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6153
	count = cur_rx - tp->cur_rx;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6154
	tp->cur_rx = cur_rx;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6155
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6156
	tp->dirty_rx += count;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6157
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6158
	return count;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6159
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6160
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6161
static irqreturn_t rtl8169_interrupt(int irq, void *dev_instance)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6162
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6163
	struct net_device *dev = dev_instance;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6164
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6165
	int handled = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6166
	u16 status;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6167
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6168
	status = rtl_get_events(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6169
	if (status && status != 0xffff) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6170
		status &= RTL_EVENT_NAPI | tp->event_slow;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6171
		if (status) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6172
			handled = 1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6173
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6174
			rtl_irq_disable(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6175
			napi_schedule(&tp->napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6176
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6177
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6178
	return IRQ_RETVAL(handled);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6179
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6180
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6181
/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6182
 * Workqueue context.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6183
 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6184
static void rtl_slow_event_work(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6185
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6186
	struct net_device *dev = tp->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6187
	u16 status;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6188
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6189
	status = rtl_get_events(tp) & tp->event_slow;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6190
	rtl_ack_events(tp, status);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6191
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6192
	if (unlikely(!tp->ecdev && (status & RxFIFOOver))) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6193
		switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6194
		/* Work around for rx fifo overflow */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6195
		case RTL_GIGA_MAC_VER_11:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6196
			netif_stop_queue(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6197
			/* XXX - Hack alert. See rtl_task(). */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6198
			set_bit(RTL_FLAG_TASK_RESET_PENDING, tp->wk.flags);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6199
		default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6200
			break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6201
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6202
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6203
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6204
	if (unlikely(!tp->ecdev && (status & SYSErr)))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6205
		rtl8169_pcierr_interrupt(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6206
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6207
	if (status & LinkChg)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6208
		__rtl8169_check_link_status(dev, tp, tp->mmio_addr, true);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6209
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6210
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6211
		rtl_irq_enable_all(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6212
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6213
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6214
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6215
static void rtl_task(struct work_struct *work)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6216
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6217
	static const struct {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6218
		int bitnr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6219
		void (*action)(struct rtl8169_private *);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6220
	} rtl_work[] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6221
		/* XXX - keep rtl_slow_event_work() as first element. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6222
		{ RTL_FLAG_TASK_SLOW_PENDING,	rtl_slow_event_work },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6223
		{ RTL_FLAG_TASK_RESET_PENDING,	rtl_reset_work },
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6224
		{ RTL_FLAG_TASK_PHY_PENDING,	rtl_phy_work }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6225
	};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6226
	struct rtl8169_private *tp =
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6227
		container_of(work, struct rtl8169_private, wk.work);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6228
	struct net_device *dev = tp->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6229
	int i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6230
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6231
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6232
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6233
	if (!netif_running(dev) ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6234
	    !test_bit(RTL_FLAG_TASK_ENABLED, tp->wk.flags))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6235
		goto out_unlock;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6236
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6237
	for (i = 0; i < ARRAY_SIZE(rtl_work); i++) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6238
		bool pending;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6239
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6240
		pending = test_and_clear_bit(rtl_work[i].bitnr, tp->wk.flags);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6241
		if (pending)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6242
			rtl_work[i].action(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6243
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6244
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6245
out_unlock:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6246
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6247
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6248
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6249
static void ec_poll(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6250
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6251
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6252
	u16 status;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6253
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6254
	status = rtl_get_events(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6255
	rtl_ack_events(tp, status & ~tp->event_slow);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6256
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6257
	if (status & RTL_EVENT_NAPI_RX) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6258
		rtl_rx(dev, tp, 100); // FIXME
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6259
    }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6260
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6261
	if (status & RTL_EVENT_NAPI_TX) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6262
		rtl_tx(dev, tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6263
    }
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6264
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6265
	if (jiffies - tp->ec_watchdog_jiffies >= 2 * HZ) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6266
		void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6267
		ecdev_set_link(tp->ecdev, tp->link_ok(ioaddr) ? 1 : 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6268
		tp->ec_watchdog_jiffies = jiffies;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6269
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6270
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6271
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6272
static int rtl8169_poll(struct napi_struct *napi, int budget)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6273
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6274
	struct rtl8169_private *tp = container_of(napi, struct rtl8169_private, napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6275
	struct net_device *dev = tp->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6276
	u16 enable_mask = RTL_EVENT_NAPI | tp->event_slow;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6277
	int work_done= 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6278
	u16 status;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6279
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6280
	status = rtl_get_events(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6281
	rtl_ack_events(tp, status & ~tp->event_slow);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6282
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6283
	if (status & RTL_EVENT_NAPI_RX)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6284
		work_done = rtl_rx(dev, tp, (u32) budget);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6285
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6286
	if (status & RTL_EVENT_NAPI_TX)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6287
		rtl_tx(dev, tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6288
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6289
	if (status & tp->event_slow) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6290
		enable_mask &= ~tp->event_slow;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6291
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6292
		rtl_schedule_task(tp, RTL_FLAG_TASK_SLOW_PENDING);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6293
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6294
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6295
	if (work_done < budget) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6296
		napi_complete(napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6297
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6298
		rtl_irq_enable(tp, enable_mask);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6299
		mmiowb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6300
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6301
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6302
	return work_done;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6303
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6304
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6305
static void rtl8169_rx_missed(struct net_device *dev, void __iomem *ioaddr)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6306
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6307
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6308
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6309
	if (tp->mac_version > RTL_GIGA_MAC_VER_06)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6310
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6311
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6312
	dev->stats.rx_missed_errors += (RTL_R32(RxMissed) & 0xffffff);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6313
	RTL_W32(RxMissed, 0);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6314
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6315
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6316
static void rtl8169_down(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6317
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6318
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6319
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6320
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6321
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6322
		del_timer_sync(&tp->timer);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6323
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6324
		napi_disable(&tp->napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6325
		netif_stop_queue(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6326
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6327
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6328
	rtl8169_hw_reset(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6329
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6330
	 * At this point device interrupts can not be enabled in any function,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6331
	 * as netif_running is not true (rtl8169_interrupt, rtl8169_reset_task)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6332
	 * and napi is disabled (rtl8169_poll).
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6333
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6334
	rtl8169_rx_missed(dev, ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6335
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6336
	/* Give a racing hard_start_xmit a few cycles to complete. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6337
	synchronize_sched();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6338
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6339
	rtl8169_tx_clear(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6340
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6341
	rtl8169_rx_clear(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6342
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6343
	rtl_pll_power_down(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6344
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6345
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6346
static int rtl8169_close(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6347
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6348
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6349
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6350
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6351
	pm_runtime_get_sync(&pdev->dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6352
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6353
	/* Update counters before going down */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6354
	rtl8169_update_counters(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6355
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6356
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6357
	clear_bit(RTL_FLAG_TASK_ENABLED, tp->wk.flags);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6358
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6359
	rtl8169_down(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6360
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6361
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6362
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6363
		free_irq(pdev->irq, dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6364
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6365
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6366
	dma_free_coherent(&pdev->dev, R8169_RX_RING_BYTES, tp->RxDescArray,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6367
			  tp->RxPhyAddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6368
	dma_free_coherent(&pdev->dev, R8169_TX_RING_BYTES, tp->TxDescArray,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6369
			  tp->TxPhyAddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6370
	tp->TxDescArray = NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6371
	tp->RxDescArray = NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6372
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6373
	pm_runtime_put_sync(&pdev->dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6374
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6375
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6376
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6377
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6378
#ifdef CONFIG_NET_POLL_CONTROLLER
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6379
static void rtl8169_netpoll(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6380
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6381
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6382
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6383
	rtl8169_interrupt(tp->pci_dev->irq, dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6384
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6385
#endif
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6386
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6387
static int rtl_open(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6388
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6389
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6390
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6391
	struct pci_dev *pdev = tp->pci_dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6392
	int retval = -ENOMEM;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6393
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6394
	pm_runtime_get_sync(&pdev->dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6395
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6396
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6397
	 * Rx and Tx descriptors needs 256 bytes alignment.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6398
	 * dma_alloc_coherent provides more.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6399
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6400
	tp->TxDescArray = dma_alloc_coherent(&pdev->dev, R8169_TX_RING_BYTES,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6401
					     &tp->TxPhyAddr, GFP_KERNEL);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6402
	if (!tp->TxDescArray)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6403
		goto err_pm_runtime_put;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6404
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6405
	tp->RxDescArray = dma_alloc_coherent(&pdev->dev, R8169_RX_RING_BYTES,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6406
					     &tp->RxPhyAddr, GFP_KERNEL);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6407
	if (!tp->RxDescArray)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6408
		goto err_free_tx_0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6409
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6410
	retval = rtl8169_init_ring(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6411
	if (retval < 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6412
		goto err_free_rx_1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6413
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6414
	INIT_WORK(&tp->wk.work, rtl_task);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6415
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6416
	smp_mb();
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6417
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6418
	rtl_request_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6419
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6420
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6421
		retval = request_irq(pdev->irq, rtl8169_interrupt,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6422
				(tp->features & RTL_FEATURE_MSI) ? 0 : IRQF_SHARED,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6423
				dev->name, dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6424
		if (retval < 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6425
			goto err_release_fw_2;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6426
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6427
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6428
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6429
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6430
	set_bit(RTL_FLAG_TASK_ENABLED, tp->wk.flags);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6431
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6432
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6433
		napi_enable(&tp->napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6434
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6435
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6436
	rtl8169_init_phy(dev, tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6437
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6438
	__rtl8169_set_features(dev, dev->features);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6439
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6440
	rtl_pll_power_up(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6441
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6442
	rtl_hw_start(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6443
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6444
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6445
		netif_start_queue(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6446
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6447
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6448
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6449
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6450
	tp->saved_wolopts = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6451
	pm_runtime_put_noidle(&pdev->dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6452
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6453
	rtl8169_check_link_status(dev, tp, ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6454
out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6455
	return retval;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6456
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6457
err_release_fw_2:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6458
	rtl_release_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6459
	rtl8169_rx_clear(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6460
err_free_rx_1:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6461
	dma_free_coherent(&pdev->dev, R8169_RX_RING_BYTES, tp->RxDescArray,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6462
			  tp->RxPhyAddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6463
	tp->RxDescArray = NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6464
err_free_tx_0:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6465
	dma_free_coherent(&pdev->dev, R8169_TX_RING_BYTES, tp->TxDescArray,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6466
			  tp->TxPhyAddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6467
	tp->TxDescArray = NULL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6468
err_pm_runtime_put:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6469
	pm_runtime_put_noidle(&pdev->dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6470
	goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6471
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6472
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6473
static struct rtnl_link_stats64 *
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6474
rtl8169_get_stats64(struct net_device *dev, struct rtnl_link_stats64 *stats)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6475
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6476
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6477
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6478
	unsigned int start;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6479
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6480
	if (netif_running(dev))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6481
		rtl8169_rx_missed(dev, ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6482
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6483
	do {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6484
		start = u64_stats_fetch_begin_bh(&tp->rx_stats.syncp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6485
		stats->rx_packets = tp->rx_stats.packets;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6486
		stats->rx_bytes	= tp->rx_stats.bytes;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6487
	} while (u64_stats_fetch_retry_bh(&tp->rx_stats.syncp, start));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6488
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6489
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6490
	do {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6491
		start = u64_stats_fetch_begin_bh(&tp->tx_stats.syncp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6492
		stats->tx_packets = tp->tx_stats.packets;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6493
		stats->tx_bytes	= tp->tx_stats.bytes;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6494
	} while (u64_stats_fetch_retry_bh(&tp->tx_stats.syncp, start));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6495
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6496
	stats->rx_dropped	= dev->stats.rx_dropped;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6497
	stats->tx_dropped	= dev->stats.tx_dropped;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6498
	stats->rx_length_errors = dev->stats.rx_length_errors;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6499
	stats->rx_errors	= dev->stats.rx_errors;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6500
	stats->rx_crc_errors	= dev->stats.rx_crc_errors;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6501
	stats->rx_fifo_errors	= dev->stats.rx_fifo_errors;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6502
	stats->rx_missed_errors = dev->stats.rx_missed_errors;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6503
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6504
	return stats;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6505
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6506
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6507
static void rtl8169_net_suspend(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6508
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6509
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6510
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6511
	if (!netif_running(dev))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6512
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6513
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6514
	netif_device_detach(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6515
	netif_stop_queue(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6516
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6517
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6518
	napi_disable(&tp->napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6519
	clear_bit(RTL_FLAG_TASK_ENABLED, tp->wk.flags);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6520
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6521
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6522
	rtl_pll_power_down(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6523
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6524
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6525
#ifdef CONFIG_PM
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6526
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6527
static int rtl8169_suspend(struct device *device)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6528
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6529
	struct pci_dev *pdev = to_pci_dev(device);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6530
	struct net_device *dev = pci_get_drvdata(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6531
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6532
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6533
	if (tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6534
		return -EBUSY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6535
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6536
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6537
	rtl8169_net_suspend(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6538
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6539
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6540
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6541
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6542
static void __rtl8169_resume(struct net_device *dev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6543
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6544
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6545
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6546
	netif_device_attach(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6547
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6548
	rtl_pll_power_up(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6549
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6550
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6551
	napi_enable(&tp->napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6552
	set_bit(RTL_FLAG_TASK_ENABLED, tp->wk.flags);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6553
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6554
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6555
	rtl_schedule_task(tp, RTL_FLAG_TASK_RESET_PENDING);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6556
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6557
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6558
static int rtl8169_resume(struct device *device)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6559
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6560
	struct pci_dev *pdev = to_pci_dev(device);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6561
	struct net_device *dev = pci_get_drvdata(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6562
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6563
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6564
	if (tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6565
		return -EBUSY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6566
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6567
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6568
	rtl8169_init_phy(dev, tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6569
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6570
	if (netif_running(dev))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6571
		__rtl8169_resume(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6572
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6573
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6574
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6575
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6576
static int rtl8169_runtime_suspend(struct device *device)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6577
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6578
	struct pci_dev *pdev = to_pci_dev(device);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6579
	struct net_device *dev = pci_get_drvdata(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6580
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6581
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6582
	if (tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6583
		return -EBUSY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6584
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6585
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6586
	if (!tp->TxDescArray)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6587
		return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6588
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6589
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6590
	tp->saved_wolopts = __rtl8169_get_wol(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6591
	__rtl8169_set_wol(tp, WAKE_ANY);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6592
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6593
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6594
	rtl8169_net_suspend(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6595
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6596
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6597
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6598
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6599
static int rtl8169_runtime_resume(struct device *device)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6600
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6601
	struct pci_dev *pdev = to_pci_dev(device);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6602
	struct net_device *dev = pci_get_drvdata(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6603
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6604
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6605
	if (tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6606
		return -EBUSY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6607
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6608
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6609
	if (!tp->TxDescArray)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6610
		return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6611
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6612
	rtl_lock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6613
	__rtl8169_set_wol(tp, tp->saved_wolopts);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6614
	tp->saved_wolopts = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6615
	rtl_unlock_work(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6616
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6617
	rtl8169_init_phy(dev, tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6618
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6619
	__rtl8169_resume(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6620
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6621
	return 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6622
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6623
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6624
static int rtl8169_runtime_idle(struct device *device)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6625
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6626
	struct pci_dev *pdev = to_pci_dev(device);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6627
	struct net_device *dev = pci_get_drvdata(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6628
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6629
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6630
	return tp->TxDescArray ? -EBUSY : 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6631
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6632
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6633
static const struct dev_pm_ops rtl8169_pm_ops = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6634
	.suspend		= rtl8169_suspend,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6635
	.resume			= rtl8169_resume,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6636
	.freeze			= rtl8169_suspend,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6637
	.thaw			= rtl8169_resume,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6638
	.poweroff		= rtl8169_suspend,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6639
	.restore		= rtl8169_resume,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6640
	.runtime_suspend	= rtl8169_runtime_suspend,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6641
	.runtime_resume		= rtl8169_runtime_resume,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6642
	.runtime_idle		= rtl8169_runtime_idle,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6643
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6644
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6645
#define RTL8169_PM_OPS	(&rtl8169_pm_ops)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6646
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6647
#else /* !CONFIG_PM */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6648
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6649
#define RTL8169_PM_OPS	NULL
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6650
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6651
#endif /* !CONFIG_PM */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6652
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6653
static void rtl_wol_shutdown_quirk(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6654
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6655
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6656
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6657
	/* WoL fails with 8168b when the receiver is disabled. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6658
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6659
	case RTL_GIGA_MAC_VER_11:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6660
	case RTL_GIGA_MAC_VER_12:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6661
	case RTL_GIGA_MAC_VER_17:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6662
		pci_clear_master(tp->pci_dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6663
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6664
		RTL_W8(ChipCmd, CmdRxEnb);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6665
		/* PCI commit */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6666
		RTL_R8(ChipCmd);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6667
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6668
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6669
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6670
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6671
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6672
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6673
static void rtl_shutdown(struct pci_dev *pdev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6674
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6675
	struct net_device *dev = pci_get_drvdata(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6676
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6677
	struct device *d = &pdev->dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6678
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6679
	pm_runtime_get_sync(d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6680
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6681
	rtl8169_net_suspend(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6682
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6683
	/* Restore original MAC address */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6684
	rtl_rar_set(tp, dev->perm_addr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6685
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6686
	rtl8169_hw_reset(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6687
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6688
	if (system_state == SYSTEM_POWER_OFF) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6689
		if (__rtl8169_get_wol(tp) & WAKE_ANY) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6690
			rtl_wol_suspend_quirk(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6691
			rtl_wol_shutdown_quirk(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6692
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6693
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6694
		pci_wake_from_d3(pdev, true);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6695
		pci_set_power_state(pdev, PCI_D3hot);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6696
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6697
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6698
	pm_runtime_put_noidle(d);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6699
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6700
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6701
static void __devexit rtl_remove_one(struct pci_dev *pdev)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6702
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6703
	struct net_device *dev = pci_get_drvdata(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6704
	struct rtl8169_private *tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6705
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6706
	if (tp->mac_version == RTL_GIGA_MAC_VER_27 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6707
	    tp->mac_version == RTL_GIGA_MAC_VER_28 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6708
	    tp->mac_version == RTL_GIGA_MAC_VER_31) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6709
		rtl8168_driver_stop(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6710
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6711
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6712
	cancel_work_sync(&tp->wk.work);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6713
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6714
	if (tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6715
		ecdev_close(tp->ecdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6716
		ecdev_withdraw(tp->ecdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6717
	} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6718
		netif_napi_del(&tp->napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6719
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6720
		unregister_netdev(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6721
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6722
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6723
	rtl_release_firmware(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6724
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6725
	if (pci_dev_run_wake(pdev))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6726
		pm_runtime_get_noresume(&pdev->dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6727
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6728
	/* restore original MAC address */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6729
	rtl_rar_set(tp, dev->perm_addr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6730
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6731
	rtl_disable_msi(pdev, tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6732
	rtl8169_release_board(pdev, dev, tp->mmio_addr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6733
	pci_set_drvdata(pdev, NULL);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6734
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6735
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6736
static const struct net_device_ops rtl_netdev_ops = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6737
	.ndo_open		= rtl_open,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6738
	.ndo_stop		= rtl8169_close,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6739
	.ndo_get_stats64	= rtl8169_get_stats64,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6740
	.ndo_start_xmit		= rtl8169_start_xmit,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6741
	.ndo_tx_timeout		= rtl8169_tx_timeout,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6742
	.ndo_validate_addr	= eth_validate_addr,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6743
	.ndo_change_mtu		= rtl8169_change_mtu,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6744
	.ndo_fix_features	= rtl8169_fix_features,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6745
	.ndo_set_features	= rtl8169_set_features,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6746
	.ndo_set_mac_address	= rtl_set_mac_address,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6747
	.ndo_do_ioctl		= rtl8169_ioctl,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6748
	.ndo_set_rx_mode	= rtl_set_rx_mode,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6749
#ifdef CONFIG_NET_POLL_CONTROLLER
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6750
	.ndo_poll_controller	= rtl8169_netpoll,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6751
#endif
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6752
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6753
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6754
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6755
static const struct rtl_cfg_info {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6756
	void (*hw_start)(struct net_device *);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6757
	unsigned int region;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6758
	unsigned int align;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6759
	u16 event_slow;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6760
	unsigned features;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6761
	u8 default_ver;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6762
} rtl_cfg_infos [] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6763
	[RTL_CFG_0] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6764
		.hw_start	= rtl_hw_start_8169,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6765
		.region		= 1,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6766
		.align		= 0,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6767
		.event_slow	= SYSErr | LinkChg | RxOverflow | RxFIFOOver,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6768
		.features	= RTL_FEATURE_GMII,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6769
		.default_ver	= RTL_GIGA_MAC_VER_01,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6770
	},
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6771
	[RTL_CFG_1] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6772
		.hw_start	= rtl_hw_start_8168,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6773
		.region		= 2,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6774
		.align		= 8,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6775
		.event_slow	= SYSErr | LinkChg | RxOverflow,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6776
		.features	= RTL_FEATURE_GMII | RTL_FEATURE_MSI,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6777
		.default_ver	= RTL_GIGA_MAC_VER_11,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6778
	},
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6779
	[RTL_CFG_2] = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6780
		.hw_start	= rtl_hw_start_8101,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6781
		.region		= 2,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6782
		.align		= 8,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6783
		.event_slow	= SYSErr | LinkChg | RxOverflow | RxFIFOOver |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6784
				  PCSTimeout,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6785
		.features	= RTL_FEATURE_MSI,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6786
		.default_ver	= RTL_GIGA_MAC_VER_13,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6787
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6788
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6789
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6790
/* Cfg9346_Unlock assumed. */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6791
static unsigned rtl_try_msi(struct rtl8169_private *tp,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6792
			    const struct rtl_cfg_info *cfg)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6793
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6794
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6795
	unsigned msi = 0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6796
	u8 cfg2;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6797
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6798
	cfg2 = RTL_R8(Config2) & ~MSIEnable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6799
	if (cfg->features & RTL_FEATURE_MSI) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6800
		if (pci_enable_msi(tp->pci_dev)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6801
			netif_info(tp, hw, tp->dev, "no MSI. Back to INTx.\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6802
		} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6803
			cfg2 |= MSIEnable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6804
			msi = RTL_FEATURE_MSI;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6805
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6806
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6807
	if (tp->mac_version <= RTL_GIGA_MAC_VER_06)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6808
		RTL_W8(Config2, cfg2);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6809
	return msi;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6810
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6811
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6812
DECLARE_RTL_COND(rtl_link_list_ready_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6813
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6814
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6815
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6816
	return RTL_R8(MCU) & LINK_LIST_RDY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6817
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6818
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6819
DECLARE_RTL_COND(rtl_rxtx_empty_cond)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6820
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6821
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6822
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6823
	return (RTL_R8(MCU) & RXTX_EMPTY) == RXTX_EMPTY;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6824
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6825
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6826
static void __devinit rtl_hw_init_8168g(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6827
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6828
	void __iomem *ioaddr = tp->mmio_addr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6829
	u32 data;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6830
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6831
	tp->ocp_base = OCP_STD_PHY_BASE;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6832
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6833
	RTL_W32(MISC, RTL_R32(MISC) | RXDV_GATED_EN);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6834
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6835
	if (!rtl_udelay_loop_wait_high(tp, &rtl_txcfg_empty_cond, 100, 42))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6836
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6837
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6838
	if (!rtl_udelay_loop_wait_high(tp, &rtl_rxtx_empty_cond, 100, 42))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6839
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6840
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6841
	RTL_W8(ChipCmd, RTL_R8(ChipCmd) & ~(CmdTxEnb | CmdRxEnb));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6842
	msleep(1);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6843
	RTL_W8(MCU, RTL_R8(MCU) & ~NOW_IS_OOB);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6844
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6845
	data = r8168_mac_ocp_read(tp, 0xe8de);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6846
	data &= ~(1 << 14);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6847
	r8168_mac_ocp_write(tp, 0xe8de, data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6848
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6849
	if (!rtl_udelay_loop_wait_high(tp, &rtl_link_list_ready_cond, 100, 42))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6850
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6851
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6852
	data = r8168_mac_ocp_read(tp, 0xe8de);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6853
	data |= (1 << 15);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6854
	r8168_mac_ocp_write(tp, 0xe8de, data);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6855
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6856
	if (!rtl_udelay_loop_wait_high(tp, &rtl_link_list_ready_cond, 100, 42))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6857
		return;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6858
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6859
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6860
static void __devinit rtl_hw_initialize(struct rtl8169_private *tp)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6861
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6862
	switch (tp->mac_version) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6863
	case RTL_GIGA_MAC_VER_40:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6864
	case RTL_GIGA_MAC_VER_41:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6865
		rtl_hw_init_8168g(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6866
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6867
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6868
	default:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6869
		break;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6870
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6871
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6872
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6873
static int __devinit
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6874
rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6875
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6876
	const struct rtl_cfg_info *cfg = rtl_cfg_infos + ent->driver_data;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6877
	const unsigned int region = cfg->region;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6878
	struct rtl8169_private *tp;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6879
	struct mii_if_info *mii;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6880
	struct net_device *dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6881
	void __iomem *ioaddr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6882
	int chipset, i;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6883
	int rc;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6884
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6885
	if (netif_msg_drv(&debug)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6886
		printk(KERN_INFO "%s Gigabit Ethernet driver %s loaded\n",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6887
		       MODULENAME, RTL8169_VERSION);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6888
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6889
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6890
	dev = alloc_etherdev(sizeof (*tp));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6891
	if (!dev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6892
		rc = -ENOMEM;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6893
		goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6894
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6895
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6896
	SET_NETDEV_DEV(dev, &pdev->dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6897
	dev->netdev_ops = &rtl_netdev_ops;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6898
	tp = netdev_priv(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6899
	tp->dev = dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6900
	tp->pci_dev = pdev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6901
	tp->msg_enable = netif_msg_init(debug.msg_enable, R8169_MSG_DEFAULT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6902
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6903
	mii = &tp->mii;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6904
	mii->dev = dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6905
	mii->mdio_read = rtl_mdio_read;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6906
	mii->mdio_write = rtl_mdio_write;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6907
	mii->phy_id_mask = 0x1f;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6908
	mii->reg_num_mask = 0x1f;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6909
	mii->supports_gmii = !!(cfg->features & RTL_FEATURE_GMII);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6910
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6911
	/* disable ASPM completely as that cause random device stop working
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6912
	 * problems as well as full system hangs for some PCIe devices users */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6913
	pci_disable_link_state(pdev, PCIE_LINK_STATE_L0S | PCIE_LINK_STATE_L1 |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6914
				     PCIE_LINK_STATE_CLKPM);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6915
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6916
	/* enable device (incl. PCI PM wakeup and hotplug setup) */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6917
	rc = pci_enable_device(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6918
	if (rc < 0) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6919
		netif_err(tp, probe, dev, "enable failure\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6920
		goto err_out_free_dev_1;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6921
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6922
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6923
	if (pci_set_mwi(pdev) < 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6924
		netif_info(tp, probe, dev, "Mem-Wr-Inval unavailable\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6925
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6926
	/* make sure PCI base addr 1 is MMIO */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6927
	if (!(pci_resource_flags(pdev, region) & IORESOURCE_MEM)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6928
		netif_err(tp, probe, dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6929
			  "region #%d not an MMIO resource, aborting\n",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6930
			  region);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6931
		rc = -ENODEV;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6932
		goto err_out_mwi_2;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6933
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6934
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6935
	/* check for weird/broken PCI region reporting */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6936
	if (pci_resource_len(pdev, region) < R8169_REGS_SIZE) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6937
		netif_err(tp, probe, dev,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6938
			  "Invalid PCI region size(s), aborting\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6939
		rc = -ENODEV;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6940
		goto err_out_mwi_2;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6941
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6942
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6943
	rc = pci_request_regions(pdev, MODULENAME);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6944
	if (rc < 0) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6945
		netif_err(tp, probe, dev, "could not request regions\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6946
		goto err_out_mwi_2;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6947
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6948
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6949
	tp->cp_cmd = RxChkSum;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6950
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6951
	if ((sizeof(dma_addr_t) > 4) &&
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6952
	    !pci_set_dma_mask(pdev, DMA_BIT_MASK(64)) && use_dac) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6953
		tp->cp_cmd |= PCIDAC;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6954
		dev->features |= NETIF_F_HIGHDMA;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6955
	} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6956
		rc = pci_set_dma_mask(pdev, DMA_BIT_MASK(32));
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6957
		if (rc < 0) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6958
			netif_err(tp, probe, dev, "DMA configuration failed\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6959
			goto err_out_free_res_3;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6960
		}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6961
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6962
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6963
	/* ioremap MMIO region */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6964
	ioaddr = ioremap(pci_resource_start(pdev, region), R8169_REGS_SIZE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6965
	if (!ioaddr) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6966
		netif_err(tp, probe, dev, "cannot remap MMIO, aborting\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6967
		rc = -EIO;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6968
		goto err_out_free_res_3;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6969
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6970
	tp->mmio_addr = ioaddr;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6971
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6972
	if (!pci_is_pcie(pdev))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6973
		netif_info(tp, probe, dev, "not PCI Express\n");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6974
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6975
	/* Identify chip attached to board */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6976
	rtl8169_get_mac_version(tp, dev, cfg->default_ver);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6977
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6978
	rtl_init_rxcfg(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6979
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6980
	rtl_irq_disable(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6981
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6982
	rtl_hw_initialize(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6983
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6984
	rtl_hw_reset(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6985
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6986
	rtl_ack_events(tp, 0xffff);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6987
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6988
	pci_set_master(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6989
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6990
	/*
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6991
	 * Pretend we are using VLANs; This bypasses a nasty bug where
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6992
	 * Interrupts stop flowing on high load on 8110SCd controllers.
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6993
	 */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6994
	if (tp->mac_version == RTL_GIGA_MAC_VER_05)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6995
		tp->cp_cmd |= RxVlan;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6996
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6997
	rtl_init_mdio_ops(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6998
	rtl_init_pll_power_ops(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  6999
	rtl_init_jumbo_ops(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7000
	rtl_init_csi_ops(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7001
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7002
	rtl8169_print_mac_version(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7003
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7004
	chipset = tp->mac_version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7005
	tp->txd_version = rtl_chip_infos[chipset].txd_version;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7006
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7007
	RTL_W8(Cfg9346, Cfg9346_Unlock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7008
	RTL_W8(Config1, RTL_R8(Config1) | PMEnable);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7009
	RTL_W8(Config5, RTL_R8(Config5) & PMEStatus);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7010
	if ((RTL_R8(Config3) & (LinkUp | MagicPacket)) != 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7011
		tp->features |= RTL_FEATURE_WOL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7012
	if ((RTL_R8(Config5) & (UWF | BWF | MWF)) != 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7013
		tp->features |= RTL_FEATURE_WOL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7014
	tp->features |= rtl_try_msi(tp, cfg);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7015
	RTL_W8(Cfg9346, Cfg9346_Lock);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7016
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7017
	if (rtl_tbi_enabled(tp)) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7018
		tp->set_speed = rtl8169_set_speed_tbi;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7019
		tp->get_settings = rtl8169_gset_tbi;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7020
		tp->phy_reset_enable = rtl8169_tbi_reset_enable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7021
		tp->phy_reset_pending = rtl8169_tbi_reset_pending;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7022
		tp->link_ok = rtl8169_tbi_link_ok;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7023
		tp->do_ioctl = rtl_tbi_ioctl;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7024
	} else {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7025
		tp->set_speed = rtl8169_set_speed_xmii;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7026
		tp->get_settings = rtl8169_gset_xmii;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7027
		tp->phy_reset_enable = rtl8169_xmii_reset_enable;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7028
		tp->phy_reset_pending = rtl8169_xmii_reset_pending;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7029
		tp->link_ok = rtl8169_xmii_link_ok;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7030
		tp->do_ioctl = rtl_xmii_ioctl;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7031
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7032
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7033
	mutex_init(&tp->wk.mutex);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7034
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7035
	/* Get MAC address */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7036
	for (i = 0; i < ETH_ALEN; i++)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7037
		dev->dev_addr[i] = RTL_R8(MAC0 + i);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7038
	memcpy(dev->perm_addr, dev->dev_addr, dev->addr_len);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7039
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7040
	SET_ETHTOOL_OPS(dev, &rtl8169_ethtool_ops);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7041
	dev->watchdog_timeo = RTL8169_TX_TIMEOUT;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7042
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7043
	netif_napi_add(dev, &tp->napi, rtl8169_poll, R8169_NAPI_WEIGHT);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7044
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7045
	/* don't enable SG, IP_CSUM and TSO by default - it might not work
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7046
	 * properly for all devices */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7047
	dev->features |= NETIF_F_RXCSUM |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7048
		NETIF_F_HW_VLAN_TX | NETIF_F_HW_VLAN_RX;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7049
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7050
	dev->hw_features = NETIF_F_SG | NETIF_F_IP_CSUM | NETIF_F_TSO |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7051
		NETIF_F_RXCSUM | NETIF_F_HW_VLAN_TX | NETIF_F_HW_VLAN_RX;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7052
	dev->vlan_features = NETIF_F_SG | NETIF_F_IP_CSUM | NETIF_F_TSO |
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7053
		NETIF_F_HIGHDMA;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7054
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7055
	if (tp->mac_version == RTL_GIGA_MAC_VER_05)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7056
		/* 8110SCd requires hardware Rx VLAN - disallow toggling */
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7057
		dev->hw_features &= ~NETIF_F_HW_VLAN_RX;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7058
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7059
	dev->hw_features |= NETIF_F_RXALL;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7060
	dev->hw_features |= NETIF_F_RXFCS;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7061
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7062
	tp->hw_start = cfg->hw_start;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7063
	tp->event_slow = cfg->event_slow;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7064
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7065
	tp->opts1_mask = (tp->mac_version != RTL_GIGA_MAC_VER_01) ?
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7066
		~(RxBOVF | RxFOVF) : ~0;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7067
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7068
	init_timer(&tp->timer);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7069
	tp->timer.data = (unsigned long) dev;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7070
	tp->timer.function = rtl8169_phy_timer;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7071
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7072
	tp->rtl_fw = RTL_FIRMWARE_UNKNOWN;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7073
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7074
	// offer device to EtherCAT master module
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7075
	tp->ecdev = ecdev_offer(dev, ec_poll, THIS_MODULE);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7076
	tp->ec_watchdog_jiffies = jiffies;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7077
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7078
	if (!tp->ecdev) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7079
		rc = register_netdev(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7080
		if (rc < 0)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7081
			goto err_out_msi_4;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7082
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7083
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7084
	pci_set_drvdata(pdev, dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7085
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7086
	netif_info(tp, probe, dev, "%s at 0x%p, %pM, XID %08x IRQ %d\n",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7087
		   rtl_chip_infos[chipset].name, ioaddr, dev->dev_addr,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7088
		   (u32)(RTL_R32(TxConfig) & 0x9cf0f8ff), pdev->irq);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7089
	if (rtl_chip_infos[chipset].jumbo_max != JUMBO_1K) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7090
		netif_info(tp, probe, dev, "jumbo features [frames: %d bytes, "
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7091
			   "tx checksumming: %s]\n",
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7092
			   rtl_chip_infos[chipset].jumbo_max,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7093
			   rtl_chip_infos[chipset].jumbo_tx_csum ? "ok" : "ko");
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7094
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7095
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7096
	if (tp->mac_version == RTL_GIGA_MAC_VER_27 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7097
	    tp->mac_version == RTL_GIGA_MAC_VER_28 ||
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7098
	    tp->mac_version == RTL_GIGA_MAC_VER_31) {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7099
		rtl8168_driver_start(tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7100
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7101
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7102
	device_set_wakeup_enable(&pdev->dev, tp->features & RTL_FEATURE_WOL);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7103
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7104
	if (pci_dev_run_wake(pdev))
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7105
		pm_runtime_put_noidle(&pdev->dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7106
2582
87e502828b3f Use return value of ecdev_open(); thanks to Patrick Bruenn.
Florian Pose <fp@igh-essen.com>
parents: 2547
diff changeset
  7107
	if (tp->ecdev) {
87e502828b3f Use return value of ecdev_open(); thanks to Patrick Bruenn.
Florian Pose <fp@igh-essen.com>
parents: 2547
diff changeset
  7108
		rc = ecdev_open(tp->ecdev);
87e502828b3f Use return value of ecdev_open(); thanks to Patrick Bruenn.
Florian Pose <fp@igh-essen.com>
parents: 2547
diff changeset
  7109
		if (rc) {
87e502828b3f Use return value of ecdev_open(); thanks to Patrick Bruenn.
Florian Pose <fp@igh-essen.com>
parents: 2547
diff changeset
  7110
			ecdev_withdraw(tp->ecdev);
87e502828b3f Use return value of ecdev_open(); thanks to Patrick Bruenn.
Florian Pose <fp@igh-essen.com>
parents: 2547
diff changeset
  7111
			goto err_out_msi_4;
87e502828b3f Use return value of ecdev_open(); thanks to Patrick Bruenn.
Florian Pose <fp@igh-essen.com>
parents: 2547
diff changeset
  7112
		}
87e502828b3f Use return value of ecdev_open(); thanks to Patrick Bruenn.
Florian Pose <fp@igh-essen.com>
parents: 2547
diff changeset
  7113
	}
87e502828b3f Use return value of ecdev_open(); thanks to Patrick Bruenn.
Florian Pose <fp@igh-essen.com>
parents: 2547
diff changeset
  7114
	else {
87e502828b3f Use return value of ecdev_open(); thanks to Patrick Bruenn.
Florian Pose <fp@igh-essen.com>
parents: 2547
diff changeset
  7115
		netif_carrier_off(dev);
2547
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7116
	}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7117
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7118
out:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7119
	return rc;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7120
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7121
err_out_msi_4:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7122
	netif_napi_del(&tp->napi);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7123
	rtl_disable_msi(pdev, tp);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7124
	iounmap(ioaddr);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7125
err_out_free_res_3:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7126
	pci_release_regions(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7127
err_out_mwi_2:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7128
	pci_clear_mwi(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7129
	pci_disable_device(pdev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7130
err_out_free_dev_1:
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7131
	free_netdev(dev);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7132
	goto out;
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7133
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7134
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7135
static struct pci_driver rtl8169_pci_driver = {
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7136
	.name		= MODULENAME,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7137
	.id_table	= rtl8169_pci_tbl,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7138
	.probe		= rtl_init_one,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7139
	.remove		= __devexit_p(rtl_remove_one),
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7140
	.shutdown	= rtl_shutdown,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7141
	.driver.pm	= RTL8169_PM_OPS,
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7142
};
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7143
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7144
static int __init rtl8169_init_module(void)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7145
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7146
	return pci_register_driver(&rtl8169_pci_driver);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7147
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7148
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7149
static void __exit rtl8169_cleanup_module(void)
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7150
{
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7151
	pci_unregister_driver(&rtl8169_pci_driver);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7152
}
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7153
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7154
module_init(rtl8169_init_module);
5b349a0b1e2b Added r8169 driver for kernel 3.6.
Florian Pose <fp@igh-essen.com>
parents:
diff changeset
  7155
module_exit(rtl8169_cleanup_module);