Merge branch 'upstream-net26' of master.kernel.org:/pub/scm/linux/kernel/git/jgarzik/netdev-2.6
This commit is contained in:
commit
2e5a3eaca3
|
@ -138,7 +138,7 @@ static int __devinit ep8248e_mdio_probe(struct of_device *ofdev,
|
|||
|
||||
bus->name = "ep8248e-mdio-bitbang";
|
||||
bus->dev = &ofdev->dev;
|
||||
bus->id = res.start;
|
||||
snprintf(bus->id, MII_BUS_ID_SIZE, "%x", res.start);
|
||||
|
||||
return mdiobus_register(bus);
|
||||
}
|
||||
|
|
|
@ -241,7 +241,7 @@ static int __devinit gpio_mdio_probe(struct of_device *ofdev,
|
|||
new_bus->reset = &gpio_mdio_reset;
|
||||
|
||||
prop = of_get_property(np, "reg", NULL);
|
||||
new_bus->id = *prop;
|
||||
snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", *prop);
|
||||
new_bus->priv = priv;
|
||||
|
||||
new_bus->phy_mask = 0;
|
||||
|
|
|
@ -341,7 +341,7 @@ static int __init gfar_of_init(void)
|
|||
goto unreg;
|
||||
}
|
||||
|
||||
gfar_data.bus_id = 0;
|
||||
snprintf(gfar_data.bus_id, MII_BUS_ID_SIZE, "0");
|
||||
gfar_data.phy_id = fixed_link[0];
|
||||
} else {
|
||||
phy = of_find_node_by_phandle(*ph);
|
||||
|
@ -362,7 +362,8 @@ static int __init gfar_of_init(void)
|
|||
}
|
||||
|
||||
gfar_data.phy_id = *id;
|
||||
gfar_data.bus_id = res.start;
|
||||
snprintf(gfar_data.bus_id, MII_BUS_ID_SIZE, "%x",
|
||||
res.start);
|
||||
|
||||
of_node_put(phy);
|
||||
of_node_put(mdio);
|
||||
|
|
|
@ -1438,7 +1438,7 @@ config CS89x0
|
|||
config TC35815
|
||||
tristate "TOSHIBA TC35815 Ethernet support"
|
||||
depends on NET_PCI && PCI && MIPS
|
||||
select MII
|
||||
select PHYLIB
|
||||
|
||||
config EEPRO100
|
||||
tristate "EtherExpressPro/100 support (eepro100, original Becker driver)"
|
||||
|
|
|
@ -701,7 +701,7 @@ static struct net_device * au1000_probe(int port_num)
|
|||
aup->mii_bus.write = mdiobus_write;
|
||||
aup->mii_bus.reset = mdiobus_reset;
|
||||
aup->mii_bus.name = "au1000_eth_mii";
|
||||
aup->mii_bus.id = aup->mac_id;
|
||||
snprintf(aup->mii_bus.id, MII_BUS_ID_SIZE, "%x", aup->mac_id);
|
||||
aup->mii_bus.irq = kmalloc(sizeof(int)*PHY_MAX_ADDR, GFP_KERNEL);
|
||||
for(i = 0; i < PHY_MAX_ADDR; ++i)
|
||||
aup->mii_bus.irq[i] = PHY_POLL;
|
||||
|
@ -709,11 +709,11 @@ static struct net_device * au1000_probe(int port_num)
|
|||
/* if known, set corresponding PHY IRQs */
|
||||
#if defined(AU1XXX_PHY_STATIC_CONFIG)
|
||||
# if defined(AU1XXX_PHY0_IRQ)
|
||||
if (AU1XXX_PHY0_BUSID == aup->mii_bus.id)
|
||||
if (AU1XXX_PHY0_BUSID == aup->mac_id)
|
||||
aup->mii_bus.irq[AU1XXX_PHY0_ADDR] = AU1XXX_PHY0_IRQ;
|
||||
# endif
|
||||
# if defined(AU1XXX_PHY1_IRQ)
|
||||
if (AU1XXX_PHY1_BUSID == aup->mii_bus.id)
|
||||
if (AU1XXX_PHY1_BUSID == aup->mac_id)
|
||||
aup->mii_bus.irq[AU1XXX_PHY1_ADDR] = AU1XXX_PHY1_IRQ;
|
||||
# endif
|
||||
#endif
|
||||
|
|
|
@ -969,7 +969,7 @@ static int __init bf537mac_probe(struct net_device *dev)
|
|||
lp->mii_bus.write = mdiobus_write;
|
||||
lp->mii_bus.reset = mdiobus_reset;
|
||||
lp->mii_bus.name = "bfin_mac_mdio";
|
||||
lp->mii_bus.id = 0;
|
||||
snprintf(lp->mii_bus.id, MII_BUS_ID_SIZE, "0");
|
||||
lp->mii_bus.irq = kmalloc(sizeof(int)*PHY_MAX_ADDR, GFP_KERNEL);
|
||||
for (i = 0; i < PHY_MAX_ADDR; ++i)
|
||||
lp->mii_bus.irq[i] = PHY_POLL;
|
||||
|
|
|
@ -3065,8 +3065,6 @@ out:
|
|||
|
||||
#ifdef CONFIG_PROC_FS
|
||||
|
||||
#define SEQ_START_TOKEN ((void *)1)
|
||||
|
||||
static void *bond_info_seq_start(struct seq_file *seq, loff_t *pos)
|
||||
{
|
||||
struct bonding *bond = seq->private;
|
||||
|
|
|
@ -987,7 +987,7 @@ static int external_switch;
|
|||
static int __devinit cpmac_probe(struct platform_device *pdev)
|
||||
{
|
||||
int rc, phy_id, i;
|
||||
int mdio_bus_id = cpmac_mii.id;
|
||||
char *mdio_bus_id = "0";
|
||||
struct resource *mem;
|
||||
struct cpmac_priv *priv;
|
||||
struct net_device *dev;
|
||||
|
@ -1008,8 +1008,6 @@ static int __devinit cpmac_probe(struct platform_device *pdev)
|
|||
if (external_switch || dumb_switch) {
|
||||
struct fixed_phy_status status = {};
|
||||
|
||||
mdio_bus_id = 0;
|
||||
|
||||
/*
|
||||
* FIXME: this should be in the platform code!
|
||||
* Since there is not platform code at all (that is,
|
||||
|
@ -1143,6 +1141,7 @@ int __devinit cpmac_init(void)
|
|||
}
|
||||
|
||||
cpmac_mii.phy_mask = ~(mask | 0x80000000);
|
||||
snprintf(cpmac_mii.id, MII_BUS_ID_SIZE, "0");
|
||||
|
||||
res = mdiobus_register(&cpmac_mii);
|
||||
if (res)
|
||||
|
|
|
@ -1014,8 +1014,8 @@ static int offload_open(struct net_device *dev)
|
|||
adapter->port[0]->mtu : 0xffff);
|
||||
init_smt(adapter);
|
||||
|
||||
/* Never mind if the next step fails */
|
||||
sysfs_create_group(&tdev->lldev->dev.kobj, &offload_attr_group);
|
||||
if (sysfs_create_group(&tdev->lldev->dev.kobj, &offload_attr_group))
|
||||
dev_dbg(&dev->dev, "cannot create sysfs group\n");
|
||||
|
||||
/* Call back all registered clients */
|
||||
cxgb3_add_clients(tdev);
|
||||
|
|
|
@ -161,13 +161,13 @@ struct e1000_buffer {
|
|||
struct sk_buff *skb;
|
||||
dma_addr_t dma;
|
||||
unsigned long time_stamp;
|
||||
uint16_t length;
|
||||
uint16_t next_to_watch;
|
||||
u16 length;
|
||||
u16 next_to_watch;
|
||||
};
|
||||
|
||||
|
||||
struct e1000_ps_page { struct page *ps_page[PS_PAGE_BUFFERS]; };
|
||||
struct e1000_ps_page_dma { uint64_t ps_page_dma[PS_PAGE_BUFFERS]; };
|
||||
struct e1000_ps_page_dma { u64 ps_page_dma[PS_PAGE_BUFFERS]; };
|
||||
|
||||
struct e1000_tx_ring {
|
||||
/* pointer to the descriptor ring memory */
|
||||
|
@ -186,8 +186,8 @@ struct e1000_tx_ring {
|
|||
struct e1000_buffer *buffer_info;
|
||||
|
||||
spinlock_t tx_lock;
|
||||
uint16_t tdh;
|
||||
uint16_t tdt;
|
||||
u16 tdh;
|
||||
u16 tdt;
|
||||
bool last_tx_tso;
|
||||
};
|
||||
|
||||
|
@ -213,8 +213,8 @@ struct e1000_rx_ring {
|
|||
/* cpu for rx queue */
|
||||
int cpu;
|
||||
|
||||
uint16_t rdh;
|
||||
uint16_t rdt;
|
||||
u16 rdh;
|
||||
u16 rdt;
|
||||
};
|
||||
|
||||
#define E1000_DESC_UNUSED(R) \
|
||||
|
@ -237,14 +237,14 @@ struct e1000_adapter {
|
|||
struct timer_list watchdog_timer;
|
||||
struct timer_list phy_info_timer;
|
||||
struct vlan_group *vlgrp;
|
||||
uint16_t mng_vlan_id;
|
||||
uint32_t bd_number;
|
||||
uint32_t rx_buffer_len;
|
||||
uint32_t wol;
|
||||
uint32_t smartspeed;
|
||||
uint32_t en_mng_pt;
|
||||
uint16_t link_speed;
|
||||
uint16_t link_duplex;
|
||||
u16 mng_vlan_id;
|
||||
u32 bd_number;
|
||||
u32 rx_buffer_len;
|
||||
u32 wol;
|
||||
u32 smartspeed;
|
||||
u32 en_mng_pt;
|
||||
u16 link_speed;
|
||||
u16 link_duplex;
|
||||
spinlock_t stats_lock;
|
||||
#ifdef CONFIG_E1000_NAPI
|
||||
spinlock_t tx_queue_lock;
|
||||
|
@ -254,13 +254,13 @@ struct e1000_adapter {
|
|||
unsigned int total_rx_bytes;
|
||||
unsigned int total_rx_packets;
|
||||
/* Interrupt Throttle Rate */
|
||||
uint32_t itr;
|
||||
uint32_t itr_setting;
|
||||
uint16_t tx_itr;
|
||||
uint16_t rx_itr;
|
||||
u32 itr;
|
||||
u32 itr_setting;
|
||||
u16 tx_itr;
|
||||
u16 rx_itr;
|
||||
|
||||
struct work_struct reset_task;
|
||||
uint8_t fc_autoneg;
|
||||
u8 fc_autoneg;
|
||||
|
||||
struct timer_list blink_timer;
|
||||
unsigned long led_status;
|
||||
|
@ -269,18 +269,18 @@ struct e1000_adapter {
|
|||
struct e1000_tx_ring *tx_ring; /* One per active queue */
|
||||
unsigned int restart_queue;
|
||||
unsigned long tx_queue_len;
|
||||
uint32_t txd_cmd;
|
||||
uint32_t tx_int_delay;
|
||||
uint32_t tx_abs_int_delay;
|
||||
uint32_t gotcl;
|
||||
uint64_t gotcl_old;
|
||||
uint64_t tpt_old;
|
||||
uint64_t colc_old;
|
||||
uint32_t tx_timeout_count;
|
||||
uint32_t tx_fifo_head;
|
||||
uint32_t tx_head_addr;
|
||||
uint32_t tx_fifo_size;
|
||||
uint8_t tx_timeout_factor;
|
||||
u32 txd_cmd;
|
||||
u32 tx_int_delay;
|
||||
u32 tx_abs_int_delay;
|
||||
u32 gotcl;
|
||||
u64 gotcl_old;
|
||||
u64 tpt_old;
|
||||
u64 colc_old;
|
||||
u32 tx_timeout_count;
|
||||
u32 tx_fifo_head;
|
||||
u32 tx_head_addr;
|
||||
u32 tx_fifo_size;
|
||||
u8 tx_timeout_factor;
|
||||
atomic_t tx_fifo_stall;
|
||||
bool pcix_82544;
|
||||
bool detect_tx_hung;
|
||||
|
@ -305,17 +305,17 @@ struct e1000_adapter {
|
|||
int num_tx_queues;
|
||||
int num_rx_queues;
|
||||
|
||||
uint64_t hw_csum_err;
|
||||
uint64_t hw_csum_good;
|
||||
uint64_t rx_hdr_split;
|
||||
uint32_t alloc_rx_buff_failed;
|
||||
uint32_t rx_int_delay;
|
||||
uint32_t rx_abs_int_delay;
|
||||
u64 hw_csum_err;
|
||||
u64 hw_csum_good;
|
||||
u64 rx_hdr_split;
|
||||
u32 alloc_rx_buff_failed;
|
||||
u32 rx_int_delay;
|
||||
u32 rx_abs_int_delay;
|
||||
bool rx_csum;
|
||||
unsigned int rx_ps_pages;
|
||||
uint32_t gorcl;
|
||||
uint64_t gorcl_old;
|
||||
uint16_t rx_ps_bsize0;
|
||||
u32 gorcl;
|
||||
u64 gorcl_old;
|
||||
u16 rx_ps_bsize0;
|
||||
|
||||
|
||||
/* OS defined structs */
|
||||
|
@ -329,7 +329,7 @@ struct e1000_adapter {
|
|||
struct e1000_phy_info phy_info;
|
||||
struct e1000_phy_stats phy_stats;
|
||||
|
||||
uint32_t test_icr;
|
||||
u32 test_icr;
|
||||
struct e1000_tx_ring test_tx_ring;
|
||||
struct e1000_rx_ring test_rx_ring;
|
||||
|
||||
|
@ -341,7 +341,7 @@ struct e1000_adapter {
|
|||
bool smart_power_down; /* phy smart power down */
|
||||
bool quad_port_a;
|
||||
unsigned long flags;
|
||||
uint32_t eeprom_wol;
|
||||
u32 eeprom_wol;
|
||||
};
|
||||
|
||||
enum e1000_state_t {
|
||||
|
|
|
@ -36,7 +36,7 @@ extern int e1000_up(struct e1000_adapter *adapter);
|
|||
extern void e1000_down(struct e1000_adapter *adapter);
|
||||
extern void e1000_reinit_locked(struct e1000_adapter *adapter);
|
||||
extern void e1000_reset(struct e1000_adapter *adapter);
|
||||
extern int e1000_set_spd_dplx(struct e1000_adapter *adapter, uint16_t spddplx);
|
||||
extern int e1000_set_spd_dplx(struct e1000_adapter *adapter, u16 spddplx);
|
||||
extern int e1000_setup_all_rx_resources(struct e1000_adapter *adapter);
|
||||
extern int e1000_setup_all_tx_resources(struct e1000_adapter *adapter);
|
||||
extern void e1000_free_all_rx_resources(struct e1000_adapter *adapter);
|
||||
|
@ -289,7 +289,7 @@ e1000_set_pauseparam(struct net_device *netdev,
|
|||
return retval;
|
||||
}
|
||||
|
||||
static uint32_t
|
||||
static u32
|
||||
e1000_get_rx_csum(struct net_device *netdev)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
|
@ -297,7 +297,7 @@ e1000_get_rx_csum(struct net_device *netdev)
|
|||
}
|
||||
|
||||
static int
|
||||
e1000_set_rx_csum(struct net_device *netdev, uint32_t data)
|
||||
e1000_set_rx_csum(struct net_device *netdev, u32 data)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
adapter->rx_csum = data;
|
||||
|
@ -309,14 +309,14 @@ e1000_set_rx_csum(struct net_device *netdev, uint32_t data)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static uint32_t
|
||||
static u32
|
||||
e1000_get_tx_csum(struct net_device *netdev)
|
||||
{
|
||||
return (netdev->features & NETIF_F_HW_CSUM) != 0;
|
||||
}
|
||||
|
||||
static int
|
||||
e1000_set_tx_csum(struct net_device *netdev, uint32_t data)
|
||||
e1000_set_tx_csum(struct net_device *netdev, u32 data)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
|
||||
|
@ -335,7 +335,7 @@ e1000_set_tx_csum(struct net_device *netdev, uint32_t data)
|
|||
}
|
||||
|
||||
static int
|
||||
e1000_set_tso(struct net_device *netdev, uint32_t data)
|
||||
e1000_set_tso(struct net_device *netdev, u32 data)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
if ((adapter->hw.mac_type < e1000_82544) ||
|
||||
|
@ -357,7 +357,7 @@ e1000_set_tso(struct net_device *netdev, uint32_t data)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static uint32_t
|
||||
static u32
|
||||
e1000_get_msglevel(struct net_device *netdev)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
|
@ -365,7 +365,7 @@ e1000_get_msglevel(struct net_device *netdev)
|
|||
}
|
||||
|
||||
static void
|
||||
e1000_set_msglevel(struct net_device *netdev, uint32_t data)
|
||||
e1000_set_msglevel(struct net_device *netdev, u32 data)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
adapter->msg_enable = data;
|
||||
|
@ -375,7 +375,7 @@ static int
|
|||
e1000_get_regs_len(struct net_device *netdev)
|
||||
{
|
||||
#define E1000_REGS_LEN 32
|
||||
return E1000_REGS_LEN * sizeof(uint32_t);
|
||||
return E1000_REGS_LEN * sizeof(u32);
|
||||
}
|
||||
|
||||
static void
|
||||
|
@ -384,10 +384,10 @@ e1000_get_regs(struct net_device *netdev,
|
|||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint32_t *regs_buff = p;
|
||||
uint16_t phy_data;
|
||||
u32 *regs_buff = p;
|
||||
u16 phy_data;
|
||||
|
||||
memset(p, 0, E1000_REGS_LEN * sizeof(uint32_t));
|
||||
memset(p, 0, E1000_REGS_LEN * sizeof(u32));
|
||||
|
||||
regs->version = (1 << 24) | (hw->revision_id << 16) | hw->device_id;
|
||||
|
||||
|
@ -412,44 +412,44 @@ e1000_get_regs(struct net_device *netdev,
|
|||
IGP01E1000_PHY_AGC_A);
|
||||
e1000_read_phy_reg(hw, IGP01E1000_PHY_AGC_A &
|
||||
IGP01E1000_PHY_PAGE_SELECT, &phy_data);
|
||||
regs_buff[13] = (uint32_t)phy_data; /* cable length */
|
||||
regs_buff[13] = (u32)phy_data; /* cable length */
|
||||
e1000_write_phy_reg(hw, IGP01E1000_PHY_PAGE_SELECT,
|
||||
IGP01E1000_PHY_AGC_B);
|
||||
e1000_read_phy_reg(hw, IGP01E1000_PHY_AGC_B &
|
||||
IGP01E1000_PHY_PAGE_SELECT, &phy_data);
|
||||
regs_buff[14] = (uint32_t)phy_data; /* cable length */
|
||||
regs_buff[14] = (u32)phy_data; /* cable length */
|
||||
e1000_write_phy_reg(hw, IGP01E1000_PHY_PAGE_SELECT,
|
||||
IGP01E1000_PHY_AGC_C);
|
||||
e1000_read_phy_reg(hw, IGP01E1000_PHY_AGC_C &
|
||||
IGP01E1000_PHY_PAGE_SELECT, &phy_data);
|
||||
regs_buff[15] = (uint32_t)phy_data; /* cable length */
|
||||
regs_buff[15] = (u32)phy_data; /* cable length */
|
||||
e1000_write_phy_reg(hw, IGP01E1000_PHY_PAGE_SELECT,
|
||||
IGP01E1000_PHY_AGC_D);
|
||||
e1000_read_phy_reg(hw, IGP01E1000_PHY_AGC_D &
|
||||
IGP01E1000_PHY_PAGE_SELECT, &phy_data);
|
||||
regs_buff[16] = (uint32_t)phy_data; /* cable length */
|
||||
regs_buff[16] = (u32)phy_data; /* cable length */
|
||||
regs_buff[17] = 0; /* extended 10bt distance (not needed) */
|
||||
e1000_write_phy_reg(hw, IGP01E1000_PHY_PAGE_SELECT, 0x0);
|
||||
e1000_read_phy_reg(hw, IGP01E1000_PHY_PORT_STATUS &
|
||||
IGP01E1000_PHY_PAGE_SELECT, &phy_data);
|
||||
regs_buff[18] = (uint32_t)phy_data; /* cable polarity */
|
||||
regs_buff[18] = (u32)phy_data; /* cable polarity */
|
||||
e1000_write_phy_reg(hw, IGP01E1000_PHY_PAGE_SELECT,
|
||||
IGP01E1000_PHY_PCS_INIT_REG);
|
||||
e1000_read_phy_reg(hw, IGP01E1000_PHY_PCS_INIT_REG &
|
||||
IGP01E1000_PHY_PAGE_SELECT, &phy_data);
|
||||
regs_buff[19] = (uint32_t)phy_data; /* cable polarity */
|
||||
regs_buff[19] = (u32)phy_data; /* cable polarity */
|
||||
regs_buff[20] = 0; /* polarity correction enabled (always) */
|
||||
regs_buff[22] = 0; /* phy receive errors (unavailable) */
|
||||
regs_buff[23] = regs_buff[18]; /* mdix mode */
|
||||
e1000_write_phy_reg(hw, IGP01E1000_PHY_PAGE_SELECT, 0x0);
|
||||
} else {
|
||||
e1000_read_phy_reg(hw, M88E1000_PHY_SPEC_STATUS, &phy_data);
|
||||
regs_buff[13] = (uint32_t)phy_data; /* cable length */
|
||||
regs_buff[13] = (u32)phy_data; /* cable length */
|
||||
regs_buff[14] = 0; /* Dummy (to align w/ IGP phy reg dump) */
|
||||
regs_buff[15] = 0; /* Dummy (to align w/ IGP phy reg dump) */
|
||||
regs_buff[16] = 0; /* Dummy (to align w/ IGP phy reg dump) */
|
||||
e1000_read_phy_reg(hw, M88E1000_PHY_SPEC_CTRL, &phy_data);
|
||||
regs_buff[17] = (uint32_t)phy_data; /* extended 10bt distance */
|
||||
regs_buff[17] = (u32)phy_data; /* extended 10bt distance */
|
||||
regs_buff[18] = regs_buff[13]; /* cable polarity */
|
||||
regs_buff[19] = 0; /* Dummy (to align w/ IGP phy reg dump) */
|
||||
regs_buff[20] = regs_buff[17]; /* polarity correction */
|
||||
|
@ -459,7 +459,7 @@ e1000_get_regs(struct net_device *netdev,
|
|||
}
|
||||
regs_buff[21] = adapter->phy_stats.idle_errors; /* phy idle errors */
|
||||
e1000_read_phy_reg(hw, PHY_1000T_STATUS, &phy_data);
|
||||
regs_buff[24] = (uint32_t)phy_data; /* phy local receiver status */
|
||||
regs_buff[24] = (u32)phy_data; /* phy local receiver status */
|
||||
regs_buff[25] = regs_buff[24]; /* phy remote receiver status */
|
||||
if (hw->mac_type >= e1000_82540 &&
|
||||
hw->mac_type < e1000_82571 &&
|
||||
|
@ -477,14 +477,14 @@ e1000_get_eeprom_len(struct net_device *netdev)
|
|||
|
||||
static int
|
||||
e1000_get_eeprom(struct net_device *netdev,
|
||||
struct ethtool_eeprom *eeprom, uint8_t *bytes)
|
||||
struct ethtool_eeprom *eeprom, u8 *bytes)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint16_t *eeprom_buff;
|
||||
u16 *eeprom_buff;
|
||||
int first_word, last_word;
|
||||
int ret_val = 0;
|
||||
uint16_t i;
|
||||
u16 i;
|
||||
|
||||
if (eeprom->len == 0)
|
||||
return -EINVAL;
|
||||
|
@ -494,7 +494,7 @@ e1000_get_eeprom(struct net_device *netdev,
|
|||
first_word = eeprom->offset >> 1;
|
||||
last_word = (eeprom->offset + eeprom->len - 1) >> 1;
|
||||
|
||||
eeprom_buff = kmalloc(sizeof(uint16_t) *
|
||||
eeprom_buff = kmalloc(sizeof(u16) *
|
||||
(last_word - first_word + 1), GFP_KERNEL);
|
||||
if (!eeprom_buff)
|
||||
return -ENOMEM;
|
||||
|
@ -514,7 +514,7 @@ e1000_get_eeprom(struct net_device *netdev,
|
|||
for (i = 0; i < last_word - first_word + 1; i++)
|
||||
le16_to_cpus(&eeprom_buff[i]);
|
||||
|
||||
memcpy(bytes, (uint8_t *)eeprom_buff + (eeprom->offset & 1),
|
||||
memcpy(bytes, (u8 *)eeprom_buff + (eeprom->offset & 1),
|
||||
eeprom->len);
|
||||
kfree(eeprom_buff);
|
||||
|
||||
|
@ -523,14 +523,14 @@ e1000_get_eeprom(struct net_device *netdev,
|
|||
|
||||
static int
|
||||
e1000_set_eeprom(struct net_device *netdev,
|
||||
struct ethtool_eeprom *eeprom, uint8_t *bytes)
|
||||
struct ethtool_eeprom *eeprom, u8 *bytes)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint16_t *eeprom_buff;
|
||||
u16 *eeprom_buff;
|
||||
void *ptr;
|
||||
int max_len, first_word, last_word, ret_val = 0;
|
||||
uint16_t i;
|
||||
u16 i;
|
||||
|
||||
if (eeprom->len == 0)
|
||||
return -EOPNOTSUPP;
|
||||
|
@ -590,7 +590,7 @@ e1000_get_drvinfo(struct net_device *netdev,
|
|||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
char firmware_version[32];
|
||||
uint16_t eeprom_data;
|
||||
u16 eeprom_data;
|
||||
|
||||
strncpy(drvinfo->driver, e1000_driver_name, 32);
|
||||
strncpy(drvinfo->version, e1000_driver_version, 32);
|
||||
|
@ -674,13 +674,13 @@ e1000_set_ringparam(struct net_device *netdev,
|
|||
adapter->tx_ring = txdr;
|
||||
adapter->rx_ring = rxdr;
|
||||
|
||||
rxdr->count = max(ring->rx_pending,(uint32_t)E1000_MIN_RXD);
|
||||
rxdr->count = min(rxdr->count,(uint32_t)(mac_type < e1000_82544 ?
|
||||
rxdr->count = max(ring->rx_pending,(u32)E1000_MIN_RXD);
|
||||
rxdr->count = min(rxdr->count,(u32)(mac_type < e1000_82544 ?
|
||||
E1000_MAX_RXD : E1000_MAX_82544_RXD));
|
||||
rxdr->count = ALIGN(rxdr->count, REQ_RX_DESCRIPTOR_MULTIPLE);
|
||||
|
||||
txdr->count = max(ring->tx_pending,(uint32_t)E1000_MIN_TXD);
|
||||
txdr->count = min(txdr->count,(uint32_t)(mac_type < e1000_82544 ?
|
||||
txdr->count = max(ring->tx_pending,(u32)E1000_MIN_TXD);
|
||||
txdr->count = min(txdr->count,(u32)(mac_type < e1000_82544 ?
|
||||
E1000_MAX_TXD : E1000_MAX_82544_TXD));
|
||||
txdr->count = ALIGN(txdr->count, REQ_TX_DESCRIPTOR_MULTIPLE);
|
||||
|
||||
|
@ -728,13 +728,13 @@ err_setup:
|
|||
return err;
|
||||
}
|
||||
|
||||
static bool reg_pattern_test(struct e1000_adapter *adapter, uint64_t *data,
|
||||
int reg, uint32_t mask, uint32_t write)
|
||||
static bool reg_pattern_test(struct e1000_adapter *adapter, u64 *data,
|
||||
int reg, u32 mask, u32 write)
|
||||
{
|
||||
static const uint32_t test[] =
|
||||
static const u32 test[] =
|
||||
{0x5A5A5A5A, 0xA5A5A5A5, 0x00000000, 0xFFFFFFFF};
|
||||
uint8_t __iomem *address = adapter->hw.hw_addr + reg;
|
||||
uint32_t read;
|
||||
u8 __iomem *address = adapter->hw.hw_addr + reg;
|
||||
u32 read;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(test); i++) {
|
||||
|
@ -751,11 +751,11 @@ static bool reg_pattern_test(struct e1000_adapter *adapter, uint64_t *data,
|
|||
return false;
|
||||
}
|
||||
|
||||
static bool reg_set_and_check(struct e1000_adapter *adapter, uint64_t *data,
|
||||
int reg, uint32_t mask, uint32_t write)
|
||||
static bool reg_set_and_check(struct e1000_adapter *adapter, u64 *data,
|
||||
int reg, u32 mask, u32 write)
|
||||
{
|
||||
uint8_t __iomem *address = adapter->hw.hw_addr + reg;
|
||||
uint32_t read;
|
||||
u8 __iomem *address = adapter->hw.hw_addr + reg;
|
||||
u32 read;
|
||||
|
||||
writel(write & mask, address);
|
||||
read = readl(address);
|
||||
|
@ -788,10 +788,10 @@ static bool reg_set_and_check(struct e1000_adapter *adapter, uint64_t *data,
|
|||
} while (0)
|
||||
|
||||
static int
|
||||
e1000_reg_test(struct e1000_adapter *adapter, uint64_t *data)
|
||||
e1000_reg_test(struct e1000_adapter *adapter, u64 *data)
|
||||
{
|
||||
uint32_t value, before, after;
|
||||
uint32_t i, toggle;
|
||||
u32 value, before, after;
|
||||
u32 i, toggle;
|
||||
|
||||
/* The status register is Read Only, so a write should fail.
|
||||
* Some bits that get toggled are ignored.
|
||||
|
@ -884,11 +884,11 @@ e1000_reg_test(struct e1000_adapter *adapter, uint64_t *data)
|
|||
}
|
||||
|
||||
static int
|
||||
e1000_eeprom_test(struct e1000_adapter *adapter, uint64_t *data)
|
||||
e1000_eeprom_test(struct e1000_adapter *adapter, u64 *data)
|
||||
{
|
||||
uint16_t temp;
|
||||
uint16_t checksum = 0;
|
||||
uint16_t i;
|
||||
u16 temp;
|
||||
u16 checksum = 0;
|
||||
u16 i;
|
||||
|
||||
*data = 0;
|
||||
/* Read and add up the contents of the EEPROM */
|
||||
|
@ -901,7 +901,7 @@ e1000_eeprom_test(struct e1000_adapter *adapter, uint64_t *data)
|
|||
}
|
||||
|
||||
/* If Checksum is not Correct return error else test passed */
|
||||
if ((checksum != (uint16_t) EEPROM_SUM) && !(*data))
|
||||
if ((checksum != (u16) EEPROM_SUM) && !(*data))
|
||||
*data = 2;
|
||||
|
||||
return *data;
|
||||
|
@ -919,12 +919,12 @@ e1000_test_intr(int irq, void *data)
|
|||
}
|
||||
|
||||
static int
|
||||
e1000_intr_test(struct e1000_adapter *adapter, uint64_t *data)
|
||||
e1000_intr_test(struct e1000_adapter *adapter, u64 *data)
|
||||
{
|
||||
struct net_device *netdev = adapter->netdev;
|
||||
uint32_t mask, i = 0;
|
||||
u32 mask, i = 0;
|
||||
bool shared_int = true;
|
||||
uint32_t irq = adapter->pdev->irq;
|
||||
u32 irq = adapter->pdev->irq;
|
||||
|
||||
*data = 0;
|
||||
|
||||
|
@ -1070,7 +1070,7 @@ e1000_setup_desc_rings(struct e1000_adapter *adapter)
|
|||
struct e1000_tx_ring *txdr = &adapter->test_tx_ring;
|
||||
struct e1000_rx_ring *rxdr = &adapter->test_rx_ring;
|
||||
struct pci_dev *pdev = adapter->pdev;
|
||||
uint32_t rctl;
|
||||
u32 rctl;
|
||||
int i, ret_val;
|
||||
|
||||
/* Setup Tx descriptor ring and Tx buffers */
|
||||
|
@ -1096,8 +1096,8 @@ e1000_setup_desc_rings(struct e1000_adapter *adapter)
|
|||
txdr->next_to_use = txdr->next_to_clean = 0;
|
||||
|
||||
E1000_WRITE_REG(&adapter->hw, TDBAL,
|
||||
((uint64_t) txdr->dma & 0x00000000FFFFFFFF));
|
||||
E1000_WRITE_REG(&adapter->hw, TDBAH, ((uint64_t) txdr->dma >> 32));
|
||||
((u64) txdr->dma & 0x00000000FFFFFFFF));
|
||||
E1000_WRITE_REG(&adapter->hw, TDBAH, ((u64) txdr->dma >> 32));
|
||||
E1000_WRITE_REG(&adapter->hw, TDLEN,
|
||||
txdr->count * sizeof(struct e1000_tx_desc));
|
||||
E1000_WRITE_REG(&adapter->hw, TDH, 0);
|
||||
|
@ -1153,8 +1153,8 @@ e1000_setup_desc_rings(struct e1000_adapter *adapter)
|
|||
rctl = E1000_READ_REG(&adapter->hw, RCTL);
|
||||
E1000_WRITE_REG(&adapter->hw, RCTL, rctl & ~E1000_RCTL_EN);
|
||||
E1000_WRITE_REG(&adapter->hw, RDBAL,
|
||||
((uint64_t) rxdr->dma & 0xFFFFFFFF));
|
||||
E1000_WRITE_REG(&adapter->hw, RDBAH, ((uint64_t) rxdr->dma >> 32));
|
||||
((u64) rxdr->dma & 0xFFFFFFFF));
|
||||
E1000_WRITE_REG(&adapter->hw, RDBAH, ((u64) rxdr->dma >> 32));
|
||||
E1000_WRITE_REG(&adapter->hw, RDLEN, rxdr->size);
|
||||
E1000_WRITE_REG(&adapter->hw, RDH, 0);
|
||||
E1000_WRITE_REG(&adapter->hw, RDT, 0);
|
||||
|
@ -1202,7 +1202,7 @@ e1000_phy_disable_receiver(struct e1000_adapter *adapter)
|
|||
static void
|
||||
e1000_phy_reset_clk_and_crs(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint16_t phy_reg;
|
||||
u16 phy_reg;
|
||||
|
||||
/* Because we reset the PHY above, we need to re-force TX_CLK in the
|
||||
* Extended PHY Specific Control Register to 25MHz clock. This
|
||||
|
@ -1226,8 +1226,8 @@ e1000_phy_reset_clk_and_crs(struct e1000_adapter *adapter)
|
|||
static int
|
||||
e1000_nonintegrated_phy_loopback(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint32_t ctrl_reg;
|
||||
uint16_t phy_reg;
|
||||
u32 ctrl_reg;
|
||||
u16 phy_reg;
|
||||
|
||||
/* Setup the Device Control Register for PHY loopback test. */
|
||||
|
||||
|
@ -1293,8 +1293,8 @@ e1000_nonintegrated_phy_loopback(struct e1000_adapter *adapter)
|
|||
static int
|
||||
e1000_integrated_phy_loopback(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint32_t ctrl_reg = 0;
|
||||
uint32_t stat_reg = 0;
|
||||
u32 ctrl_reg = 0;
|
||||
u32 stat_reg = 0;
|
||||
|
||||
adapter->hw.autoneg = false;
|
||||
|
||||
|
@ -1363,8 +1363,8 @@ e1000_integrated_phy_loopback(struct e1000_adapter *adapter)
|
|||
static int
|
||||
e1000_set_phy_loopback(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint16_t phy_reg = 0;
|
||||
uint16_t count = 0;
|
||||
u16 phy_reg = 0;
|
||||
u16 count = 0;
|
||||
|
||||
switch (adapter->hw.mac_type) {
|
||||
case e1000_82543:
|
||||
|
@ -1416,7 +1416,7 @@ static int
|
|||
e1000_setup_loopback_test(struct e1000_adapter *adapter)
|
||||
{
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint32_t rctl;
|
||||
u32 rctl;
|
||||
|
||||
if (hw->media_type == e1000_media_type_fiber ||
|
||||
hw->media_type == e1000_media_type_internal_serdes) {
|
||||
|
@ -1451,8 +1451,8 @@ static void
|
|||
e1000_loopback_cleanup(struct e1000_adapter *adapter)
|
||||
{
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint32_t rctl;
|
||||
uint16_t phy_reg;
|
||||
u32 rctl;
|
||||
u16 phy_reg;
|
||||
|
||||
rctl = E1000_READ_REG(hw, RCTL);
|
||||
rctl &= ~(E1000_RCTL_LBM_TCVR | E1000_RCTL_LBM_MAC);
|
||||
|
@ -1578,7 +1578,7 @@ e1000_run_loopback_test(struct e1000_adapter *adapter)
|
|||
}
|
||||
|
||||
static int
|
||||
e1000_loopback_test(struct e1000_adapter *adapter, uint64_t *data)
|
||||
e1000_loopback_test(struct e1000_adapter *adapter, u64 *data)
|
||||
{
|
||||
/* PHY loopback cannot be performed if SoL/IDER
|
||||
* sessions are active */
|
||||
|
@ -1603,7 +1603,7 @@ out:
|
|||
}
|
||||
|
||||
static int
|
||||
e1000_link_test(struct e1000_adapter *adapter, uint64_t *data)
|
||||
e1000_link_test(struct e1000_adapter *adapter, u64 *data)
|
||||
{
|
||||
*data = 0;
|
||||
if (adapter->hw.media_type == e1000_media_type_internal_serdes) {
|
||||
|
@ -1647,7 +1647,7 @@ e1000_get_sset_count(struct net_device *netdev, int sset)
|
|||
|
||||
static void
|
||||
e1000_diag_test(struct net_device *netdev,
|
||||
struct ethtool_test *eth_test, uint64_t *data)
|
||||
struct ethtool_test *eth_test, u64 *data)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
bool if_running = netif_running(netdev);
|
||||
|
@ -1657,9 +1657,9 @@ e1000_diag_test(struct net_device *netdev,
|
|||
/* Offline tests */
|
||||
|
||||
/* save speed, duplex, autoneg settings */
|
||||
uint16_t autoneg_advertised = adapter->hw.autoneg_advertised;
|
||||
uint8_t forced_speed_duplex = adapter->hw.forced_speed_duplex;
|
||||
uint8_t autoneg = adapter->hw.autoneg;
|
||||
u16 autoneg_advertised = adapter->hw.autoneg_advertised;
|
||||
u8 forced_speed_duplex = adapter->hw.forced_speed_duplex;
|
||||
u8 autoneg = adapter->hw.autoneg;
|
||||
|
||||
DPRINTK(HW, INFO, "offline testing starting\n");
|
||||
|
||||
|
@ -1877,7 +1877,7 @@ e1000_led_blink_callback(unsigned long data)
|
|||
}
|
||||
|
||||
static int
|
||||
e1000_phys_id(struct net_device *netdev, uint32_t data)
|
||||
e1000_phys_id(struct net_device *netdev, u32 data)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
|
||||
|
@ -1927,7 +1927,7 @@ e1000_nway_reset(struct net_device *netdev)
|
|||
|
||||
static void
|
||||
e1000_get_ethtool_stats(struct net_device *netdev,
|
||||
struct ethtool_stats *stats, uint64_t *data)
|
||||
struct ethtool_stats *stats, u64 *data)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
int i;
|
||||
|
@ -1936,15 +1936,15 @@ e1000_get_ethtool_stats(struct net_device *netdev,
|
|||
for (i = 0; i < E1000_GLOBAL_STATS_LEN; i++) {
|
||||
char *p = (char *)adapter+e1000_gstrings_stats[i].stat_offset;
|
||||
data[i] = (e1000_gstrings_stats[i].sizeof_stat ==
|
||||
sizeof(uint64_t)) ? *(uint64_t *)p : *(uint32_t *)p;
|
||||
sizeof(u64)) ? *(u64 *)p : *(u32 *)p;
|
||||
}
|
||||
/* BUG_ON(i != E1000_STATS_LEN); */
|
||||
}
|
||||
|
||||
static void
|
||||
e1000_get_strings(struct net_device *netdev, uint32_t stringset, uint8_t *data)
|
||||
e1000_get_strings(struct net_device *netdev, u32 stringset, u8 *data)
|
||||
{
|
||||
uint8_t *p = data;
|
||||
u8 *p = data;
|
||||
int i;
|
||||
|
||||
switch (stringset) {
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -100,7 +100,7 @@ typedef enum {
|
|||
} e1000_fc_type;
|
||||
|
||||
struct e1000_shadow_ram {
|
||||
uint16_t eeprom_word;
|
||||
u16 eeprom_word;
|
||||
bool modified;
|
||||
};
|
||||
|
||||
|
@ -263,17 +263,17 @@ struct e1000_phy_info {
|
|||
};
|
||||
|
||||
struct e1000_phy_stats {
|
||||
uint32_t idle_errors;
|
||||
uint32_t receive_errors;
|
||||
u32 idle_errors;
|
||||
u32 receive_errors;
|
||||
};
|
||||
|
||||
struct e1000_eeprom_info {
|
||||
e1000_eeprom_type type;
|
||||
uint16_t word_size;
|
||||
uint16_t opcode_bits;
|
||||
uint16_t address_bits;
|
||||
uint16_t delay_usec;
|
||||
uint16_t page_size;
|
||||
u16 word_size;
|
||||
u16 opcode_bits;
|
||||
u16 address_bits;
|
||||
u16 delay_usec;
|
||||
u16 page_size;
|
||||
bool use_eerd;
|
||||
bool use_eewr;
|
||||
};
|
||||
|
@ -308,34 +308,34 @@ typedef enum {
|
|||
|
||||
/* Function prototypes */
|
||||
/* Initialization */
|
||||
int32_t e1000_reset_hw(struct e1000_hw *hw);
|
||||
int32_t e1000_init_hw(struct e1000_hw *hw);
|
||||
int32_t e1000_set_mac_type(struct e1000_hw *hw);
|
||||
s32 e1000_reset_hw(struct e1000_hw *hw);
|
||||
s32 e1000_init_hw(struct e1000_hw *hw);
|
||||
s32 e1000_set_mac_type(struct e1000_hw *hw);
|
||||
void e1000_set_media_type(struct e1000_hw *hw);
|
||||
|
||||
/* Link Configuration */
|
||||
int32_t e1000_setup_link(struct e1000_hw *hw);
|
||||
int32_t e1000_phy_setup_autoneg(struct e1000_hw *hw);
|
||||
s32 e1000_setup_link(struct e1000_hw *hw);
|
||||
s32 e1000_phy_setup_autoneg(struct e1000_hw *hw);
|
||||
void e1000_config_collision_dist(struct e1000_hw *hw);
|
||||
int32_t e1000_check_for_link(struct e1000_hw *hw);
|
||||
int32_t e1000_get_speed_and_duplex(struct e1000_hw *hw, uint16_t *speed, uint16_t *duplex);
|
||||
int32_t e1000_force_mac_fc(struct e1000_hw *hw);
|
||||
s32 e1000_check_for_link(struct e1000_hw *hw);
|
||||
s32 e1000_get_speed_and_duplex(struct e1000_hw *hw, u16 *speed, u16 *duplex);
|
||||
s32 e1000_force_mac_fc(struct e1000_hw *hw);
|
||||
|
||||
/* PHY */
|
||||
int32_t e1000_read_phy_reg(struct e1000_hw *hw, uint32_t reg_addr, uint16_t *phy_data);
|
||||
int32_t e1000_write_phy_reg(struct e1000_hw *hw, uint32_t reg_addr, uint16_t data);
|
||||
int32_t e1000_phy_hw_reset(struct e1000_hw *hw);
|
||||
int32_t e1000_phy_reset(struct e1000_hw *hw);
|
||||
int32_t e1000_phy_get_info(struct e1000_hw *hw, struct e1000_phy_info *phy_info);
|
||||
int32_t e1000_validate_mdi_setting(struct e1000_hw *hw);
|
||||
s32 e1000_read_phy_reg(struct e1000_hw *hw, u32 reg_addr, u16 *phy_data);
|
||||
s32 e1000_write_phy_reg(struct e1000_hw *hw, u32 reg_addr, u16 data);
|
||||
s32 e1000_phy_hw_reset(struct e1000_hw *hw);
|
||||
s32 e1000_phy_reset(struct e1000_hw *hw);
|
||||
s32 e1000_phy_get_info(struct e1000_hw *hw, struct e1000_phy_info *phy_info);
|
||||
s32 e1000_validate_mdi_setting(struct e1000_hw *hw);
|
||||
|
||||
void e1000_phy_powerdown_workaround(struct e1000_hw *hw);
|
||||
|
||||
/* EEPROM Functions */
|
||||
int32_t e1000_init_eeprom_params(struct e1000_hw *hw);
|
||||
s32 e1000_init_eeprom_params(struct e1000_hw *hw);
|
||||
|
||||
/* MNG HOST IF functions */
|
||||
uint32_t e1000_enable_mng_pass_thru(struct e1000_hw *hw);
|
||||
u32 e1000_enable_mng_pass_thru(struct e1000_hw *hw);
|
||||
|
||||
#define E1000_MNG_DHCP_TX_PAYLOAD_CMD 64
|
||||
#define E1000_HI_MAX_MNG_DATA_LENGTH 0x6F8 /* Host Interface data length */
|
||||
|
@ -354,80 +354,80 @@ uint32_t e1000_enable_mng_pass_thru(struct e1000_hw *hw);
|
|||
#define E1000_VFTA_ENTRY_BIT_SHIFT_MASK 0x1F
|
||||
|
||||
struct e1000_host_mng_command_header {
|
||||
uint8_t command_id;
|
||||
uint8_t checksum;
|
||||
uint16_t reserved1;
|
||||
uint16_t reserved2;
|
||||
uint16_t command_length;
|
||||
u8 command_id;
|
||||
u8 checksum;
|
||||
u16 reserved1;
|
||||
u16 reserved2;
|
||||
u16 command_length;
|
||||
};
|
||||
|
||||
struct e1000_host_mng_command_info {
|
||||
struct e1000_host_mng_command_header command_header; /* Command Head/Command Result Head has 4 bytes */
|
||||
uint8_t command_data[E1000_HI_MAX_MNG_DATA_LENGTH]; /* Command data can length 0..0x658*/
|
||||
u8 command_data[E1000_HI_MAX_MNG_DATA_LENGTH]; /* Command data can length 0..0x658*/
|
||||
};
|
||||
#ifdef __BIG_ENDIAN
|
||||
struct e1000_host_mng_dhcp_cookie{
|
||||
uint32_t signature;
|
||||
uint16_t vlan_id;
|
||||
uint8_t reserved0;
|
||||
uint8_t status;
|
||||
uint32_t reserved1;
|
||||
uint8_t checksum;
|
||||
uint8_t reserved3;
|
||||
uint16_t reserved2;
|
||||
u32 signature;
|
||||
u16 vlan_id;
|
||||
u8 reserved0;
|
||||
u8 status;
|
||||
u32 reserved1;
|
||||
u8 checksum;
|
||||
u8 reserved3;
|
||||
u16 reserved2;
|
||||
};
|
||||
#else
|
||||
struct e1000_host_mng_dhcp_cookie{
|
||||
uint32_t signature;
|
||||
uint8_t status;
|
||||
uint8_t reserved0;
|
||||
uint16_t vlan_id;
|
||||
uint32_t reserved1;
|
||||
uint16_t reserved2;
|
||||
uint8_t reserved3;
|
||||
uint8_t checksum;
|
||||
u32 signature;
|
||||
u8 status;
|
||||
u8 reserved0;
|
||||
u16 vlan_id;
|
||||
u32 reserved1;
|
||||
u16 reserved2;
|
||||
u8 reserved3;
|
||||
u8 checksum;
|
||||
};
|
||||
#endif
|
||||
|
||||
int32_t e1000_mng_write_dhcp_info(struct e1000_hw *hw, uint8_t *buffer,
|
||||
uint16_t length);
|
||||
s32 e1000_mng_write_dhcp_info(struct e1000_hw *hw, u8 *buffer,
|
||||
u16 length);
|
||||
bool e1000_check_mng_mode(struct e1000_hw *hw);
|
||||
bool e1000_enable_tx_pkt_filtering(struct e1000_hw *hw);
|
||||
int32_t e1000_read_eeprom(struct e1000_hw *hw, uint16_t reg, uint16_t words, uint16_t *data);
|
||||
int32_t e1000_validate_eeprom_checksum(struct e1000_hw *hw);
|
||||
int32_t e1000_update_eeprom_checksum(struct e1000_hw *hw);
|
||||
int32_t e1000_write_eeprom(struct e1000_hw *hw, uint16_t reg, uint16_t words, uint16_t *data);
|
||||
int32_t e1000_read_mac_addr(struct e1000_hw * hw);
|
||||
s32 e1000_read_eeprom(struct e1000_hw *hw, u16 reg, u16 words, u16 *data);
|
||||
s32 e1000_validate_eeprom_checksum(struct e1000_hw *hw);
|
||||
s32 e1000_update_eeprom_checksum(struct e1000_hw *hw);
|
||||
s32 e1000_write_eeprom(struct e1000_hw *hw, u16 reg, u16 words, u16 *data);
|
||||
s32 e1000_read_mac_addr(struct e1000_hw * hw);
|
||||
|
||||
/* Filters (multicast, vlan, receive) */
|
||||
uint32_t e1000_hash_mc_addr(struct e1000_hw *hw, uint8_t * mc_addr);
|
||||
void e1000_mta_set(struct e1000_hw *hw, uint32_t hash_value);
|
||||
void e1000_rar_set(struct e1000_hw *hw, uint8_t * mc_addr, uint32_t rar_index);
|
||||
void e1000_write_vfta(struct e1000_hw *hw, uint32_t offset, uint32_t value);
|
||||
u32 e1000_hash_mc_addr(struct e1000_hw *hw, u8 * mc_addr);
|
||||
void e1000_mta_set(struct e1000_hw *hw, u32 hash_value);
|
||||
void e1000_rar_set(struct e1000_hw *hw, u8 * mc_addr, u32 rar_index);
|
||||
void e1000_write_vfta(struct e1000_hw *hw, u32 offset, u32 value);
|
||||
|
||||
/* LED functions */
|
||||
int32_t e1000_setup_led(struct e1000_hw *hw);
|
||||
int32_t e1000_cleanup_led(struct e1000_hw *hw);
|
||||
int32_t e1000_led_on(struct e1000_hw *hw);
|
||||
int32_t e1000_led_off(struct e1000_hw *hw);
|
||||
int32_t e1000_blink_led_start(struct e1000_hw *hw);
|
||||
s32 e1000_setup_led(struct e1000_hw *hw);
|
||||
s32 e1000_cleanup_led(struct e1000_hw *hw);
|
||||
s32 e1000_led_on(struct e1000_hw *hw);
|
||||
s32 e1000_led_off(struct e1000_hw *hw);
|
||||
s32 e1000_blink_led_start(struct e1000_hw *hw);
|
||||
|
||||
/* Adaptive IFS Functions */
|
||||
|
||||
/* Everything else */
|
||||
void e1000_reset_adaptive(struct e1000_hw *hw);
|
||||
void e1000_update_adaptive(struct e1000_hw *hw);
|
||||
void e1000_tbi_adjust_stats(struct e1000_hw *hw, struct e1000_hw_stats *stats, uint32_t frame_len, uint8_t * mac_addr);
|
||||
void e1000_tbi_adjust_stats(struct e1000_hw *hw, struct e1000_hw_stats *stats, u32 frame_len, u8 * mac_addr);
|
||||
void e1000_get_bus_info(struct e1000_hw *hw);
|
||||
void e1000_pci_set_mwi(struct e1000_hw *hw);
|
||||
void e1000_pci_clear_mwi(struct e1000_hw *hw);
|
||||
int32_t e1000_read_pcie_cap_reg(struct e1000_hw *hw, uint32_t reg, uint16_t *value);
|
||||
s32 e1000_read_pcie_cap_reg(struct e1000_hw *hw, u32 reg, u16 *value);
|
||||
void e1000_pcix_set_mmrbc(struct e1000_hw *hw, int mmrbc);
|
||||
int e1000_pcix_get_mmrbc(struct e1000_hw *hw);
|
||||
/* Port I/O is only supported on 82544 and newer */
|
||||
void e1000_io_write(struct e1000_hw *hw, unsigned long port, uint32_t value);
|
||||
int32_t e1000_disable_pciex_master(struct e1000_hw *hw);
|
||||
int32_t e1000_check_phy_reset_block(struct e1000_hw *hw);
|
||||
void e1000_io_write(struct e1000_hw *hw, unsigned long port, u32 value);
|
||||
s32 e1000_disable_pciex_master(struct e1000_hw *hw);
|
||||
s32 e1000_check_phy_reset_block(struct e1000_hw *hw);
|
||||
|
||||
|
||||
#define E1000_READ_REG_IO(a, reg) \
|
||||
|
@ -596,8 +596,8 @@ struct e1000_rx_desc {
|
|||
__le64 buffer_addr; /* Address of the descriptor's data buffer */
|
||||
__le16 length; /* Length of data DMAed into data buffer */
|
||||
__le16 csum; /* Packet checksum */
|
||||
uint8_t status; /* Descriptor status */
|
||||
uint8_t errors; /* Descriptor Errors */
|
||||
u8 status; /* Descriptor status */
|
||||
u8 errors; /* Descriptor Errors */
|
||||
__le16 special;
|
||||
};
|
||||
|
||||
|
@ -718,15 +718,15 @@ struct e1000_tx_desc {
|
|||
__le32 data;
|
||||
struct {
|
||||
__le16 length; /* Data buffer length */
|
||||
uint8_t cso; /* Checksum offset */
|
||||
uint8_t cmd; /* Descriptor control */
|
||||
u8 cso; /* Checksum offset */
|
||||
u8 cmd; /* Descriptor control */
|
||||
} flags;
|
||||
} lower;
|
||||
union {
|
||||
__le32 data;
|
||||
struct {
|
||||
uint8_t status; /* Descriptor status */
|
||||
uint8_t css; /* Checksum start */
|
||||
u8 status; /* Descriptor status */
|
||||
u8 css; /* Checksum start */
|
||||
__le16 special;
|
||||
} fields;
|
||||
} upper;
|
||||
|
@ -759,16 +759,16 @@ struct e1000_context_desc {
|
|||
union {
|
||||
__le32 ip_config;
|
||||
struct {
|
||||
uint8_t ipcss; /* IP checksum start */
|
||||
uint8_t ipcso; /* IP checksum offset */
|
||||
u8 ipcss; /* IP checksum start */
|
||||
u8 ipcso; /* IP checksum offset */
|
||||
__le16 ipcse; /* IP checksum end */
|
||||
} ip_fields;
|
||||
} lower_setup;
|
||||
union {
|
||||
__le32 tcp_config;
|
||||
struct {
|
||||
uint8_t tucss; /* TCP checksum start */
|
||||
uint8_t tucso; /* TCP checksum offset */
|
||||
u8 tucss; /* TCP checksum start */
|
||||
u8 tucso; /* TCP checksum offset */
|
||||
__le16 tucse; /* TCP checksum end */
|
||||
} tcp_fields;
|
||||
} upper_setup;
|
||||
|
@ -776,8 +776,8 @@ struct e1000_context_desc {
|
|||
union {
|
||||
__le32 data;
|
||||
struct {
|
||||
uint8_t status; /* Descriptor status */
|
||||
uint8_t hdr_len; /* Header length */
|
||||
u8 status; /* Descriptor status */
|
||||
u8 hdr_len; /* Header length */
|
||||
__le16 mss; /* Maximum segment size */
|
||||
} fields;
|
||||
} tcp_seg_setup;
|
||||
|
@ -790,15 +790,15 @@ struct e1000_data_desc {
|
|||
__le32 data;
|
||||
struct {
|
||||
__le16 length; /* Data buffer length */
|
||||
uint8_t typ_len_ext; /* */
|
||||
uint8_t cmd; /* */
|
||||
u8 typ_len_ext; /* */
|
||||
u8 cmd; /* */
|
||||
} flags;
|
||||
} lower;
|
||||
union {
|
||||
__le32 data;
|
||||
struct {
|
||||
uint8_t status; /* Descriptor status */
|
||||
uint8_t popts; /* Packet Options */
|
||||
u8 status; /* Descriptor status */
|
||||
u8 popts; /* Packet Options */
|
||||
__le16 special; /* */
|
||||
} fields;
|
||||
} upper;
|
||||
|
@ -825,8 +825,8 @@ struct e1000_rar {
|
|||
|
||||
/* IPv4 Address Table Entry */
|
||||
struct e1000_ipv4_at_entry {
|
||||
volatile uint32_t ipv4_addr; /* IP Address (RW) */
|
||||
volatile uint32_t reserved;
|
||||
volatile u32 ipv4_addr; /* IP Address (RW) */
|
||||
volatile u32 reserved;
|
||||
};
|
||||
|
||||
/* Four wakeup IP addresses are supported */
|
||||
|
@ -837,25 +837,25 @@ struct e1000_ipv4_at_entry {
|
|||
|
||||
/* IPv6 Address Table Entry */
|
||||
struct e1000_ipv6_at_entry {
|
||||
volatile uint8_t ipv6_addr[16];
|
||||
volatile u8 ipv6_addr[16];
|
||||
};
|
||||
|
||||
/* Flexible Filter Length Table Entry */
|
||||
struct e1000_fflt_entry {
|
||||
volatile uint32_t length; /* Flexible Filter Length (RW) */
|
||||
volatile uint32_t reserved;
|
||||
volatile u32 length; /* Flexible Filter Length (RW) */
|
||||
volatile u32 reserved;
|
||||
};
|
||||
|
||||
/* Flexible Filter Mask Table Entry */
|
||||
struct e1000_ffmt_entry {
|
||||
volatile uint32_t mask; /* Flexible Filter Mask (RW) */
|
||||
volatile uint32_t reserved;
|
||||
volatile u32 mask; /* Flexible Filter Mask (RW) */
|
||||
volatile u32 reserved;
|
||||
};
|
||||
|
||||
/* Flexible Filter Value Table Entry */
|
||||
struct e1000_ffvt_entry {
|
||||
volatile uint32_t value; /* Flexible Filter Value (RW) */
|
||||
volatile uint32_t reserved;
|
||||
volatile u32 value; /* Flexible Filter Value (RW) */
|
||||
volatile u32 reserved;
|
||||
};
|
||||
|
||||
/* Four Flexible Filters are supported */
|
||||
|
@ -1309,89 +1309,89 @@ struct e1000_ffvt_entry {
|
|||
|
||||
/* Statistics counters collected by the MAC */
|
||||
struct e1000_hw_stats {
|
||||
uint64_t crcerrs;
|
||||
uint64_t algnerrc;
|
||||
uint64_t symerrs;
|
||||
uint64_t rxerrc;
|
||||
uint64_t txerrc;
|
||||
uint64_t mpc;
|
||||
uint64_t scc;
|
||||
uint64_t ecol;
|
||||
uint64_t mcc;
|
||||
uint64_t latecol;
|
||||
uint64_t colc;
|
||||
uint64_t dc;
|
||||
uint64_t tncrs;
|
||||
uint64_t sec;
|
||||
uint64_t cexterr;
|
||||
uint64_t rlec;
|
||||
uint64_t xonrxc;
|
||||
uint64_t xontxc;
|
||||
uint64_t xoffrxc;
|
||||
uint64_t xofftxc;
|
||||
uint64_t fcruc;
|
||||
uint64_t prc64;
|
||||
uint64_t prc127;
|
||||
uint64_t prc255;
|
||||
uint64_t prc511;
|
||||
uint64_t prc1023;
|
||||
uint64_t prc1522;
|
||||
uint64_t gprc;
|
||||
uint64_t bprc;
|
||||
uint64_t mprc;
|
||||
uint64_t gptc;
|
||||
uint64_t gorcl;
|
||||
uint64_t gorch;
|
||||
uint64_t gotcl;
|
||||
uint64_t gotch;
|
||||
uint64_t rnbc;
|
||||
uint64_t ruc;
|
||||
uint64_t rfc;
|
||||
uint64_t roc;
|
||||
uint64_t rlerrc;
|
||||
uint64_t rjc;
|
||||
uint64_t mgprc;
|
||||
uint64_t mgpdc;
|
||||
uint64_t mgptc;
|
||||
uint64_t torl;
|
||||
uint64_t torh;
|
||||
uint64_t totl;
|
||||
uint64_t toth;
|
||||
uint64_t tpr;
|
||||
uint64_t tpt;
|
||||
uint64_t ptc64;
|
||||
uint64_t ptc127;
|
||||
uint64_t ptc255;
|
||||
uint64_t ptc511;
|
||||
uint64_t ptc1023;
|
||||
uint64_t ptc1522;
|
||||
uint64_t mptc;
|
||||
uint64_t bptc;
|
||||
uint64_t tsctc;
|
||||
uint64_t tsctfc;
|
||||
uint64_t iac;
|
||||
uint64_t icrxptc;
|
||||
uint64_t icrxatc;
|
||||
uint64_t ictxptc;
|
||||
uint64_t ictxatc;
|
||||
uint64_t ictxqec;
|
||||
uint64_t ictxqmtc;
|
||||
uint64_t icrxdmtc;
|
||||
uint64_t icrxoc;
|
||||
u64 crcerrs;
|
||||
u64 algnerrc;
|
||||
u64 symerrs;
|
||||
u64 rxerrc;
|
||||
u64 txerrc;
|
||||
u64 mpc;
|
||||
u64 scc;
|
||||
u64 ecol;
|
||||
u64 mcc;
|
||||
u64 latecol;
|
||||
u64 colc;
|
||||
u64 dc;
|
||||
u64 tncrs;
|
||||
u64 sec;
|
||||
u64 cexterr;
|
||||
u64 rlec;
|
||||
u64 xonrxc;
|
||||
u64 xontxc;
|
||||
u64 xoffrxc;
|
||||
u64 xofftxc;
|
||||
u64 fcruc;
|
||||
u64 prc64;
|
||||
u64 prc127;
|
||||
u64 prc255;
|
||||
u64 prc511;
|
||||
u64 prc1023;
|
||||
u64 prc1522;
|
||||
u64 gprc;
|
||||
u64 bprc;
|
||||
u64 mprc;
|
||||
u64 gptc;
|
||||
u64 gorcl;
|
||||
u64 gorch;
|
||||
u64 gotcl;
|
||||
u64 gotch;
|
||||
u64 rnbc;
|
||||
u64 ruc;
|
||||
u64 rfc;
|
||||
u64 roc;
|
||||
u64 rlerrc;
|
||||
u64 rjc;
|
||||
u64 mgprc;
|
||||
u64 mgpdc;
|
||||
u64 mgptc;
|
||||
u64 torl;
|
||||
u64 torh;
|
||||
u64 totl;
|
||||
u64 toth;
|
||||
u64 tpr;
|
||||
u64 tpt;
|
||||
u64 ptc64;
|
||||
u64 ptc127;
|
||||
u64 ptc255;
|
||||
u64 ptc511;
|
||||
u64 ptc1023;
|
||||
u64 ptc1522;
|
||||
u64 mptc;
|
||||
u64 bptc;
|
||||
u64 tsctc;
|
||||
u64 tsctfc;
|
||||
u64 iac;
|
||||
u64 icrxptc;
|
||||
u64 icrxatc;
|
||||
u64 ictxptc;
|
||||
u64 ictxatc;
|
||||
u64 ictxqec;
|
||||
u64 ictxqmtc;
|
||||
u64 icrxdmtc;
|
||||
u64 icrxoc;
|
||||
};
|
||||
|
||||
/* Structure containing variables used by the shared code (e1000_hw.c) */
|
||||
struct e1000_hw {
|
||||
uint8_t __iomem *hw_addr;
|
||||
uint8_t __iomem *flash_address;
|
||||
u8 __iomem *hw_addr;
|
||||
u8 __iomem *flash_address;
|
||||
e1000_mac_type mac_type;
|
||||
e1000_phy_type phy_type;
|
||||
uint32_t phy_init_script;
|
||||
u32 phy_init_script;
|
||||
e1000_media_type media_type;
|
||||
void *back;
|
||||
struct e1000_shadow_ram *eeprom_shadow_ram;
|
||||
uint32_t flash_bank_size;
|
||||
uint32_t flash_base_addr;
|
||||
u32 flash_bank_size;
|
||||
u32 flash_base_addr;
|
||||
e1000_fc_type fc;
|
||||
e1000_bus_speed bus_speed;
|
||||
e1000_bus_width bus_width;
|
||||
|
@ -1400,51 +1400,51 @@ struct e1000_hw {
|
|||
e1000_ms_type master_slave;
|
||||
e1000_ms_type original_master_slave;
|
||||
e1000_ffe_config ffe_config_state;
|
||||
uint32_t asf_firmware_present;
|
||||
uint32_t eeprom_semaphore_present;
|
||||
uint32_t swfw_sync_present;
|
||||
uint32_t swfwhw_semaphore_present;
|
||||
u32 asf_firmware_present;
|
||||
u32 eeprom_semaphore_present;
|
||||
u32 swfw_sync_present;
|
||||
u32 swfwhw_semaphore_present;
|
||||
unsigned long io_base;
|
||||
uint32_t phy_id;
|
||||
uint32_t phy_revision;
|
||||
uint32_t phy_addr;
|
||||
uint32_t original_fc;
|
||||
uint32_t txcw;
|
||||
uint32_t autoneg_failed;
|
||||
uint32_t max_frame_size;
|
||||
uint32_t min_frame_size;
|
||||
uint32_t mc_filter_type;
|
||||
uint32_t num_mc_addrs;
|
||||
uint32_t collision_delta;
|
||||
uint32_t tx_packet_delta;
|
||||
uint32_t ledctl_default;
|
||||
uint32_t ledctl_mode1;
|
||||
uint32_t ledctl_mode2;
|
||||
u32 phy_id;
|
||||
u32 phy_revision;
|
||||
u32 phy_addr;
|
||||
u32 original_fc;
|
||||
u32 txcw;
|
||||
u32 autoneg_failed;
|
||||
u32 max_frame_size;
|
||||
u32 min_frame_size;
|
||||
u32 mc_filter_type;
|
||||
u32 num_mc_addrs;
|
||||
u32 collision_delta;
|
||||
u32 tx_packet_delta;
|
||||
u32 ledctl_default;
|
||||
u32 ledctl_mode1;
|
||||
u32 ledctl_mode2;
|
||||
bool tx_pkt_filtering;
|
||||
struct e1000_host_mng_dhcp_cookie mng_cookie;
|
||||
uint16_t phy_spd_default;
|
||||
uint16_t autoneg_advertised;
|
||||
uint16_t pci_cmd_word;
|
||||
uint16_t fc_high_water;
|
||||
uint16_t fc_low_water;
|
||||
uint16_t fc_pause_time;
|
||||
uint16_t current_ifs_val;
|
||||
uint16_t ifs_min_val;
|
||||
uint16_t ifs_max_val;
|
||||
uint16_t ifs_step_size;
|
||||
uint16_t ifs_ratio;
|
||||
uint16_t device_id;
|
||||
uint16_t vendor_id;
|
||||
uint16_t subsystem_id;
|
||||
uint16_t subsystem_vendor_id;
|
||||
uint8_t revision_id;
|
||||
uint8_t autoneg;
|
||||
uint8_t mdix;
|
||||
uint8_t forced_speed_duplex;
|
||||
uint8_t wait_autoneg_complete;
|
||||
uint8_t dma_fairness;
|
||||
uint8_t mac_addr[NODE_ADDRESS_SIZE];
|
||||
uint8_t perm_mac_addr[NODE_ADDRESS_SIZE];
|
||||
u16 phy_spd_default;
|
||||
u16 autoneg_advertised;
|
||||
u16 pci_cmd_word;
|
||||
u16 fc_high_water;
|
||||
u16 fc_low_water;
|
||||
u16 fc_pause_time;
|
||||
u16 current_ifs_val;
|
||||
u16 ifs_min_val;
|
||||
u16 ifs_max_val;
|
||||
u16 ifs_step_size;
|
||||
u16 ifs_ratio;
|
||||
u16 device_id;
|
||||
u16 vendor_id;
|
||||
u16 subsystem_id;
|
||||
u16 subsystem_vendor_id;
|
||||
u8 revision_id;
|
||||
u8 autoneg;
|
||||
u8 mdix;
|
||||
u8 forced_speed_duplex;
|
||||
u8 wait_autoneg_complete;
|
||||
u8 dma_fairness;
|
||||
u8 mac_addr[NODE_ADDRESS_SIZE];
|
||||
u8 perm_mac_addr[NODE_ADDRESS_SIZE];
|
||||
bool disable_polarity_correction;
|
||||
bool speed_downgraded;
|
||||
e1000_smart_speed smart_speed;
|
||||
|
@ -2165,14 +2165,14 @@ typedef enum {
|
|||
#define E1000_HI_COMMAND_TIMEOUT 500 /* Time in ms to process HI command */
|
||||
|
||||
struct e1000_host_command_header {
|
||||
uint8_t command_id;
|
||||
uint8_t command_length;
|
||||
uint8_t command_options; /* I/F bits for command, status for return */
|
||||
uint8_t checksum;
|
||||
u8 command_id;
|
||||
u8 command_length;
|
||||
u8 command_options; /* I/F bits for command, status for return */
|
||||
u8 checksum;
|
||||
};
|
||||
struct e1000_host_command_info {
|
||||
struct e1000_host_command_header command_header; /* Command Head/Command Result Head has 4 bytes */
|
||||
uint8_t command_data[E1000_HI_MAX_DATA_LENGTH]; /* Command data can length 0..252 */
|
||||
u8 command_data[E1000_HI_MAX_DATA_LENGTH]; /* Command data can length 0..252 */
|
||||
};
|
||||
|
||||
/* Host SMB register #0 */
|
||||
|
@ -2495,7 +2495,7 @@ struct e1000_host_command_info {
|
|||
/* Number of milliseconds we wait for PHY configuration done after MAC reset */
|
||||
#define PHY_CFG_TIMEOUT 100
|
||||
|
||||
#define E1000_TX_BUFFER_SIZE ((uint32_t)1514)
|
||||
#define E1000_TX_BUFFER_SIZE ((u32)1514)
|
||||
|
||||
/* The carrier extension symbol, as received by the NIC. */
|
||||
#define CARRIER_EXTENSION 0x0F
|
||||
|
@ -3312,68 +3312,68 @@ struct e1000_host_command_info {
|
|||
/* Offset 04h HSFSTS */
|
||||
union ich8_hws_flash_status {
|
||||
struct ich8_hsfsts {
|
||||
#ifdef E1000_BIG_ENDIAN
|
||||
uint16_t reserved2 :6;
|
||||
uint16_t fldesvalid :1;
|
||||
uint16_t flockdn :1;
|
||||
uint16_t flcdone :1;
|
||||
uint16_t flcerr :1;
|
||||
uint16_t dael :1;
|
||||
uint16_t berasesz :2;
|
||||
uint16_t flcinprog :1;
|
||||
uint16_t reserved1 :2;
|
||||
#ifdef __BIG_ENDIAN
|
||||
u16 reserved2 :6;
|
||||
u16 fldesvalid :1;
|
||||
u16 flockdn :1;
|
||||
u16 flcdone :1;
|
||||
u16 flcerr :1;
|
||||
u16 dael :1;
|
||||
u16 berasesz :2;
|
||||
u16 flcinprog :1;
|
||||
u16 reserved1 :2;
|
||||
#else
|
||||
uint16_t flcdone :1; /* bit 0 Flash Cycle Done */
|
||||
uint16_t flcerr :1; /* bit 1 Flash Cycle Error */
|
||||
uint16_t dael :1; /* bit 2 Direct Access error Log */
|
||||
uint16_t berasesz :2; /* bit 4:3 Block/Sector Erase Size */
|
||||
uint16_t flcinprog :1; /* bit 5 flash SPI cycle in Progress */
|
||||
uint16_t reserved1 :2; /* bit 13:6 Reserved */
|
||||
uint16_t reserved2 :6; /* bit 13:6 Reserved */
|
||||
uint16_t fldesvalid :1; /* bit 14 Flash Descriptor Valid */
|
||||
uint16_t flockdn :1; /* bit 15 Flash Configuration Lock-Down */
|
||||
u16 flcdone :1; /* bit 0 Flash Cycle Done */
|
||||
u16 flcerr :1; /* bit 1 Flash Cycle Error */
|
||||
u16 dael :1; /* bit 2 Direct Access error Log */
|
||||
u16 berasesz :2; /* bit 4:3 Block/Sector Erase Size */
|
||||
u16 flcinprog :1; /* bit 5 flash SPI cycle in Progress */
|
||||
u16 reserved1 :2; /* bit 13:6 Reserved */
|
||||
u16 reserved2 :6; /* bit 13:6 Reserved */
|
||||
u16 fldesvalid :1; /* bit 14 Flash Descriptor Valid */
|
||||
u16 flockdn :1; /* bit 15 Flash Configuration Lock-Down */
|
||||
#endif
|
||||
} hsf_status;
|
||||
uint16_t regval;
|
||||
u16 regval;
|
||||
};
|
||||
|
||||
/* ICH8 GbE Flash Hardware Sequencing Flash control Register bit breakdown */
|
||||
/* Offset 06h FLCTL */
|
||||
union ich8_hws_flash_ctrl {
|
||||
struct ich8_hsflctl {
|
||||
#ifdef E1000_BIG_ENDIAN
|
||||
uint16_t fldbcount :2;
|
||||
uint16_t flockdn :6;
|
||||
uint16_t flcgo :1;
|
||||
uint16_t flcycle :2;
|
||||
uint16_t reserved :5;
|
||||
#ifdef __BIG_ENDIAN
|
||||
u16 fldbcount :2;
|
||||
u16 flockdn :6;
|
||||
u16 flcgo :1;
|
||||
u16 flcycle :2;
|
||||
u16 reserved :5;
|
||||
#else
|
||||
uint16_t flcgo :1; /* 0 Flash Cycle Go */
|
||||
uint16_t flcycle :2; /* 2:1 Flash Cycle */
|
||||
uint16_t reserved :5; /* 7:3 Reserved */
|
||||
uint16_t fldbcount :2; /* 9:8 Flash Data Byte Count */
|
||||
uint16_t flockdn :6; /* 15:10 Reserved */
|
||||
u16 flcgo :1; /* 0 Flash Cycle Go */
|
||||
u16 flcycle :2; /* 2:1 Flash Cycle */
|
||||
u16 reserved :5; /* 7:3 Reserved */
|
||||
u16 fldbcount :2; /* 9:8 Flash Data Byte Count */
|
||||
u16 flockdn :6; /* 15:10 Reserved */
|
||||
#endif
|
||||
} hsf_ctrl;
|
||||
uint16_t regval;
|
||||
u16 regval;
|
||||
};
|
||||
|
||||
/* ICH8 Flash Region Access Permissions */
|
||||
union ich8_hws_flash_regacc {
|
||||
struct ich8_flracc {
|
||||
#ifdef E1000_BIG_ENDIAN
|
||||
uint32_t gmwag :8;
|
||||
uint32_t gmrag :8;
|
||||
uint32_t grwa :8;
|
||||
uint32_t grra :8;
|
||||
#ifdef __BIG_ENDIAN
|
||||
u32 gmwag :8;
|
||||
u32 gmrag :8;
|
||||
u32 grwa :8;
|
||||
u32 grra :8;
|
||||
#else
|
||||
uint32_t grra :8; /* 0:7 GbE region Read Access */
|
||||
uint32_t grwa :8; /* 8:15 GbE region Write Access */
|
||||
uint32_t gmrag :8; /* 23:16 GbE Master Read Access Grant */
|
||||
uint32_t gmwag :8; /* 31:24 GbE Master Write Access Grant */
|
||||
u32 grra :8; /* 0:7 GbE region Read Access */
|
||||
u32 grwa :8; /* 8:15 GbE region Write Access */
|
||||
u32 gmrag :8; /* 23:16 GbE Master Read Access Grant */
|
||||
u32 gmwag :8; /* 31:24 GbE Master Write Access Grant */
|
||||
#endif
|
||||
} hsf_flregacc;
|
||||
uint16_t regval;
|
||||
u16 regval;
|
||||
};
|
||||
|
||||
/* Miscellaneous PHY bit definitions. */
|
||||
|
|
|
@ -127,7 +127,7 @@ int e1000_up(struct e1000_adapter *adapter);
|
|||
void e1000_down(struct e1000_adapter *adapter);
|
||||
void e1000_reinit_locked(struct e1000_adapter *adapter);
|
||||
void e1000_reset(struct e1000_adapter *adapter);
|
||||
int e1000_set_spd_dplx(struct e1000_adapter *adapter, uint16_t spddplx);
|
||||
int e1000_set_spd_dplx(struct e1000_adapter *adapter, u16 spddplx);
|
||||
int e1000_setup_all_tx_resources(struct e1000_adapter *adapter);
|
||||
int e1000_setup_all_rx_resources(struct e1000_adapter *adapter);
|
||||
void e1000_free_all_tx_resources(struct e1000_adapter *adapter);
|
||||
|
@ -203,8 +203,8 @@ static int e1000_82547_fifo_workaround(struct e1000_adapter *adapter,
|
|||
struct sk_buff *skb);
|
||||
|
||||
static void e1000_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp);
|
||||
static void e1000_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid);
|
||||
static void e1000_vlan_rx_kill_vid(struct net_device *netdev, uint16_t vid);
|
||||
static void e1000_vlan_rx_add_vid(struct net_device *netdev, u16 vid);
|
||||
static void e1000_vlan_rx_kill_vid(struct net_device *netdev, u16 vid);
|
||||
static void e1000_restore_vlan(struct e1000_adapter *adapter);
|
||||
|
||||
static int e1000_suspend(struct pci_dev *pdev, pm_message_t state);
|
||||
|
@ -368,8 +368,8 @@ static void
|
|||
e1000_update_mng_vlan(struct e1000_adapter *adapter)
|
||||
{
|
||||
struct net_device *netdev = adapter->netdev;
|
||||
uint16_t vid = adapter->hw.mng_cookie.vlan_id;
|
||||
uint16_t old_vid = adapter->mng_vlan_id;
|
||||
u16 vid = adapter->hw.mng_cookie.vlan_id;
|
||||
u16 old_vid = adapter->mng_vlan_id;
|
||||
if (adapter->vlgrp) {
|
||||
if (!vlan_group_get_device(adapter->vlgrp, vid)) {
|
||||
if (adapter->hw.mng_cookie.status &
|
||||
|
@ -379,7 +379,7 @@ e1000_update_mng_vlan(struct e1000_adapter *adapter)
|
|||
} else
|
||||
adapter->mng_vlan_id = E1000_MNG_VLAN_NONE;
|
||||
|
||||
if ((old_vid != (uint16_t)E1000_MNG_VLAN_NONE) &&
|
||||
if ((old_vid != (u16)E1000_MNG_VLAN_NONE) &&
|
||||
(vid != old_vid) &&
|
||||
!vlan_group_get_device(adapter->vlgrp, old_vid))
|
||||
e1000_vlan_rx_kill_vid(netdev, old_vid);
|
||||
|
@ -402,8 +402,8 @@ e1000_update_mng_vlan(struct e1000_adapter *adapter)
|
|||
static void
|
||||
e1000_release_hw_control(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint32_t ctrl_ext;
|
||||
uint32_t swsm;
|
||||
u32 ctrl_ext;
|
||||
u32 swsm;
|
||||
|
||||
/* Let firmware taken over control of h/w */
|
||||
switch (adapter->hw.mac_type) {
|
||||
|
@ -439,8 +439,8 @@ e1000_release_hw_control(struct e1000_adapter *adapter)
|
|||
static void
|
||||
e1000_get_hw_control(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint32_t ctrl_ext;
|
||||
uint32_t swsm;
|
||||
u32 ctrl_ext;
|
||||
u32 swsm;
|
||||
|
||||
/* Let firmware know the driver has taken over */
|
||||
switch (adapter->hw.mac_type) {
|
||||
|
@ -466,7 +466,7 @@ static void
|
|||
e1000_init_manageability(struct e1000_adapter *adapter)
|
||||
{
|
||||
if (adapter->en_mng_pt) {
|
||||
uint32_t manc = E1000_READ_REG(&adapter->hw, MANC);
|
||||
u32 manc = E1000_READ_REG(&adapter->hw, MANC);
|
||||
|
||||
/* disable hardware interception of ARP */
|
||||
manc &= ~(E1000_MANC_ARP_EN);
|
||||
|
@ -475,7 +475,7 @@ e1000_init_manageability(struct e1000_adapter *adapter)
|
|||
/* this will probably generate destination unreachable messages
|
||||
* from the host OS, but the packets will be handled on SMBUS */
|
||||
if (adapter->hw.has_manc2h) {
|
||||
uint32_t manc2h = E1000_READ_REG(&adapter->hw, MANC2H);
|
||||
u32 manc2h = E1000_READ_REG(&adapter->hw, MANC2H);
|
||||
|
||||
manc |= E1000_MANC_EN_MNG2HOST;
|
||||
#define E1000_MNG2HOST_PORT_623 (1 << 5)
|
||||
|
@ -493,7 +493,7 @@ static void
|
|||
e1000_release_manageability(struct e1000_adapter *adapter)
|
||||
{
|
||||
if (adapter->en_mng_pt) {
|
||||
uint32_t manc = E1000_READ_REG(&adapter->hw, MANC);
|
||||
u32 manc = E1000_READ_REG(&adapter->hw, MANC);
|
||||
|
||||
/* re-enable hardware interception of ARP */
|
||||
manc |= E1000_MANC_ARP_EN;
|
||||
|
@ -566,7 +566,7 @@ int e1000_up(struct e1000_adapter *adapter)
|
|||
|
||||
void e1000_power_up_phy(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint16_t mii_reg = 0;
|
||||
u16 mii_reg = 0;
|
||||
|
||||
/* Just clear the power down bit to wake the phy back up */
|
||||
if (adapter->hw.media_type == e1000_media_type_copper) {
|
||||
|
@ -587,7 +587,7 @@ static void e1000_power_down_phy(struct e1000_adapter *adapter)
|
|||
* (c) SoL/IDER session is active */
|
||||
if (!adapter->wol && adapter->hw.mac_type >= e1000_82540 &&
|
||||
adapter->hw.media_type == e1000_media_type_copper) {
|
||||
uint16_t mii_reg = 0;
|
||||
u16 mii_reg = 0;
|
||||
|
||||
switch (adapter->hw.mac_type) {
|
||||
case e1000_82540:
|
||||
|
@ -667,8 +667,8 @@ e1000_reinit_locked(struct e1000_adapter *adapter)
|
|||
void
|
||||
e1000_reset(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint32_t pba = 0, tx_space, min_tx_space, min_rx_space;
|
||||
uint16_t fc_high_water_mark = E1000_FC_HIGH_DIFF;
|
||||
u32 pba = 0, tx_space, min_tx_space, min_rx_space;
|
||||
u16 fc_high_water_mark = E1000_FC_HIGH_DIFF;
|
||||
bool legacy_pba_adjust = false;
|
||||
|
||||
/* Repartition Pba for greater than 9k mtu
|
||||
|
@ -815,7 +815,7 @@ e1000_reset(struct e1000_adapter *adapter)
|
|||
adapter->hw.mac_type <= e1000_82547_rev_2 &&
|
||||
adapter->hw.autoneg == 1 &&
|
||||
adapter->hw.autoneg_advertised == ADVERTISE_1000_FULL) {
|
||||
uint32_t ctrl = E1000_READ_REG(&adapter->hw, CTRL);
|
||||
u32 ctrl = E1000_READ_REG(&adapter->hw, CTRL);
|
||||
/* clear phy power management bit if we are in gig only mode,
|
||||
* which if enabled will attempt negotiation to 100Mb, which
|
||||
* can cause a loss of link at power off or driver unload */
|
||||
|
@ -832,7 +832,7 @@ e1000_reset(struct e1000_adapter *adapter)
|
|||
if (!adapter->smart_power_down &&
|
||||
(adapter->hw.mac_type == e1000_82571 ||
|
||||
adapter->hw.mac_type == e1000_82572)) {
|
||||
uint16_t phy_data = 0;
|
||||
u16 phy_data = 0;
|
||||
/* speed up time to link by disabling smart power down, ignore
|
||||
* the return value of this function because there is nothing
|
||||
* different we would do if it failed */
|
||||
|
@ -926,8 +926,8 @@ e1000_probe(struct pci_dev *pdev,
|
|||
static int cards_found = 0;
|
||||
static int global_quad_port_a = 0; /* global ksp3 port a indication */
|
||||
int i, err, pci_using_dac;
|
||||
uint16_t eeprom_data = 0;
|
||||
uint16_t eeprom_apme_mask = E1000_EEPROM_APME;
|
||||
u16 eeprom_data = 0;
|
||||
u16 eeprom_apme_mask = E1000_EEPROM_APME;
|
||||
DECLARE_MAC_BUF(mac);
|
||||
|
||||
if ((err = pci_enable_device(pdev)))
|
||||
|
@ -1702,10 +1702,10 @@ e1000_setup_all_tx_resources(struct e1000_adapter *adapter)
|
|||
static void
|
||||
e1000_configure_tx(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint64_t tdba;
|
||||
u64 tdba;
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint32_t tdlen, tctl, tipg, tarc;
|
||||
uint32_t ipgr1, ipgr2;
|
||||
u32 tdlen, tctl, tipg, tarc;
|
||||
u32 ipgr1, ipgr2;
|
||||
|
||||
/* Setup the HW Tx Head and Tail descriptor pointers */
|
||||
|
||||
|
@ -1947,10 +1947,10 @@ e1000_setup_all_rx_resources(struct e1000_adapter *adapter)
|
|||
static void
|
||||
e1000_setup_rctl(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint32_t rctl, rfctl;
|
||||
uint32_t psrctl = 0;
|
||||
u32 rctl, rfctl;
|
||||
u32 psrctl = 0;
|
||||
#ifndef CONFIG_E1000_DISABLE_PACKET_SPLIT
|
||||
uint32_t pages = 0;
|
||||
u32 pages = 0;
|
||||
#endif
|
||||
|
||||
rctl = E1000_READ_REG(&adapter->hw, RCTL);
|
||||
|
@ -2065,9 +2065,9 @@ e1000_setup_rctl(struct e1000_adapter *adapter)
|
|||
static void
|
||||
e1000_configure_rx(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint64_t rdba;
|
||||
u64 rdba;
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint32_t rdlen, rctl, rxcsum, ctrl_ext;
|
||||
u32 rdlen, rctl, rxcsum, ctrl_ext;
|
||||
|
||||
if (adapter->rx_ps_pages) {
|
||||
/* this is a 32 byte descriptor */
|
||||
|
@ -2387,7 +2387,7 @@ static void
|
|||
e1000_enter_82542_rst(struct e1000_adapter *adapter)
|
||||
{
|
||||
struct net_device *netdev = adapter->netdev;
|
||||
uint32_t rctl;
|
||||
u32 rctl;
|
||||
|
||||
e1000_pci_clear_mwi(&adapter->hw);
|
||||
|
||||
|
@ -2405,7 +2405,7 @@ static void
|
|||
e1000_leave_82542_rst(struct e1000_adapter *adapter)
|
||||
{
|
||||
struct net_device *netdev = adapter->netdev;
|
||||
uint32_t rctl;
|
||||
u32 rctl;
|
||||
|
||||
rctl = E1000_READ_REG(&adapter->hw, RCTL);
|
||||
rctl &= ~E1000_RCTL_RST;
|
||||
|
@ -2490,8 +2490,8 @@ e1000_set_rx_mode(struct net_device *netdev)
|
|||
struct e1000_hw *hw = &adapter->hw;
|
||||
struct dev_addr_list *uc_ptr;
|
||||
struct dev_addr_list *mc_ptr;
|
||||
uint32_t rctl;
|
||||
uint32_t hash_value;
|
||||
u32 rctl;
|
||||
u32 hash_value;
|
||||
int i, rar_entries = E1000_RAR_ENTRIES;
|
||||
int mta_reg_count = (hw->mac_type == e1000_ich8lan) ?
|
||||
E1000_NUM_MTA_REGISTERS_ICH8LAN :
|
||||
|
@ -2595,7 +2595,7 @@ e1000_82547_tx_fifo_stall(unsigned long data)
|
|||
{
|
||||
struct e1000_adapter *adapter = (struct e1000_adapter *) data;
|
||||
struct net_device *netdev = adapter->netdev;
|
||||
uint32_t tctl;
|
||||
u32 tctl;
|
||||
|
||||
if (atomic_read(&adapter->tx_fifo_stall)) {
|
||||
if ((E1000_READ_REG(&adapter->hw, TDT) ==
|
||||
|
@ -2637,8 +2637,8 @@ e1000_watchdog(unsigned long data)
|
|||
struct e1000_adapter *adapter = (struct e1000_adapter *) data;
|
||||
struct net_device *netdev = adapter->netdev;
|
||||
struct e1000_tx_ring *txdr = adapter->tx_ring;
|
||||
uint32_t link, tctl;
|
||||
int32_t ret_val;
|
||||
u32 link, tctl;
|
||||
s32 ret_val;
|
||||
|
||||
ret_val = e1000_check_for_link(&adapter->hw);
|
||||
if ((ret_val == E1000_ERR_PHY) &&
|
||||
|
@ -2663,7 +2663,7 @@ e1000_watchdog(unsigned long data)
|
|||
|
||||
if (link) {
|
||||
if (!netif_carrier_ok(netdev)) {
|
||||
uint32_t ctrl;
|
||||
u32 ctrl;
|
||||
bool txb2b = true;
|
||||
e1000_get_speed_and_duplex(&adapter->hw,
|
||||
&adapter->link_speed,
|
||||
|
@ -2700,7 +2700,7 @@ e1000_watchdog(unsigned long data)
|
|||
if ((adapter->hw.mac_type == e1000_82571 ||
|
||||
adapter->hw.mac_type == e1000_82572) &&
|
||||
!txb2b) {
|
||||
uint32_t tarc0;
|
||||
u32 tarc0;
|
||||
tarc0 = E1000_READ_REG(&adapter->hw, TARC0);
|
||||
tarc0 &= ~(1 << 21);
|
||||
E1000_WRITE_REG(&adapter->hw, TARC0, tarc0);
|
||||
|
@ -2742,7 +2742,7 @@ e1000_watchdog(unsigned long data)
|
|||
/* make sure the receive unit is started */
|
||||
if (adapter->hw.rx_needs_kicking) {
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint32_t rctl = E1000_READ_REG(hw, RCTL);
|
||||
u32 rctl = E1000_READ_REG(hw, RCTL);
|
||||
E1000_WRITE_REG(hw, RCTL, rctl | E1000_RCTL_EN);
|
||||
}
|
||||
}
|
||||
|
@ -2832,7 +2832,7 @@ enum latency_range {
|
|||
* @bytes: the number of bytes during this measurement interval
|
||||
**/
|
||||
static unsigned int e1000_update_itr(struct e1000_adapter *adapter,
|
||||
uint16_t itr_setting,
|
||||
u16 itr_setting,
|
||||
int packets,
|
||||
int bytes)
|
||||
{
|
||||
|
@ -2884,8 +2884,8 @@ update_itr_done:
|
|||
static void e1000_set_itr(struct e1000_adapter *adapter)
|
||||
{
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint16_t current_itr;
|
||||
uint32_t new_itr = adapter->itr;
|
||||
u16 current_itr;
|
||||
u32 new_itr = adapter->itr;
|
||||
|
||||
if (unlikely(hw->mac_type < e1000_82540))
|
||||
return;
|
||||
|
@ -2959,9 +2959,9 @@ e1000_tso(struct e1000_adapter *adapter, struct e1000_tx_ring *tx_ring,
|
|||
struct e1000_context_desc *context_desc;
|
||||
struct e1000_buffer *buffer_info;
|
||||
unsigned int i;
|
||||
uint32_t cmd_length = 0;
|
||||
uint16_t ipcse = 0, tucse, mss;
|
||||
uint8_t ipcss, ipcso, tucss, tucso, hdr_len;
|
||||
u32 cmd_length = 0;
|
||||
u16 ipcse = 0, tucse, mss;
|
||||
u8 ipcss, ipcso, tucss, tucso, hdr_len;
|
||||
int err;
|
||||
|
||||
if (skb_is_gso(skb)) {
|
||||
|
@ -3032,7 +3032,7 @@ e1000_tx_csum(struct e1000_adapter *adapter, struct e1000_tx_ring *tx_ring,
|
|||
struct e1000_context_desc *context_desc;
|
||||
struct e1000_buffer *buffer_info;
|
||||
unsigned int i;
|
||||
uint8_t css;
|
||||
u8 css;
|
||||
|
||||
if (likely(skb->ip_summed == CHECKSUM_PARTIAL)) {
|
||||
css = skb_transport_offset(skb);
|
||||
|
@ -3177,7 +3177,7 @@ e1000_tx_queue(struct e1000_adapter *adapter, struct e1000_tx_ring *tx_ring,
|
|||
{
|
||||
struct e1000_tx_desc *tx_desc = NULL;
|
||||
struct e1000_buffer *buffer_info;
|
||||
uint32_t txd_upper = 0, txd_lower = E1000_TXD_CMD_IFCS;
|
||||
u32 txd_upper = 0, txd_lower = E1000_TXD_CMD_IFCS;
|
||||
unsigned int i;
|
||||
|
||||
if (likely(tx_flags & E1000_TX_FLAGS_TSO)) {
|
||||
|
@ -3241,8 +3241,8 @@ e1000_tx_queue(struct e1000_adapter *adapter, struct e1000_tx_ring *tx_ring,
|
|||
static int
|
||||
e1000_82547_fifo_workaround(struct e1000_adapter *adapter, struct sk_buff *skb)
|
||||
{
|
||||
uint32_t fifo_space = adapter->tx_fifo_size - adapter->tx_fifo_head;
|
||||
uint32_t skb_fifo_len = skb->len + E1000_FIFO_HDR;
|
||||
u32 fifo_space = adapter->tx_fifo_size - adapter->tx_fifo_head;
|
||||
u32 skb_fifo_len = skb->len + E1000_FIFO_HDR;
|
||||
|
||||
skb_fifo_len = ALIGN(skb_fifo_len, E1000_FIFO_HDR);
|
||||
|
||||
|
@ -3269,7 +3269,7 @@ static int
|
|||
e1000_transfer_dhcp_info(struct e1000_adapter *adapter, struct sk_buff *skb)
|
||||
{
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint16_t length, offset;
|
||||
u16 length, offset;
|
||||
if (vlan_tx_tag_present(skb)) {
|
||||
if (!((vlan_tx_tag_get(skb) == adapter->hw.mng_cookie.vlan_id) &&
|
||||
( adapter->hw.mng_cookie.status &
|
||||
|
@ -3280,17 +3280,17 @@ e1000_transfer_dhcp_info(struct e1000_adapter *adapter, struct sk_buff *skb)
|
|||
struct ethhdr *eth = (struct ethhdr *) skb->data;
|
||||
if ((htons(ETH_P_IP) == eth->h_proto)) {
|
||||
const struct iphdr *ip =
|
||||
(struct iphdr *)((uint8_t *)skb->data+14);
|
||||
(struct iphdr *)((u8 *)skb->data+14);
|
||||
if (IPPROTO_UDP == ip->protocol) {
|
||||
struct udphdr *udp =
|
||||
(struct udphdr *)((uint8_t *)ip +
|
||||
(struct udphdr *)((u8 *)ip +
|
||||
(ip->ihl << 2));
|
||||
if (ntohs(udp->dest) == 67) {
|
||||
offset = (uint8_t *)udp + 8 - skb->data;
|
||||
offset = (u8 *)udp + 8 - skb->data;
|
||||
length = skb->len - offset;
|
||||
|
||||
return e1000_mng_write_dhcp_info(hw,
|
||||
(uint8_t *)udp + 8,
|
||||
(u8 *)udp + 8,
|
||||
length);
|
||||
}
|
||||
}
|
||||
|
@ -3370,7 +3370,7 @@ e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
|
|||
* overrun the FIFO, adjust the max buffer len if mss
|
||||
* drops. */
|
||||
if (mss) {
|
||||
uint8_t hdr_len;
|
||||
u8 hdr_len;
|
||||
max_per_txd = min(mss << 2, max_per_txd);
|
||||
max_txd_pwr = fls(max_per_txd) - 1;
|
||||
|
||||
|
@ -3557,7 +3557,7 @@ e1000_change_mtu(struct net_device *netdev, int new_mtu)
|
|||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
int max_frame = new_mtu + ENET_HEADER_SIZE + ETHERNET_FCS_SIZE;
|
||||
uint16_t eeprom_data = 0;
|
||||
u16 eeprom_data = 0;
|
||||
|
||||
if ((max_frame < MINIMUM_ETHERNET_FRAME_SIZE) ||
|
||||
(max_frame > MAX_JUMBO_FRAME_SIZE)) {
|
||||
|
@ -3652,7 +3652,7 @@ e1000_update_stats(struct e1000_adapter *adapter)
|
|||
struct e1000_hw *hw = &adapter->hw;
|
||||
struct pci_dev *pdev = adapter->pdev;
|
||||
unsigned long flags;
|
||||
uint16_t phy_tmp;
|
||||
u16 phy_tmp;
|
||||
|
||||
#define PHY_IDLE_ERROR_COUNT_MASK 0x00FF
|
||||
|
||||
|
@ -3829,7 +3829,7 @@ e1000_intr_msi(int irq, void *data)
|
|||
#ifndef CONFIG_E1000_NAPI
|
||||
int i;
|
||||
#endif
|
||||
uint32_t icr = E1000_READ_REG(hw, ICR);
|
||||
u32 icr = E1000_READ_REG(hw, ICR);
|
||||
|
||||
/* in NAPI mode read ICR disables interrupts using IAM */
|
||||
|
||||
|
@ -3841,7 +3841,7 @@ e1000_intr_msi(int irq, void *data)
|
|||
if (netif_carrier_ok(netdev) &&
|
||||
(adapter->hw.mac_type == e1000_80003es2lan)) {
|
||||
/* disable receives */
|
||||
uint32_t rctl = E1000_READ_REG(hw, RCTL);
|
||||
u32 rctl = E1000_READ_REG(hw, RCTL);
|
||||
E1000_WRITE_REG(hw, RCTL, rctl & ~E1000_RCTL_EN);
|
||||
}
|
||||
/* guard against interrupt when we're going down */
|
||||
|
@ -3888,7 +3888,7 @@ e1000_intr(int irq, void *data)
|
|||
struct net_device *netdev = data;
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
uint32_t rctl, icr = E1000_READ_REG(hw, ICR);
|
||||
u32 rctl, icr = E1000_READ_REG(hw, ICR);
|
||||
#ifndef CONFIG_E1000_NAPI
|
||||
int i;
|
||||
#endif
|
||||
|
@ -4139,11 +4139,11 @@ e1000_clean_tx_irq(struct e1000_adapter *adapter,
|
|||
|
||||
static void
|
||||
e1000_rx_checksum(struct e1000_adapter *adapter,
|
||||
uint32_t status_err, uint32_t csum,
|
||||
u32 status_err, u32 csum,
|
||||
struct sk_buff *skb)
|
||||
{
|
||||
uint16_t status = (uint16_t)status_err;
|
||||
uint8_t errors = (uint8_t)(status_err >> 24);
|
||||
u16 status = (u16)status_err;
|
||||
u8 errors = (u8)(status_err >> 24);
|
||||
skb->ip_summed = CHECKSUM_NONE;
|
||||
|
||||
/* 82543 or newer only */
|
||||
|
@ -4200,8 +4200,8 @@ e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
|||
struct e1000_rx_desc *rx_desc, *next_rxd;
|
||||
struct e1000_buffer *buffer_info, *next_buffer;
|
||||
unsigned long flags;
|
||||
uint32_t length;
|
||||
uint8_t last_byte;
|
||||
u32 length;
|
||||
u8 last_byte;
|
||||
unsigned int i;
|
||||
int cleaned_count = 0;
|
||||
bool cleaned = false;
|
||||
|
@ -4301,8 +4301,8 @@ e1000_clean_rx_irq(struct e1000_adapter *adapter,
|
|||
|
||||
/* Receive Checksum Offload */
|
||||
e1000_rx_checksum(adapter,
|
||||
(uint32_t)(status) |
|
||||
((uint32_t)(rx_desc->errors) << 24),
|
||||
(u32)(status) |
|
||||
((u32)(rx_desc->errors) << 24),
|
||||
le16_to_cpu(rx_desc->csum), skb);
|
||||
|
||||
skb->protocol = eth_type_trans(skb, netdev);
|
||||
|
@ -4376,7 +4376,7 @@ e1000_clean_rx_irq_ps(struct e1000_adapter *adapter,
|
|||
struct e1000_ps_page_dma *ps_page_dma;
|
||||
struct sk_buff *skb;
|
||||
unsigned int i, j;
|
||||
uint32_t length, staterr;
|
||||
u32 length, staterr;
|
||||
int cleaned_count = 0;
|
||||
bool cleaned = false;
|
||||
unsigned int total_rx_bytes=0, total_rx_packets=0;
|
||||
|
@ -4759,8 +4759,8 @@ no_buffers:
|
|||
static void
|
||||
e1000_smartspeed(struct e1000_adapter *adapter)
|
||||
{
|
||||
uint16_t phy_status;
|
||||
uint16_t phy_ctrl;
|
||||
u16 phy_status;
|
||||
u16 phy_ctrl;
|
||||
|
||||
if ((adapter->hw.phy_type != e1000_phy_igp) || !adapter->hw.autoneg ||
|
||||
!(adapter->hw.autoneg_advertised & ADVERTISE_1000_FULL))
|
||||
|
@ -4839,8 +4839,8 @@ e1000_mii_ioctl(struct net_device *netdev, struct ifreq *ifr, int cmd)
|
|||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
struct mii_ioctl_data *data = if_mii(ifr);
|
||||
int retval;
|
||||
uint16_t mii_reg;
|
||||
uint16_t spddplx;
|
||||
u16 mii_reg;
|
||||
u16 spddplx;
|
||||
unsigned long flags;
|
||||
|
||||
if (adapter->hw.media_type != e1000_media_type_copper)
|
||||
|
@ -4959,11 +4959,11 @@ e1000_pcix_set_mmrbc(struct e1000_hw *hw, int mmrbc)
|
|||
pcix_set_mmrbc(adapter->pdev, mmrbc);
|
||||
}
|
||||
|
||||
int32_t
|
||||
e1000_read_pcie_cap_reg(struct e1000_hw *hw, uint32_t reg, uint16_t *value)
|
||||
s32
|
||||
e1000_read_pcie_cap_reg(struct e1000_hw *hw, u32 reg, u16 *value)
|
||||
{
|
||||
struct e1000_adapter *adapter = hw->back;
|
||||
uint16_t cap_offset;
|
||||
u16 cap_offset;
|
||||
|
||||
cap_offset = pci_find_capability(adapter->pdev, PCI_CAP_ID_EXP);
|
||||
if (!cap_offset)
|
||||
|
@ -4975,7 +4975,7 @@ e1000_read_pcie_cap_reg(struct e1000_hw *hw, uint32_t reg, uint16_t *value)
|
|||
}
|
||||
|
||||
void
|
||||
e1000_io_write(struct e1000_hw *hw, unsigned long port, uint32_t value)
|
||||
e1000_io_write(struct e1000_hw *hw, unsigned long port, u32 value)
|
||||
{
|
||||
outl(value, port);
|
||||
}
|
||||
|
@ -4984,7 +4984,7 @@ static void
|
|||
e1000_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
uint32_t ctrl, rctl;
|
||||
u32 ctrl, rctl;
|
||||
|
||||
if (!test_bit(__E1000_DOWN, &adapter->flags))
|
||||
e1000_irq_disable(adapter);
|
||||
|
@ -5016,7 +5016,7 @@ e1000_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
|
|||
rctl &= ~E1000_RCTL_VFE;
|
||||
E1000_WRITE_REG(&adapter->hw, RCTL, rctl);
|
||||
if (adapter->mng_vlan_id !=
|
||||
(uint16_t)E1000_MNG_VLAN_NONE) {
|
||||
(u16)E1000_MNG_VLAN_NONE) {
|
||||
e1000_vlan_rx_kill_vid(netdev,
|
||||
adapter->mng_vlan_id);
|
||||
adapter->mng_vlan_id = E1000_MNG_VLAN_NONE;
|
||||
|
@ -5029,10 +5029,10 @@ e1000_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
|
|||
}
|
||||
|
||||
static void
|
||||
e1000_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid)
|
||||
e1000_vlan_rx_add_vid(struct net_device *netdev, u16 vid)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
uint32_t vfta, index;
|
||||
u32 vfta, index;
|
||||
|
||||
if ((adapter->hw.mng_cookie.status &
|
||||
E1000_MNG_DHCP_COOKIE_STATUS_VLAN_SUPPORT) &&
|
||||
|
@ -5046,10 +5046,10 @@ e1000_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid)
|
|||
}
|
||||
|
||||
static void
|
||||
e1000_vlan_rx_kill_vid(struct net_device *netdev, uint16_t vid)
|
||||
e1000_vlan_rx_kill_vid(struct net_device *netdev, u16 vid)
|
||||
{
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
uint32_t vfta, index;
|
||||
u32 vfta, index;
|
||||
|
||||
if (!test_bit(__E1000_DOWN, &adapter->flags))
|
||||
e1000_irq_disable(adapter);
|
||||
|
@ -5078,7 +5078,7 @@ e1000_restore_vlan(struct e1000_adapter *adapter)
|
|||
e1000_vlan_rx_register(adapter->netdev, adapter->vlgrp);
|
||||
|
||||
if (adapter->vlgrp) {
|
||||
uint16_t vid;
|
||||
u16 vid;
|
||||
for (vid = 0; vid < VLAN_GROUP_ARRAY_LEN; vid++) {
|
||||
if (!vlan_group_get_device(adapter->vlgrp, vid))
|
||||
continue;
|
||||
|
@ -5088,7 +5088,7 @@ e1000_restore_vlan(struct e1000_adapter *adapter)
|
|||
}
|
||||
|
||||
int
|
||||
e1000_set_spd_dplx(struct e1000_adapter *adapter, uint16_t spddplx)
|
||||
e1000_set_spd_dplx(struct e1000_adapter *adapter, u16 spddplx)
|
||||
{
|
||||
adapter->hw.autoneg = 0;
|
||||
|
||||
|
@ -5129,8 +5129,8 @@ e1000_suspend(struct pci_dev *pdev, pm_message_t state)
|
|||
{
|
||||
struct net_device *netdev = pci_get_drvdata(pdev);
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
uint32_t ctrl, ctrl_ext, rctl, status;
|
||||
uint32_t wufc = adapter->wol;
|
||||
u32 ctrl, ctrl_ext, rctl, status;
|
||||
u32 wufc = adapter->wol;
|
||||
#ifdef CONFIG_PM
|
||||
int retval = 0;
|
||||
#endif
|
||||
|
@ -5227,7 +5227,7 @@ e1000_resume(struct pci_dev *pdev)
|
|||
{
|
||||
struct net_device *netdev = pci_get_drvdata(pdev);
|
||||
struct e1000_adapter *adapter = netdev_priv(netdev);
|
||||
uint32_t err;
|
||||
u32 err;
|
||||
|
||||
pci_set_power_state(pdev, PCI_D0);
|
||||
pci_restore_state(pdev);
|
||||
|
|
|
@ -171,6 +171,10 @@ static s32 e1000_init_nvm_params_82571(struct e1000_hw *hw)
|
|||
* for setting word_size.
|
||||
*/
|
||||
size += NVM_WORD_SIZE_BASE_SHIFT;
|
||||
|
||||
/* EEPROM access above 16k is unsupported */
|
||||
if (size > 14)
|
||||
size = 14;
|
||||
nvm->word_size = 1 << size;
|
||||
break;
|
||||
}
|
||||
|
@ -244,7 +248,7 @@ static s32 e1000_init_mac_params_82571(struct e1000_adapter *adapter)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static s32 e1000_get_invariants_82571(struct e1000_adapter *adapter)
|
||||
static s32 e1000_get_variants_82571(struct e1000_adapter *adapter)
|
||||
{
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
static int global_quad_port_a; /* global port a indication */
|
||||
|
@ -832,19 +836,19 @@ static s32 e1000_init_hw_82571(struct e1000_hw *hw)
|
|||
ret_val = e1000_setup_link_82571(hw);
|
||||
|
||||
/* Set the transmit descriptor write-back policy */
|
||||
reg_data = er32(TXDCTL);
|
||||
reg_data = er32(TXDCTL(0));
|
||||
reg_data = (reg_data & ~E1000_TXDCTL_WTHRESH) |
|
||||
E1000_TXDCTL_FULL_TX_DESC_WB |
|
||||
E1000_TXDCTL_COUNT_DESC;
|
||||
ew32(TXDCTL, reg_data);
|
||||
ew32(TXDCTL(0), reg_data);
|
||||
|
||||
/* ...for both queues. */
|
||||
if (mac->type != e1000_82573) {
|
||||
reg_data = er32(TXDCTL1);
|
||||
reg_data = er32(TXDCTL(1));
|
||||
reg_data = (reg_data & ~E1000_TXDCTL_WTHRESH) |
|
||||
E1000_TXDCTL_FULL_TX_DESC_WB |
|
||||
E1000_TXDCTL_COUNT_DESC;
|
||||
ew32(TXDCTL1, reg_data);
|
||||
ew32(TXDCTL(1), reg_data);
|
||||
} else {
|
||||
e1000e_enable_tx_pkt_filtering(hw);
|
||||
reg_data = er32(GCR);
|
||||
|
@ -874,17 +878,17 @@ static void e1000_initialize_hw_bits_82571(struct e1000_hw *hw)
|
|||
u32 reg;
|
||||
|
||||
/* Transmit Descriptor Control 0 */
|
||||
reg = er32(TXDCTL);
|
||||
reg = er32(TXDCTL(0));
|
||||
reg |= (1 << 22);
|
||||
ew32(TXDCTL, reg);
|
||||
ew32(TXDCTL(0), reg);
|
||||
|
||||
/* Transmit Descriptor Control 1 */
|
||||
reg = er32(TXDCTL1);
|
||||
reg = er32(TXDCTL(1));
|
||||
reg |= (1 << 22);
|
||||
ew32(TXDCTL1, reg);
|
||||
ew32(TXDCTL(1), reg);
|
||||
|
||||
/* Transmit Arbitration Control 0 */
|
||||
reg = er32(TARC0);
|
||||
reg = er32(TARC(0));
|
||||
reg &= ~(0xF << 27); /* 30:27 */
|
||||
switch (hw->mac.type) {
|
||||
case e1000_82571:
|
||||
|
@ -894,10 +898,10 @@ static void e1000_initialize_hw_bits_82571(struct e1000_hw *hw)
|
|||
default:
|
||||
break;
|
||||
}
|
||||
ew32(TARC0, reg);
|
||||
ew32(TARC(0), reg);
|
||||
|
||||
/* Transmit Arbitration Control 1 */
|
||||
reg = er32(TARC1);
|
||||
reg = er32(TARC(1));
|
||||
switch (hw->mac.type) {
|
||||
case e1000_82571:
|
||||
case e1000_82572:
|
||||
|
@ -907,7 +911,7 @@ static void e1000_initialize_hw_bits_82571(struct e1000_hw *hw)
|
|||
reg &= ~(1 << 28);
|
||||
else
|
||||
reg |= (1 << 28);
|
||||
ew32(TARC1, reg);
|
||||
ew32(TARC(1), reg);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
|
@ -1333,7 +1337,7 @@ struct e1000_info e1000_82571_info = {
|
|||
| FLAG_TARC_SPEED_MODE_BIT /* errata */
|
||||
| FLAG_APME_CHECK_PORT_B,
|
||||
.pba = 38,
|
||||
.get_invariants = e1000_get_invariants_82571,
|
||||
.get_variants = e1000_get_variants_82571,
|
||||
.mac_ops = &e82571_mac_ops,
|
||||
.phy_ops = &e82_phy_ops_igp,
|
||||
.nvm_ops = &e82571_nvm_ops,
|
||||
|
@ -1351,7 +1355,7 @@ struct e1000_info e1000_82572_info = {
|
|||
| FLAG_HAS_STATS_ICR_ICT
|
||||
| FLAG_TARC_SPEED_MODE_BIT, /* errata */
|
||||
.pba = 38,
|
||||
.get_invariants = e1000_get_invariants_82571,
|
||||
.get_variants = e1000_get_variants_82571,
|
||||
.mac_ops = &e82571_mac_ops,
|
||||
.phy_ops = &e82_phy_ops_igp,
|
||||
.nvm_ops = &e82571_nvm_ops,
|
||||
|
@ -1371,7 +1375,7 @@ struct e1000_info e1000_82573_info = {
|
|||
| FLAG_HAS_ERT
|
||||
| FLAG_HAS_SWSM_ON_LOAD,
|
||||
.pba = 20,
|
||||
.get_invariants = e1000_get_invariants_82571,
|
||||
.get_variants = e1000_get_variants_82571,
|
||||
.mac_ops = &e82571_mac_ops,
|
||||
.phy_ops = &e82_phy_ops_m88,
|
||||
.nvm_ops = &e82571_nvm_ops,
|
||||
|
|
|
@ -271,7 +271,7 @@ struct e1000_info {
|
|||
enum e1000_mac_type mac;
|
||||
unsigned int flags;
|
||||
u32 pba;
|
||||
s32 (*get_invariants)(struct e1000_adapter *);
|
||||
s32 (*get_variants)(struct e1000_adapter *);
|
||||
struct e1000_mac_operations *mac_ops;
|
||||
struct e1000_phy_operations *phy_ops;
|
||||
struct e1000_nvm_operations *nvm_ops;
|
||||
|
@ -357,7 +357,7 @@ extern struct e1000_info e1000_ich8_info;
|
|||
extern struct e1000_info e1000_ich9_info;
|
||||
extern struct e1000_info e1000_es2_info;
|
||||
|
||||
extern s32 e1000e_read_part_num(struct e1000_hw *hw, u32 *part_num);
|
||||
extern s32 e1000e_read_pba_num(struct e1000_hw *hw, u32 *pba_num);
|
||||
|
||||
extern s32 e1000e_commit_phy(struct e1000_hw *hw);
|
||||
|
||||
|
|
|
@ -178,6 +178,10 @@ static s32 e1000_init_nvm_params_80003es2lan(struct e1000_hw *hw)
|
|||
* for setting word_size.
|
||||
*/
|
||||
size += NVM_WORD_SIZE_BASE_SHIFT;
|
||||
|
||||
/* EEPROM access above 16k is unsupported */
|
||||
if (size > 14)
|
||||
size = 14;
|
||||
nvm->word_size = 1 << size;
|
||||
|
||||
return 0;
|
||||
|
@ -234,7 +238,7 @@ static s32 e1000_init_mac_params_80003es2lan(struct e1000_adapter *adapter)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static s32 e1000_get_invariants_80003es2lan(struct e1000_adapter *adapter)
|
||||
static s32 e1000_get_variants_80003es2lan(struct e1000_adapter *adapter)
|
||||
{
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
s32 rc;
|
||||
|
@ -788,16 +792,16 @@ static s32 e1000_init_hw_80003es2lan(struct e1000_hw *hw)
|
|||
ret_val = e1000e_setup_link(hw);
|
||||
|
||||
/* Set the transmit descriptor write-back policy */
|
||||
reg_data = er32(TXDCTL);
|
||||
reg_data = er32(TXDCTL(0));
|
||||
reg_data = (reg_data & ~E1000_TXDCTL_WTHRESH) |
|
||||
E1000_TXDCTL_FULL_TX_DESC_WB | E1000_TXDCTL_COUNT_DESC;
|
||||
ew32(TXDCTL, reg_data);
|
||||
ew32(TXDCTL(0), reg_data);
|
||||
|
||||
/* ...for both queues. */
|
||||
reg_data = er32(TXDCTL1);
|
||||
reg_data = er32(TXDCTL(1));
|
||||
reg_data = (reg_data & ~E1000_TXDCTL_WTHRESH) |
|
||||
E1000_TXDCTL_FULL_TX_DESC_WB | E1000_TXDCTL_COUNT_DESC;
|
||||
ew32(TXDCTL1, reg_data);
|
||||
ew32(TXDCTL(1), reg_data);
|
||||
|
||||
/* Enable retransmit on late collisions */
|
||||
reg_data = er32(TCTL);
|
||||
|
@ -842,29 +846,29 @@ static void e1000_initialize_hw_bits_80003es2lan(struct e1000_hw *hw)
|
|||
u32 reg;
|
||||
|
||||
/* Transmit Descriptor Control 0 */
|
||||
reg = er32(TXDCTL);
|
||||
reg = er32(TXDCTL(0));
|
||||
reg |= (1 << 22);
|
||||
ew32(TXDCTL, reg);
|
||||
ew32(TXDCTL(0), reg);
|
||||
|
||||
/* Transmit Descriptor Control 1 */
|
||||
reg = er32(TXDCTL1);
|
||||
reg = er32(TXDCTL(1));
|
||||
reg |= (1 << 22);
|
||||
ew32(TXDCTL1, reg);
|
||||
ew32(TXDCTL(1), reg);
|
||||
|
||||
/* Transmit Arbitration Control 0 */
|
||||
reg = er32(TARC0);
|
||||
reg = er32(TARC(0));
|
||||
reg &= ~(0xF << 27); /* 30:27 */
|
||||
if (hw->phy.media_type != e1000_media_type_copper)
|
||||
reg &= ~(1 << 20);
|
||||
ew32(TARC0, reg);
|
||||
ew32(TARC(0), reg);
|
||||
|
||||
/* Transmit Arbitration Control 1 */
|
||||
reg = er32(TARC1);
|
||||
reg = er32(TARC(1));
|
||||
if (er32(TCTL) & E1000_TCTL_MULR)
|
||||
reg &= ~(1 << 28);
|
||||
else
|
||||
reg |= (1 << 28);
|
||||
ew32(TARC1, reg);
|
||||
ew32(TARC(1), reg);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1239,7 +1243,7 @@ struct e1000_info e1000_es2_info = {
|
|||
| FLAG_DISABLE_FC_PAUSE_TIME /* errata */
|
||||
| FLAG_TIPG_MEDIUM_FOR_80003ESLAN,
|
||||
.pba = 38,
|
||||
.get_invariants = e1000_get_invariants_80003es2lan,
|
||||
.get_variants = e1000_get_variants_80003es2lan,
|
||||
.mac_ops = &es2_mac_ops,
|
||||
.phy_ops = &es2_phy_ops,
|
||||
.nvm_ops = &es2_nvm_ops,
|
||||
|
|
|
@ -641,10 +641,17 @@ static int e1000_set_ringparam(struct net_device *netdev,
|
|||
tx_ring = kzalloc(sizeof(struct e1000_ring), GFP_KERNEL);
|
||||
if (!tx_ring)
|
||||
goto err_alloc_tx;
|
||||
/*
|
||||
* use a memcpy to save any previously configured
|
||||
* items like napi structs from having to be
|
||||
* reinitialized
|
||||
*/
|
||||
memcpy(tx_ring, tx_old, sizeof(struct e1000_ring));
|
||||
|
||||
rx_ring = kzalloc(sizeof(struct e1000_ring), GFP_KERNEL);
|
||||
if (!rx_ring)
|
||||
goto err_alloc_rx;
|
||||
memcpy(rx_ring, rx_old, sizeof(struct e1000_ring));
|
||||
|
||||
adapter->tx_ring = tx_ring;
|
||||
adapter->rx_ring = rx_ring;
|
||||
|
@ -700,61 +707,55 @@ err_setup:
|
|||
return err;
|
||||
}
|
||||
|
||||
static bool reg_pattern_test_array(struct e1000_adapter *adapter, u64 *data,
|
||||
int reg, int offset, u32 mask, u32 write)
|
||||
static bool reg_pattern_test(struct e1000_adapter *adapter, u64 *data,
|
||||
int reg, int offset, u32 mask, u32 write)
|
||||
{
|
||||
int i;
|
||||
u32 read;
|
||||
u32 pat, val;
|
||||
static const u32 test[] =
|
||||
{0x5A5A5A5A, 0xA5A5A5A5, 0x00000000, 0xFFFFFFFF};
|
||||
for (i = 0; i < ARRAY_SIZE(test); i++) {
|
||||
for (pat = 0; pat < ARRAY_SIZE(test); pat++) {
|
||||
E1000_WRITE_REG_ARRAY(&adapter->hw, reg, offset,
|
||||
(test[i] & write));
|
||||
read = E1000_READ_REG_ARRAY(&adapter->hw, reg, offset);
|
||||
if (read != (test[i] & write & mask)) {
|
||||
(test[pat] & write));
|
||||
val = E1000_READ_REG_ARRAY(&adapter->hw, reg, offset);
|
||||
if (val != (test[pat] & write & mask)) {
|
||||
ndev_err(adapter->netdev, "pattern test reg %04X "
|
||||
"failed: got 0x%08X expected 0x%08X\n",
|
||||
reg + offset,
|
||||
read, (test[i] & write & mask));
|
||||
val, (test[pat] & write & mask));
|
||||
*data = reg;
|
||||
return true;
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static bool reg_set_and_check(struct e1000_adapter *adapter, u64 *data,
|
||||
int reg, u32 mask, u32 write)
|
||||
{
|
||||
u32 read;
|
||||
u32 val;
|
||||
__ew32(&adapter->hw, reg, write & mask);
|
||||
read = __er32(&adapter->hw, reg);
|
||||
if ((write & mask) != (read & mask)) {
|
||||
val = __er32(&adapter->hw, reg);
|
||||
if ((write & mask) != (val & mask)) {
|
||||
ndev_err(adapter->netdev, "set/check reg %04X test failed: "
|
||||
"got 0x%08X expected 0x%08X\n", reg, (read & mask),
|
||||
"got 0x%08X expected 0x%08X\n", reg, (val & mask),
|
||||
(write & mask));
|
||||
*data = reg;
|
||||
return true;
|
||||
return 1;
|
||||
}
|
||||
return false;
|
||||
return 0;
|
||||
}
|
||||
|
||||
#define REG_PATTERN_TEST(R, M, W) \
|
||||
do { \
|
||||
if (reg_pattern_test_array(adapter, data, R, 0, M, W)) \
|
||||
return 1; \
|
||||
#define REG_PATTERN_TEST_ARRAY(reg, offset, mask, write) \
|
||||
do { \
|
||||
if (reg_pattern_test(adapter, data, reg, offset, mask, write)) \
|
||||
return 1; \
|
||||
} while (0)
|
||||
#define REG_PATTERN_TEST(reg, mask, write) \
|
||||
REG_PATTERN_TEST_ARRAY(reg, 0, mask, write)
|
||||
|
||||
#define REG_PATTERN_TEST_ARRAY(R, offset, M, W) \
|
||||
do { \
|
||||
if (reg_pattern_test_array(adapter, data, R, offset, M, W)) \
|
||||
return 1; \
|
||||
} while (0)
|
||||
|
||||
#define REG_SET_AND_CHECK(R, M, W) \
|
||||
do { \
|
||||
if (reg_set_and_check(adapter, data, R, M, W)) \
|
||||
return 1; \
|
||||
#define REG_SET_AND_CHECK(reg, mask, write) \
|
||||
do { \
|
||||
if (reg_set_and_check(adapter, data, reg, mask, write)) \
|
||||
return 1; \
|
||||
} while (0)
|
||||
|
||||
static int e1000_reg_test(struct e1000_adapter *adapter, u64 *data)
|
||||
|
@ -1038,7 +1039,6 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter)
|
|||
struct pci_dev *pdev = adapter->pdev;
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
u32 rctl;
|
||||
int size;
|
||||
int i;
|
||||
int ret_val;
|
||||
|
||||
|
@ -1047,13 +1047,13 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter)
|
|||
if (!tx_ring->count)
|
||||
tx_ring->count = E1000_DEFAULT_TXD;
|
||||
|
||||
size = tx_ring->count * sizeof(struct e1000_buffer);
|
||||
tx_ring->buffer_info = kmalloc(size, GFP_KERNEL);
|
||||
if (!tx_ring->buffer_info) {
|
||||
tx_ring->buffer_info = kcalloc(tx_ring->count,
|
||||
sizeof(struct e1000_buffer),
|
||||
GFP_KERNEL);
|
||||
if (!(tx_ring->buffer_info)) {
|
||||
ret_val = 1;
|
||||
goto err_nomem;
|
||||
}
|
||||
memset(tx_ring->buffer_info, 0, size);
|
||||
|
||||
tx_ring->size = tx_ring->count * sizeof(struct e1000_tx_desc);
|
||||
tx_ring->size = ALIGN(tx_ring->size, 4096);
|
||||
|
@ -1063,21 +1063,17 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter)
|
|||
ret_val = 2;
|
||||
goto err_nomem;
|
||||
}
|
||||
memset(tx_ring->desc, 0, tx_ring->size);
|
||||
tx_ring->next_to_use = 0;
|
||||
tx_ring->next_to_clean = 0;
|
||||
|
||||
ew32(TDBAL,
|
||||
((u64) tx_ring->dma & 0x00000000FFFFFFFF));
|
||||
ew32(TDBAL, ((u64) tx_ring->dma & 0x00000000FFFFFFFF));
|
||||
ew32(TDBAH, ((u64) tx_ring->dma >> 32));
|
||||
ew32(TDLEN,
|
||||
tx_ring->count * sizeof(struct e1000_tx_desc));
|
||||
ew32(TDLEN, tx_ring->count * sizeof(struct e1000_tx_desc));
|
||||
ew32(TDH, 0);
|
||||
ew32(TDT, 0);
|
||||
ew32(TCTL,
|
||||
E1000_TCTL_PSP | E1000_TCTL_EN |
|
||||
E1000_COLLISION_THRESHOLD << E1000_CT_SHIFT |
|
||||
E1000_COLLISION_DISTANCE << E1000_COLD_SHIFT);
|
||||
ew32(TCTL, E1000_TCTL_PSP | E1000_TCTL_EN | E1000_TCTL_MULR |
|
||||
E1000_COLLISION_THRESHOLD << E1000_CT_SHIFT |
|
||||
E1000_COLLISION_DISTANCE << E1000_COLD_SHIFT);
|
||||
|
||||
for (i = 0; i < tx_ring->count; i++) {
|
||||
struct e1000_tx_desc *tx_desc = E1000_TX_DESC(*tx_ring, i);
|
||||
|
@ -1099,12 +1095,11 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter)
|
|||
ret_val = 4;
|
||||
goto err_nomem;
|
||||
}
|
||||
tx_desc->buffer_addr = cpu_to_le64(
|
||||
tx_ring->buffer_info[i].dma);
|
||||
tx_desc->buffer_addr = cpu_to_le64(tx_ring->buffer_info[i].dma);
|
||||
tx_desc->lower.data = cpu_to_le32(skb->len);
|
||||
tx_desc->lower.data |= cpu_to_le32(E1000_TXD_CMD_EOP |
|
||||
E1000_TXD_CMD_IFCS |
|
||||
E1000_TXD_CMD_RPS);
|
||||
E1000_TXD_CMD_RS);
|
||||
tx_desc->upper.data = 0;
|
||||
}
|
||||
|
||||
|
@ -1113,13 +1108,13 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter)
|
|||
if (!rx_ring->count)
|
||||
rx_ring->count = E1000_DEFAULT_RXD;
|
||||
|
||||
size = rx_ring->count * sizeof(struct e1000_buffer);
|
||||
rx_ring->buffer_info = kmalloc(size, GFP_KERNEL);
|
||||
if (!rx_ring->buffer_info) {
|
||||
rx_ring->buffer_info = kcalloc(rx_ring->count,
|
||||
sizeof(struct e1000_buffer),
|
||||
GFP_KERNEL);
|
||||
if (!(rx_ring->buffer_info)) {
|
||||
ret_val = 5;
|
||||
goto err_nomem;
|
||||
}
|
||||
memset(rx_ring->buffer_info, 0, size);
|
||||
|
||||
rx_ring->size = rx_ring->count * sizeof(struct e1000_rx_desc);
|
||||
rx_ring->desc = dma_alloc_coherent(&pdev->dev, rx_ring->size,
|
||||
|
@ -1128,7 +1123,6 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter)
|
|||
ret_val = 6;
|
||||
goto err_nomem;
|
||||
}
|
||||
memset(rx_ring->desc, 0, rx_ring->size);
|
||||
rx_ring->next_to_use = 0;
|
||||
rx_ring->next_to_clean = 0;
|
||||
|
||||
|
@ -1140,6 +1134,8 @@ static int e1000_setup_desc_rings(struct e1000_adapter *adapter)
|
|||
ew32(RDH, 0);
|
||||
ew32(RDT, 0);
|
||||
rctl = E1000_RCTL_EN | E1000_RCTL_BAM | E1000_RCTL_SZ_2048 |
|
||||
E1000_RCTL_UPE | E1000_RCTL_MPE | E1000_RCTL_LPE |
|
||||
E1000_RCTL_SBP | E1000_RCTL_SECRC |
|
||||
E1000_RCTL_LBM_NO | E1000_RCTL_RDMTS_HALF |
|
||||
(adapter->hw.mac.mc_filter_type << E1000_RCTL_MO_SHIFT);
|
||||
ew32(RCTL, rctl);
|
||||
|
@ -1203,7 +1199,8 @@ static int e1000_integrated_phy_loopback(struct e1000_adapter *adapter)
|
|||
|
||||
ctrl_reg = er32(CTRL);
|
||||
|
||||
if (hw->phy.type == e1000_phy_ife) {
|
||||
switch (hw->phy.type) {
|
||||
case e1000_phy_ife:
|
||||
/* force 100, set loopback */
|
||||
e1e_wphy(hw, PHY_CONTROL, 0x6100);
|
||||
|
||||
|
@ -1213,9 +1210,11 @@ static int e1000_integrated_phy_loopback(struct e1000_adapter *adapter)
|
|||
E1000_CTRL_FRCDPX | /* Set the Force Duplex Bit */
|
||||
E1000_CTRL_SPD_100 |/* Force Speed to 100 */
|
||||
E1000_CTRL_FD); /* Force Duplex to FULL */
|
||||
} else {
|
||||
break;
|
||||
default:
|
||||
/* force 1000, set loopback */
|
||||
e1e_wphy(hw, PHY_CONTROL, 0x4140);
|
||||
mdelay(250);
|
||||
|
||||
/* Now set up the MAC to the same speed/duplex as the PHY. */
|
||||
ctrl_reg = er32(CTRL);
|
||||
|
@ -1224,6 +1223,10 @@ static int e1000_integrated_phy_loopback(struct e1000_adapter *adapter)
|
|||
E1000_CTRL_FRCDPX | /* Set the Force Duplex Bit */
|
||||
E1000_CTRL_SPD_1000 |/* Force Speed to 1000 */
|
||||
E1000_CTRL_FD); /* Force Duplex to FULL */
|
||||
|
||||
if ((adapter->hw.mac.type == e1000_ich8lan) ||
|
||||
(adapter->hw.mac.type == e1000_ich9lan))
|
||||
ctrl_reg |= E1000_CTRL_SLU; /* Set Link Up */
|
||||
}
|
||||
|
||||
if (hw->phy.media_type == e1000_media_type_copper &&
|
||||
|
@ -1325,7 +1328,7 @@ static int e1000_set_es2lan_mac_loopback(struct e1000_adapter *adapter)
|
|||
#define KMRNCTRLSTA_OPMODE (0x1F << 16)
|
||||
#define KMRNCTRLSTA_OPMODE_1GB_FD_GMII 0x0582
|
||||
ew32(KMRNCTRLSTA,
|
||||
(KMRNCTRLSTA_OPMODE | KMRNCTRLSTA_OPMODE_1GB_FD_GMII));
|
||||
(KMRNCTRLSTA_OPMODE | KMRNCTRLSTA_OPMODE_1GB_FD_GMII));
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -1451,8 +1454,8 @@ static int e1000_run_loopback_test(struct e1000_adapter *adapter)
|
|||
l = 0;
|
||||
for (j = 0; j <= lc; j++) { /* loop count loop */
|
||||
for (i = 0; i < 64; i++) { /* send the packets */
|
||||
e1000_create_lbtest_frame(
|
||||
tx_ring->buffer_info[i].skb, 1024);
|
||||
e1000_create_lbtest_frame(tx_ring->buffer_info[k].skb,
|
||||
1024);
|
||||
pci_dma_sync_single_for_device(pdev,
|
||||
tx_ring->buffer_info[k].dma,
|
||||
tx_ring->buffer_info[k].length,
|
||||
|
@ -1487,7 +1490,7 @@ static int e1000_run_loopback_test(struct e1000_adapter *adapter)
|
|||
ret_val = 13; /* ret_val is the same as mis-compare */
|
||||
break;
|
||||
}
|
||||
if (jiffies >= (time + 2)) {
|
||||
if (jiffies >= (time + 20)) {
|
||||
ret_val = 14; /* error code for time out error */
|
||||
break;
|
||||
}
|
||||
|
|
|
@ -93,6 +93,8 @@ enum e1e_registers {
|
|||
E1000_RDH = 0x02810, /* Rx Descriptor Head - RW */
|
||||
E1000_RDT = 0x02818, /* Rx Descriptor Tail - RW */
|
||||
E1000_RDTR = 0x02820, /* Rx Delay Timer - RW */
|
||||
E1000_RXDCTL_BASE = 0x02828, /* Rx Descriptor Control - RW */
|
||||
#define E1000_RXDCTL(_n) (E1000_RXDCTL_BASE + (_n << 8))
|
||||
E1000_RADV = 0x0282C, /* RX Interrupt Absolute Delay Timer - RW */
|
||||
|
||||
/* Convenience macros
|
||||
|
@ -111,11 +113,11 @@ enum e1e_registers {
|
|||
E1000_TDH = 0x03810, /* Tx Descriptor Head - RW */
|
||||
E1000_TDT = 0x03818, /* Tx Descriptor Tail - RW */
|
||||
E1000_TIDV = 0x03820, /* Tx Interrupt Delay Value - RW */
|
||||
E1000_TXDCTL = 0x03828, /* Tx Descriptor Control - RW */
|
||||
E1000_TXDCTL_BASE = 0x03828, /* Tx Descriptor Control - RW */
|
||||
#define E1000_TXDCTL(_n) (E1000_TXDCTL_BASE + (_n << 8))
|
||||
E1000_TADV = 0x0382C, /* Tx Interrupt Absolute Delay Val - RW */
|
||||
E1000_TARC0 = 0x03840, /* Tx Arbitration Count (0) */
|
||||
E1000_TXDCTL1 = 0x03928, /* Tx Descriptor Control (1) - RW */
|
||||
E1000_TARC1 = 0x03940, /* Tx Arbitration Count (1) */
|
||||
E1000_TARC_BASE = 0x03840, /* Tx Arbitration Count (0) */
|
||||
#define E1000_TARC(_n) (E1000_TARC_BASE + (_n << 8))
|
||||
E1000_CRCERRS = 0x04000, /* CRC Error Count - R/clr */
|
||||
E1000_ALGNERRC = 0x04004, /* Alignment Error Count - R/clr */
|
||||
E1000_SYMERRS = 0x04008, /* Symbol Error Count - R/clr */
|
||||
|
|
|
@ -316,7 +316,7 @@ static s32 e1000_init_mac_params_ich8lan(struct e1000_adapter *adapter)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static s32 e1000_get_invariants_ich8lan(struct e1000_adapter *adapter)
|
||||
static s32 e1000_get_variants_ich8lan(struct e1000_adapter *adapter)
|
||||
{
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
s32 rc;
|
||||
|
@ -1753,18 +1753,18 @@ static s32 e1000_init_hw_ich8lan(struct e1000_hw *hw)
|
|||
ret_val = e1000_setup_link_ich8lan(hw);
|
||||
|
||||
/* Set the transmit descriptor write-back policy for both queues */
|
||||
txdctl = er32(TXDCTL);
|
||||
txdctl = er32(TXDCTL(0));
|
||||
txdctl = (txdctl & ~E1000_TXDCTL_WTHRESH) |
|
||||
E1000_TXDCTL_FULL_TX_DESC_WB;
|
||||
txdctl = (txdctl & ~E1000_TXDCTL_PTHRESH) |
|
||||
E1000_TXDCTL_MAX_TX_DESC_PREFETCH;
|
||||
ew32(TXDCTL, txdctl);
|
||||
txdctl = er32(TXDCTL1);
|
||||
ew32(TXDCTL(0), txdctl);
|
||||
txdctl = er32(TXDCTL(1));
|
||||
txdctl = (txdctl & ~E1000_TXDCTL_WTHRESH) |
|
||||
E1000_TXDCTL_FULL_TX_DESC_WB;
|
||||
txdctl = (txdctl & ~E1000_TXDCTL_PTHRESH) |
|
||||
E1000_TXDCTL_MAX_TX_DESC_PREFETCH;
|
||||
ew32(TXDCTL1, txdctl);
|
||||
ew32(TXDCTL(1), txdctl);
|
||||
|
||||
/*
|
||||
* ICH8 has opposite polarity of no_snoop bits.
|
||||
|
@ -1807,30 +1807,30 @@ static void e1000_initialize_hw_bits_ich8lan(struct e1000_hw *hw)
|
|||
ew32(CTRL_EXT, reg);
|
||||
|
||||
/* Transmit Descriptor Control 0 */
|
||||
reg = er32(TXDCTL);
|
||||
reg = er32(TXDCTL(0));
|
||||
reg |= (1 << 22);
|
||||
ew32(TXDCTL, reg);
|
||||
ew32(TXDCTL(0), reg);
|
||||
|
||||
/* Transmit Descriptor Control 1 */
|
||||
reg = er32(TXDCTL1);
|
||||
reg = er32(TXDCTL(1));
|
||||
reg |= (1 << 22);
|
||||
ew32(TXDCTL1, reg);
|
||||
ew32(TXDCTL(1), reg);
|
||||
|
||||
/* Transmit Arbitration Control 0 */
|
||||
reg = er32(TARC0);
|
||||
reg = er32(TARC(0));
|
||||
if (hw->mac.type == e1000_ich8lan)
|
||||
reg |= (1 << 28) | (1 << 29);
|
||||
reg |= (1 << 23) | (1 << 24) | (1 << 26) | (1 << 27);
|
||||
ew32(TARC0, reg);
|
||||
ew32(TARC(0), reg);
|
||||
|
||||
/* Transmit Arbitration Control 1 */
|
||||
reg = er32(TARC1);
|
||||
reg = er32(TARC(1));
|
||||
if (er32(TCTL) & E1000_TCTL_MULR)
|
||||
reg &= ~(1 << 28);
|
||||
else
|
||||
reg |= (1 << 28);
|
||||
reg |= (1 << 24) | (1 << 26) | (1 << 30);
|
||||
ew32(TARC1, reg);
|
||||
ew32(TARC(1), reg);
|
||||
|
||||
/* Device Status */
|
||||
if (hw->mac.type == e1000_ich8lan) {
|
||||
|
@ -2253,7 +2253,7 @@ struct e1000_info e1000_ich8_info = {
|
|||
| FLAG_HAS_FLASH
|
||||
| FLAG_APME_IN_WUC,
|
||||
.pba = 8,
|
||||
.get_invariants = e1000_get_invariants_ich8lan,
|
||||
.get_variants = e1000_get_variants_ich8lan,
|
||||
.mac_ops = &ich8_mac_ops,
|
||||
.phy_ops = &ich8_phy_ops,
|
||||
.nvm_ops = &ich8_nvm_ops,
|
||||
|
@ -2270,7 +2270,7 @@ struct e1000_info e1000_ich9_info = {
|
|||
| FLAG_HAS_FLASH
|
||||
| FLAG_APME_IN_WUC,
|
||||
.pba = 10,
|
||||
.get_invariants = e1000_get_invariants_ich8lan,
|
||||
.get_variants = e1000_get_variants_ich8lan,
|
||||
.mac_ops = &ich8_mac_ops,
|
||||
.phy_ops = &ich8_phy_ops,
|
||||
.nvm_ops = &ich8_nvm_ops,
|
||||
|
|
|
@ -2477,7 +2477,7 @@ bool e1000e_enable_mng_pass_thru(struct e1000_hw *hw)
|
|||
return ret_val;
|
||||
}
|
||||
|
||||
s32 e1000e_read_part_num(struct e1000_hw *hw, u32 *part_num)
|
||||
s32 e1000e_read_pba_num(struct e1000_hw *hw, u32 *pba_num)
|
||||
{
|
||||
s32 ret_val;
|
||||
u16 nvm_data;
|
||||
|
@ -2487,14 +2487,14 @@ s32 e1000e_read_part_num(struct e1000_hw *hw, u32 *part_num)
|
|||
hw_dbg(hw, "NVM Read Error\n");
|
||||
return ret_val;
|
||||
}
|
||||
*part_num = (u32)(nvm_data << 16);
|
||||
*pba_num = (u32)(nvm_data << 16);
|
||||
|
||||
ret_val = e1000_read_nvm(hw, NVM_PBA_OFFSET_1, 1, &nvm_data);
|
||||
if (ret_val) {
|
||||
hw_dbg(hw, "NVM Read Error\n");
|
||||
return ret_val;
|
||||
}
|
||||
*part_num |= nvm_data;
|
||||
*pba_num |= nvm_data;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -1639,24 +1639,24 @@ static void e1000_configure_tx(struct e1000_adapter *adapter)
|
|||
(E1000_COLLISION_THRESHOLD << E1000_CT_SHIFT);
|
||||
|
||||
if (adapter->flags & FLAG_TARC_SPEED_MODE_BIT) {
|
||||
tarc = er32(TARC0);
|
||||
tarc = er32(TARC(0));
|
||||
/*
|
||||
* set the speed mode bit, we'll clear it if we're not at
|
||||
* gigabit link later
|
||||
*/
|
||||
#define SPEED_MODE_BIT (1 << 21)
|
||||
tarc |= SPEED_MODE_BIT;
|
||||
ew32(TARC0, tarc);
|
||||
ew32(TARC(0), tarc);
|
||||
}
|
||||
|
||||
/* errata: program both queues to unweighted RR */
|
||||
if (adapter->flags & FLAG_TARC_SET_BIT_ZERO) {
|
||||
tarc = er32(TARC0);
|
||||
tarc = er32(TARC(0));
|
||||
tarc |= 1;
|
||||
ew32(TARC0, tarc);
|
||||
tarc = er32(TARC1);
|
||||
ew32(TARC(0), tarc);
|
||||
tarc = er32(TARC(1));
|
||||
tarc |= 1;
|
||||
ew32(TARC1, tarc);
|
||||
ew32(TARC(1), tarc);
|
||||
}
|
||||
|
||||
e1000e_config_collision_dist(hw);
|
||||
|
@ -2775,9 +2775,9 @@ static void e1000_watchdog_task(struct work_struct *work)
|
|||
if ((adapter->flags & FLAG_TARC_SPEED_MODE_BIT) &&
|
||||
!txb2b) {
|
||||
u32 tarc0;
|
||||
tarc0 = er32(TARC0);
|
||||
tarc0 = er32(TARC(0));
|
||||
tarc0 &= ~SPEED_MODE_BIT;
|
||||
ew32(TARC0, tarc0);
|
||||
ew32(TARC(0), tarc0);
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -3824,7 +3824,7 @@ static void e1000_print_device_info(struct e1000_adapter *adapter)
|
|||
{
|
||||
struct e1000_hw *hw = &adapter->hw;
|
||||
struct net_device *netdev = adapter->netdev;
|
||||
u32 part_num;
|
||||
u32 pba_num;
|
||||
|
||||
/* print bus type/speed/width info */
|
||||
ndev_info(netdev, "(PCI Express:2.5GB/s:%s) "
|
||||
|
@ -3839,10 +3839,10 @@ static void e1000_print_device_info(struct e1000_adapter *adapter)
|
|||
ndev_info(netdev, "Intel(R) PRO/%s Network Connection\n",
|
||||
(hw->phy.type == e1000_phy_ife)
|
||||
? "10/100" : "1000");
|
||||
e1000e_read_part_num(hw, &part_num);
|
||||
e1000e_read_pba_num(hw, &pba_num);
|
||||
ndev_info(netdev, "MAC: %d, PHY: %d, PBA No: %06x-%03x\n",
|
||||
hw->mac.type, hw->phy.type,
|
||||
(part_num >> 8), (part_num & 0xff));
|
||||
(pba_num >> 8), (pba_num & 0xff));
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -3974,7 +3974,7 @@ static int __devinit e1000_probe(struct pci_dev *pdev,
|
|||
memcpy(&hw->nvm.ops, ei->nvm_ops, sizeof(hw->nvm.ops));
|
||||
memcpy(&hw->phy.ops, ei->phy_ops, sizeof(hw->phy.ops));
|
||||
|
||||
err = ei->get_invariants(adapter);
|
||||
err = ei->get_variants(adapter);
|
||||
if (err)
|
||||
goto err_hw_init;
|
||||
|
||||
|
|
|
@ -198,7 +198,7 @@ static int mpc52xx_fec_init_phy(struct net_device *dev)
|
|||
struct phy_device *phydev;
|
||||
char phy_id[BUS_ID_SIZE];
|
||||
|
||||
snprintf(phy_id, BUS_ID_SIZE, PHY_ID_FMT,
|
||||
snprintf(phy_id, BUS_ID_SIZE, "%x:%02x",
|
||||
(unsigned int)dev->base_addr, priv->phy_addr);
|
||||
|
||||
priv->link = PHY_DOWN;
|
||||
|
|
|
@ -124,7 +124,7 @@ static int mpc52xx_fec_mdio_probe(struct of_device *of, const struct of_device_i
|
|||
goto out_free;
|
||||
}
|
||||
|
||||
bus->id = res.start;
|
||||
snprintf(bus->id, MII_BUS_ID_SIZE, "%x", res.start);
|
||||
bus->priv = priv;
|
||||
|
||||
bus->dev = dev;
|
||||
|
|
|
@ -29,90 +29,6 @@
|
|||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
*
|
||||
* Changelog:
|
||||
* 0.01: 05 Oct 2003: First release that compiles without warnings.
|
||||
* 0.02: 05 Oct 2003: Fix bug for nv_drain_tx: do not try to free NULL skbs.
|
||||
* Check all PCI BARs for the register window.
|
||||
* udelay added to mii_rw.
|
||||
* 0.03: 06 Oct 2003: Initialize dev->irq.
|
||||
* 0.04: 07 Oct 2003: Initialize np->lock, reduce handled irqs, add printks.
|
||||
* 0.05: 09 Oct 2003: printk removed again, irq status print tx_timeout.
|
||||
* 0.06: 10 Oct 2003: MAC Address read updated, pff flag generation updated,
|
||||
* irq mask updated
|
||||
* 0.07: 14 Oct 2003: Further irq mask updates.
|
||||
* 0.08: 20 Oct 2003: rx_desc.Length initialization added, nv_alloc_rx refill
|
||||
* added into irq handler, NULL check for drain_ring.
|
||||
* 0.09: 20 Oct 2003: Basic link speed irq implementation. Only handle the
|
||||
* requested interrupt sources.
|
||||
* 0.10: 20 Oct 2003: First cleanup for release.
|
||||
* 0.11: 21 Oct 2003: hexdump for tx added, rx buffer sizes increased.
|
||||
* MAC Address init fix, set_multicast cleanup.
|
||||
* 0.12: 23 Oct 2003: Cleanups for release.
|
||||
* 0.13: 25 Oct 2003: Limit for concurrent tx packets increased to 10.
|
||||
* Set link speed correctly. start rx before starting
|
||||
* tx (nv_start_rx sets the link speed).
|
||||
* 0.14: 25 Oct 2003: Nic dependant irq mask.
|
||||
* 0.15: 08 Nov 2003: fix smp deadlock with set_multicast_list during
|
||||
* open.
|
||||
* 0.16: 15 Nov 2003: include file cleanup for ppc64, rx buffer size
|
||||
* increased to 1628 bytes.
|
||||
* 0.17: 16 Nov 2003: undo rx buffer size increase. Substract 1 from
|
||||
* the tx length.
|
||||
* 0.18: 17 Nov 2003: fix oops due to late initialization of dev_stats
|
||||
* 0.19: 29 Nov 2003: Handle RxNoBuf, detect & handle invalid mac
|
||||
* addresses, really stop rx if already running
|
||||
* in nv_start_rx, clean up a bit.
|
||||
* 0.20: 07 Dec 2003: alloc fixes
|
||||
* 0.21: 12 Jan 2004: additional alloc fix, nic polling fix.
|
||||
* 0.22: 19 Jan 2004: reprogram timer to a sane rate, avoid lockup
|
||||
* on close.
|
||||
* 0.23: 26 Jan 2004: various small cleanups
|
||||
* 0.24: 27 Feb 2004: make driver even less anonymous in backtraces
|
||||
* 0.25: 09 Mar 2004: wol support
|
||||
* 0.26: 03 Jun 2004: netdriver specific annotation, sparse-related fixes
|
||||
* 0.27: 19 Jun 2004: Gigabit support, new descriptor rings,
|
||||
* added CK804/MCP04 device IDs, code fixes
|
||||
* for registers, link status and other minor fixes.
|
||||
* 0.28: 21 Jun 2004: Big cleanup, making driver mostly endian safe
|
||||
* 0.29: 31 Aug 2004: Add backup timer for link change notification.
|
||||
* 0.30: 25 Sep 2004: rx checksum support for nf 250 Gb. Add rx reset
|
||||
* into nv_close, otherwise reenabling for wol can
|
||||
* cause DMA to kfree'd memory.
|
||||
* 0.31: 14 Nov 2004: ethtool support for getting/setting link
|
||||
* capabilities.
|
||||
* 0.32: 16 Apr 2005: RX_ERROR4 handling added.
|
||||
* 0.33: 16 May 2005: Support for MCP51 added.
|
||||
* 0.34: 18 Jun 2005: Add DEV_NEED_LINKTIMER to all nForce nics.
|
||||
* 0.35: 26 Jun 2005: Support for MCP55 added.
|
||||
* 0.36: 28 Jun 2005: Add jumbo frame support.
|
||||
* 0.37: 10 Jul 2005: Additional ethtool support, cleanup of pci id list
|
||||
* 0.38: 16 Jul 2005: tx irq rewrite: Use global flags instead of
|
||||
* per-packet flags.
|
||||
* 0.39: 18 Jul 2005: Add 64bit descriptor support.
|
||||
* 0.40: 19 Jul 2005: Add support for mac address change.
|
||||
* 0.41: 30 Jul 2005: Write back original MAC in nv_close instead
|
||||
* of nv_remove
|
||||
* 0.42: 06 Aug 2005: Fix lack of link speed initialization
|
||||
* in the second (and later) nv_open call
|
||||
* 0.43: 10 Aug 2005: Add support for tx checksum.
|
||||
* 0.44: 20 Aug 2005: Add support for scatter gather and segmentation.
|
||||
* 0.45: 18 Sep 2005: Remove nv_stop/start_rx from every link check
|
||||
* 0.46: 20 Oct 2005: Add irq optimization modes.
|
||||
* 0.47: 26 Oct 2005: Add phyaddr 0 in phy scan.
|
||||
* 0.48: 24 Dec 2005: Disable TSO, bugfix for pci_map_single
|
||||
* 0.49: 10 Dec 2005: Fix tso for large buffers.
|
||||
* 0.50: 20 Jan 2006: Add 8021pq tagging support.
|
||||
* 0.51: 20 Jan 2006: Add 64bit consistent memory allocation for rings.
|
||||
* 0.52: 20 Jan 2006: Add MSI/MSIX support.
|
||||
* 0.53: 19 Mar 2006: Fix init from low power mode and add hw reset.
|
||||
* 0.54: 21 Mar 2006: Fix spin locks for multi irqs and cleanup.
|
||||
* 0.55: 22 Mar 2006: Add flow control (pause frame).
|
||||
* 0.56: 22 Mar 2006: Additional ethtool config and moduleparam support.
|
||||
* 0.57: 14 May 2006: Mac address set in probe/remove and order corrections.
|
||||
* 0.58: 30 Oct 2006: Added support for sideband management unit.
|
||||
* 0.59: 30 Oct 2006: Added support for recoverable error.
|
||||
* 0.60: 20 Jan 2007: Code optimizations for rings, rx & tx data paths, and stats.
|
||||
*
|
||||
* Known bugs:
|
||||
* We suspect that on some hardware no TX done interrupts are generated.
|
||||
* This means recovery from netif_stop_queue only happens if the hw timer
|
||||
|
@ -123,11 +39,6 @@
|
|||
* DEV_NEED_TIMERIRQ will not harm you on sane hardware, only generating a few
|
||||
* superfluous timer interrupts from the nic.
|
||||
*/
|
||||
#ifdef CONFIG_FORCEDETH_NAPI
|
||||
#define DRIVERNAPI "-NAPI"
|
||||
#else
|
||||
#define DRIVERNAPI
|
||||
#endif
|
||||
#define FORCEDETH_VERSION "0.61"
|
||||
#define DRV_NAME "forcedeth"
|
||||
|
||||
|
@ -930,6 +841,13 @@ static inline u32 nv_descr_getlength_ex(struct ring_desc_ex *prd, u32 v)
|
|||
return le32_to_cpu(prd->flaglen) & LEN_MASK_V2;
|
||||
}
|
||||
|
||||
static bool nv_optimized(struct fe_priv *np)
|
||||
{
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2)
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
static int reg_delay(struct net_device *dev, int offset, u32 mask, u32 target,
|
||||
int delay, int delaymax, const char *msg)
|
||||
{
|
||||
|
@ -966,7 +884,7 @@ static void setup_hw_rings(struct net_device *dev, int rxtx_flags)
|
|||
struct fe_priv *np = get_nvpriv(dev);
|
||||
u8 __iomem *base = get_hwbase(dev);
|
||||
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
if (rxtx_flags & NV_SETUP_RX_RING) {
|
||||
writel(dma_low(np->ring_addr), base + NvRegRxRingPhysAddr);
|
||||
}
|
||||
|
@ -989,7 +907,7 @@ static void free_rings(struct net_device *dev)
|
|||
{
|
||||
struct fe_priv *np = get_nvpriv(dev);
|
||||
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
if (np->rx_ring.orig)
|
||||
pci_free_consistent(np->pci_dev, sizeof(struct ring_desc) * (np->rx_ring_size + np->tx_ring_size),
|
||||
np->rx_ring.orig, np->ring_addr);
|
||||
|
@ -1435,6 +1353,18 @@ static void nv_stop_tx(struct net_device *dev)
|
|||
base + NvRegTransmitPoll);
|
||||
}
|
||||
|
||||
static void nv_start_rxtx(struct net_device *dev)
|
||||
{
|
||||
nv_start_rx(dev);
|
||||
nv_start_tx(dev);
|
||||
}
|
||||
|
||||
static void nv_stop_rxtx(struct net_device *dev)
|
||||
{
|
||||
nv_stop_rx(dev);
|
||||
nv_stop_tx(dev);
|
||||
}
|
||||
|
||||
static void nv_txrx_reset(struct net_device *dev)
|
||||
{
|
||||
struct fe_priv *np = netdev_priv(dev);
|
||||
|
@ -1657,7 +1587,7 @@ static void nv_do_rx_refill(unsigned long data)
|
|||
} else {
|
||||
disable_irq(np->msi_x_entry[NV_MSI_X_VECTOR_RX].vector);
|
||||
}
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2)
|
||||
if (!nv_optimized(np))
|
||||
retcode = nv_alloc_rx(dev);
|
||||
else
|
||||
retcode = nv_alloc_rx_optimized(dev);
|
||||
|
@ -1682,8 +1612,10 @@ static void nv_init_rx(struct net_device *dev)
|
|||
{
|
||||
struct fe_priv *np = netdev_priv(dev);
|
||||
int i;
|
||||
|
||||
np->get_rx = np->put_rx = np->first_rx = np->rx_ring;
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2)
|
||||
|
||||
if (!nv_optimized(np))
|
||||
np->last_rx.orig = &np->rx_ring.orig[np->rx_ring_size-1];
|
||||
else
|
||||
np->last_rx.ex = &np->rx_ring.ex[np->rx_ring_size-1];
|
||||
|
@ -1691,7 +1623,7 @@ static void nv_init_rx(struct net_device *dev)
|
|||
np->last_rx_ctx = &np->rx_skb[np->rx_ring_size-1];
|
||||
|
||||
for (i = 0; i < np->rx_ring_size; i++) {
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
np->rx_ring.orig[i].flaglen = 0;
|
||||
np->rx_ring.orig[i].buf = 0;
|
||||
} else {
|
||||
|
@ -1709,8 +1641,10 @@ static void nv_init_tx(struct net_device *dev)
|
|||
{
|
||||
struct fe_priv *np = netdev_priv(dev);
|
||||
int i;
|
||||
|
||||
np->get_tx = np->put_tx = np->first_tx = np->tx_ring;
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2)
|
||||
|
||||
if (!nv_optimized(np))
|
||||
np->last_tx.orig = &np->tx_ring.orig[np->tx_ring_size-1];
|
||||
else
|
||||
np->last_tx.ex = &np->tx_ring.ex[np->tx_ring_size-1];
|
||||
|
@ -1721,7 +1655,7 @@ static void nv_init_tx(struct net_device *dev)
|
|||
np->tx_end_flip = NULL;
|
||||
|
||||
for (i = 0; i < np->tx_ring_size; i++) {
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
np->tx_ring.orig[i].flaglen = 0;
|
||||
np->tx_ring.orig[i].buf = 0;
|
||||
} else {
|
||||
|
@ -1744,7 +1678,8 @@ static int nv_init_ring(struct net_device *dev)
|
|||
|
||||
nv_init_tx(dev);
|
||||
nv_init_rx(dev);
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2)
|
||||
|
||||
if (!nv_optimized(np))
|
||||
return nv_alloc_rx(dev);
|
||||
else
|
||||
return nv_alloc_rx_optimized(dev);
|
||||
|
@ -1775,7 +1710,7 @@ static void nv_drain_tx(struct net_device *dev)
|
|||
unsigned int i;
|
||||
|
||||
for (i = 0; i < np->tx_ring_size; i++) {
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
np->tx_ring.orig[i].flaglen = 0;
|
||||
np->tx_ring.orig[i].buf = 0;
|
||||
} else {
|
||||
|
@ -1802,7 +1737,7 @@ static void nv_drain_rx(struct net_device *dev)
|
|||
int i;
|
||||
|
||||
for (i = 0; i < np->rx_ring_size; i++) {
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
np->rx_ring.orig[i].flaglen = 0;
|
||||
np->rx_ring.orig[i].buf = 0;
|
||||
} else {
|
||||
|
@ -1823,7 +1758,7 @@ static void nv_drain_rx(struct net_device *dev)
|
|||
}
|
||||
}
|
||||
|
||||
static void drain_ring(struct net_device *dev)
|
||||
static void nv_drain_rxtx(struct net_device *dev)
|
||||
{
|
||||
nv_drain_tx(dev);
|
||||
nv_drain_rx(dev);
|
||||
|
@ -2260,7 +2195,7 @@ static void nv_tx_timeout(struct net_device *dev)
|
|||
}
|
||||
printk(KERN_INFO "%s: Dumping tx ring\n", dev->name);
|
||||
for (i=0;i<np->tx_ring_size;i+= 4) {
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
printk(KERN_INFO "%03x: %08x %08x // %08x %08x // %08x %08x // %08x %08x\n",
|
||||
i,
|
||||
le32_to_cpu(np->tx_ring.orig[i].buf),
|
||||
|
@ -2296,7 +2231,7 @@ static void nv_tx_timeout(struct net_device *dev)
|
|||
nv_stop_tx(dev);
|
||||
|
||||
/* 2) check that the packets were not sent already: */
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2)
|
||||
if (!nv_optimized(np))
|
||||
nv_tx_done(dev);
|
||||
else
|
||||
nv_tx_done_optimized(dev, np->tx_ring_size);
|
||||
|
@ -2663,12 +2598,10 @@ static int nv_change_mtu(struct net_device *dev, int new_mtu)
|
|||
netif_tx_lock_bh(dev);
|
||||
spin_lock(&np->lock);
|
||||
/* stop engines */
|
||||
nv_stop_rx(dev);
|
||||
nv_stop_tx(dev);
|
||||
nv_stop_rxtx(dev);
|
||||
nv_txrx_reset(dev);
|
||||
/* drain rx queue */
|
||||
nv_drain_rx(dev);
|
||||
nv_drain_tx(dev);
|
||||
nv_drain_rxtx(dev);
|
||||
/* reinit driver view of the rx queue */
|
||||
set_bufsize(dev);
|
||||
if (nv_init_ring(dev)) {
|
||||
|
@ -2685,8 +2618,7 @@ static int nv_change_mtu(struct net_device *dev, int new_mtu)
|
|||
pci_push(base);
|
||||
|
||||
/* restart rx engine */
|
||||
nv_start_rx(dev);
|
||||
nv_start_tx(dev);
|
||||
nv_start_rxtx(dev);
|
||||
spin_unlock(&np->lock);
|
||||
netif_tx_unlock_bh(dev);
|
||||
nv_enable_irq(dev);
|
||||
|
@ -3393,7 +3325,7 @@ static int nv_napi_poll(struct napi_struct *napi, int budget)
|
|||
unsigned long flags;
|
||||
int pkts, retcode;
|
||||
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
pkts = nv_rx_process(dev, budget);
|
||||
retcode = nv_alloc_rx(dev);
|
||||
} else {
|
||||
|
@ -3634,7 +3566,7 @@ static int nv_request_irq(struct net_device *dev, int intr_test)
|
|||
if (intr_test) {
|
||||
handler = nv_nic_irq_test;
|
||||
} else {
|
||||
if (np->desc_ver == DESC_VER_3)
|
||||
if (nv_optimized(np))
|
||||
handler = nv_nic_irq_optimized;
|
||||
else
|
||||
handler = nv_nic_irq;
|
||||
|
@ -3787,12 +3719,10 @@ static void nv_do_nic_poll(unsigned long data)
|
|||
netif_tx_lock_bh(dev);
|
||||
spin_lock(&np->lock);
|
||||
/* stop engines */
|
||||
nv_stop_rx(dev);
|
||||
nv_stop_tx(dev);
|
||||
nv_stop_rxtx(dev);
|
||||
nv_txrx_reset(dev);
|
||||
/* drain rx queue */
|
||||
nv_drain_rx(dev);
|
||||
nv_drain_tx(dev);
|
||||
nv_drain_rxtx(dev);
|
||||
/* reinit driver view of the rx queue */
|
||||
set_bufsize(dev);
|
||||
if (nv_init_ring(dev)) {
|
||||
|
@ -3809,8 +3739,7 @@ static void nv_do_nic_poll(unsigned long data)
|
|||
pci_push(base);
|
||||
|
||||
/* restart rx engine */
|
||||
nv_start_rx(dev);
|
||||
nv_start_tx(dev);
|
||||
nv_start_rxtx(dev);
|
||||
spin_unlock(&np->lock);
|
||||
netif_tx_unlock_bh(dev);
|
||||
}
|
||||
|
@ -3821,7 +3750,7 @@ static void nv_do_nic_poll(unsigned long data)
|
|||
pci_push(base);
|
||||
|
||||
if (!using_multi_irqs(dev)) {
|
||||
if (np->desc_ver == DESC_VER_3)
|
||||
if (nv_optimized(np))
|
||||
nv_nic_irq_optimized(0, dev);
|
||||
else
|
||||
nv_nic_irq(0, dev);
|
||||
|
@ -4019,8 +3948,7 @@ static int nv_set_settings(struct net_device *dev, struct ethtool_cmd *ecmd)
|
|||
netif_tx_lock_bh(dev);
|
||||
spin_lock(&np->lock);
|
||||
/* stop engines */
|
||||
nv_stop_rx(dev);
|
||||
nv_stop_tx(dev);
|
||||
nv_stop_rxtx(dev);
|
||||
spin_unlock(&np->lock);
|
||||
netif_tx_unlock_bh(dev);
|
||||
}
|
||||
|
@ -4126,8 +4054,7 @@ static int nv_set_settings(struct net_device *dev, struct ethtool_cmd *ecmd)
|
|||
}
|
||||
|
||||
if (netif_running(dev)) {
|
||||
nv_start_rx(dev);
|
||||
nv_start_tx(dev);
|
||||
nv_start_rxtx(dev);
|
||||
nv_enable_irq(dev);
|
||||
}
|
||||
|
||||
|
@ -4170,8 +4097,7 @@ static int nv_nway_reset(struct net_device *dev)
|
|||
netif_tx_lock_bh(dev);
|
||||
spin_lock(&np->lock);
|
||||
/* stop engines */
|
||||
nv_stop_rx(dev);
|
||||
nv_stop_tx(dev);
|
||||
nv_stop_rxtx(dev);
|
||||
spin_unlock(&np->lock);
|
||||
netif_tx_unlock_bh(dev);
|
||||
printk(KERN_INFO "%s: link down.\n", dev->name);
|
||||
|
@ -4191,8 +4117,7 @@ static int nv_nway_reset(struct net_device *dev)
|
|||
}
|
||||
|
||||
if (netif_running(dev)) {
|
||||
nv_start_rx(dev);
|
||||
nv_start_tx(dev);
|
||||
nv_start_rxtx(dev);
|
||||
nv_enable_irq(dev);
|
||||
}
|
||||
ret = 0;
|
||||
|
@ -4249,7 +4174,7 @@ static int nv_set_ringparam(struct net_device *dev, struct ethtool_ringparam* ri
|
|||
}
|
||||
|
||||
/* allocate new rings */
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
rxtx_ring = pci_alloc_consistent(np->pci_dev,
|
||||
sizeof(struct ring_desc) * (ring->rx_pending + ring->tx_pending),
|
||||
&ring_addr);
|
||||
|
@ -4262,7 +4187,7 @@ static int nv_set_ringparam(struct net_device *dev, struct ethtool_ringparam* ri
|
|||
tx_skbuff = kmalloc(sizeof(struct nv_skb_map) * ring->tx_pending, GFP_KERNEL);
|
||||
if (!rxtx_ring || !rx_skbuff || !tx_skbuff) {
|
||||
/* fall back to old rings */
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
if (rxtx_ring)
|
||||
pci_free_consistent(np->pci_dev, sizeof(struct ring_desc) * (ring->rx_pending + ring->tx_pending),
|
||||
rxtx_ring, ring_addr);
|
||||
|
@ -4283,12 +4208,10 @@ static int nv_set_ringparam(struct net_device *dev, struct ethtool_ringparam* ri
|
|||
netif_tx_lock_bh(dev);
|
||||
spin_lock(&np->lock);
|
||||
/* stop engines */
|
||||
nv_stop_rx(dev);
|
||||
nv_stop_tx(dev);
|
||||
nv_stop_rxtx(dev);
|
||||
nv_txrx_reset(dev);
|
||||
/* drain queues */
|
||||
nv_drain_rx(dev);
|
||||
nv_drain_tx(dev);
|
||||
nv_drain_rxtx(dev);
|
||||
/* delete queues */
|
||||
free_rings(dev);
|
||||
}
|
||||
|
@ -4296,7 +4219,8 @@ static int nv_set_ringparam(struct net_device *dev, struct ethtool_ringparam* ri
|
|||
/* set new values */
|
||||
np->rx_ring_size = ring->rx_pending;
|
||||
np->tx_ring_size = ring->tx_pending;
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
|
||||
if (!nv_optimized(np)) {
|
||||
np->rx_ring.orig = (struct ring_desc*)rxtx_ring;
|
||||
np->tx_ring.orig = &np->rx_ring.orig[np->rx_ring_size];
|
||||
} else {
|
||||
|
@ -4328,8 +4252,7 @@ static int nv_set_ringparam(struct net_device *dev, struct ethtool_ringparam* ri
|
|||
pci_push(base);
|
||||
|
||||
/* restart engines */
|
||||
nv_start_rx(dev);
|
||||
nv_start_tx(dev);
|
||||
nv_start_rxtx(dev);
|
||||
spin_unlock(&np->lock);
|
||||
netif_tx_unlock_bh(dev);
|
||||
nv_enable_irq(dev);
|
||||
|
@ -4370,8 +4293,7 @@ static int nv_set_pauseparam(struct net_device *dev, struct ethtool_pauseparam*
|
|||
netif_tx_lock_bh(dev);
|
||||
spin_lock(&np->lock);
|
||||
/* stop engines */
|
||||
nv_stop_rx(dev);
|
||||
nv_stop_tx(dev);
|
||||
nv_stop_rxtx(dev);
|
||||
spin_unlock(&np->lock);
|
||||
netif_tx_unlock_bh(dev);
|
||||
}
|
||||
|
@ -4412,8 +4334,7 @@ static int nv_set_pauseparam(struct net_device *dev, struct ethtool_pauseparam*
|
|||
}
|
||||
|
||||
if (netif_running(dev)) {
|
||||
nv_start_rx(dev);
|
||||
nv_start_tx(dev);
|
||||
nv_start_rxtx(dev);
|
||||
nv_enable_irq(dev);
|
||||
}
|
||||
return 0;
|
||||
|
@ -4649,8 +4570,7 @@ static int nv_loopback_test(struct net_device *dev)
|
|||
pci_push(base);
|
||||
|
||||
/* restart rx engine */
|
||||
nv_start_rx(dev);
|
||||
nv_start_tx(dev);
|
||||
nv_start_rxtx(dev);
|
||||
|
||||
/* setup packet for tx */
|
||||
pkt_len = ETH_DATA_LEN;
|
||||
|
@ -4668,7 +4588,7 @@ static int nv_loopback_test(struct net_device *dev)
|
|||
for (i = 0; i < pkt_len; i++)
|
||||
pkt_data[i] = (u8)(i & 0xff);
|
||||
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
np->tx_ring.orig[0].buf = cpu_to_le32(test_dma_addr);
|
||||
np->tx_ring.orig[0].flaglen = cpu_to_le32((pkt_len-1) | np->tx_flags | tx_flags_extra);
|
||||
} else {
|
||||
|
@ -4682,7 +4602,7 @@ static int nv_loopback_test(struct net_device *dev)
|
|||
msleep(500);
|
||||
|
||||
/* check for rx of the packet */
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
flags = le32_to_cpu(np->rx_ring.orig[0].flaglen);
|
||||
len = nv_descr_getlength(&np->rx_ring.orig[0], np->desc_ver);
|
||||
|
||||
|
@ -4728,12 +4648,10 @@ static int nv_loopback_test(struct net_device *dev)
|
|||
dev_kfree_skb_any(tx_skb);
|
||||
out:
|
||||
/* stop engines */
|
||||
nv_stop_rx(dev);
|
||||
nv_stop_tx(dev);
|
||||
nv_stop_rxtx(dev);
|
||||
nv_txrx_reset(dev);
|
||||
/* drain rx queue */
|
||||
nv_drain_rx(dev);
|
||||
nv_drain_tx(dev);
|
||||
nv_drain_rxtx(dev);
|
||||
|
||||
if (netif_running(dev)) {
|
||||
writel(misc1_flags, base + NvRegMisc1);
|
||||
|
@ -4771,12 +4689,10 @@ static void nv_self_test(struct net_device *dev, struct ethtool_test *test, u64
|
|||
writel(NVREG_IRQSTAT_MASK, base + NvRegMSIXIrqStatus);
|
||||
}
|
||||
/* stop engines */
|
||||
nv_stop_rx(dev);
|
||||
nv_stop_tx(dev);
|
||||
nv_stop_rxtx(dev);
|
||||
nv_txrx_reset(dev);
|
||||
/* drain rx queue */
|
||||
nv_drain_rx(dev);
|
||||
nv_drain_tx(dev);
|
||||
nv_drain_rxtx(dev);
|
||||
spin_unlock_irq(&np->lock);
|
||||
netif_tx_unlock_bh(dev);
|
||||
}
|
||||
|
@ -4817,8 +4733,7 @@ static void nv_self_test(struct net_device *dev, struct ethtool_test *test, u64
|
|||
writel(NVREG_TXRXCTL_KICK|np->txrxctl_bits, get_hwbase(dev) + NvRegTxRxControl);
|
||||
pci_push(base);
|
||||
/* restart rx engine */
|
||||
nv_start_rx(dev);
|
||||
nv_start_tx(dev);
|
||||
nv_start_rxtx(dev);
|
||||
netif_start_queue(dev);
|
||||
#ifdef CONFIG_FORCEDETH_NAPI
|
||||
napi_enable(&np->napi);
|
||||
|
@ -5047,8 +4962,7 @@ static int nv_open(struct net_device *dev)
|
|||
* to init hw */
|
||||
np->linkspeed = 0;
|
||||
ret = nv_update_linkspeed(dev);
|
||||
nv_start_rx(dev);
|
||||
nv_start_tx(dev);
|
||||
nv_start_rxtx(dev);
|
||||
netif_start_queue(dev);
|
||||
#ifdef CONFIG_FORCEDETH_NAPI
|
||||
napi_enable(&np->napi);
|
||||
|
@ -5072,7 +4986,7 @@ static int nv_open(struct net_device *dev)
|
|||
|
||||
return 0;
|
||||
out_drain:
|
||||
drain_ring(dev);
|
||||
nv_drain_rxtx(dev);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -5095,8 +5009,7 @@ static int nv_close(struct net_device *dev)
|
|||
|
||||
netif_stop_queue(dev);
|
||||
spin_lock_irq(&np->lock);
|
||||
nv_stop_tx(dev);
|
||||
nv_stop_rx(dev);
|
||||
nv_stop_rxtx(dev);
|
||||
nv_txrx_reset(dev);
|
||||
|
||||
/* disable interrupts on the nic or we will lock up */
|
||||
|
@ -5109,7 +5022,7 @@ static int nv_close(struct net_device *dev)
|
|||
|
||||
nv_free_irq(dev);
|
||||
|
||||
drain_ring(dev);
|
||||
nv_drain_rxtx(dev);
|
||||
|
||||
if (np->wolenabled) {
|
||||
writel(NVREG_PFF_ALWAYS|NVREG_PFF_MYADDR, base + NvRegPacketFilterFlags);
|
||||
|
@ -5269,7 +5182,7 @@ static int __devinit nv_probe(struct pci_dev *pci_dev, const struct pci_device_i
|
|||
np->rx_ring_size = RX_RING_DEFAULT;
|
||||
np->tx_ring_size = TX_RING_DEFAULT;
|
||||
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2) {
|
||||
if (!nv_optimized(np)) {
|
||||
np->rx_ring.orig = pci_alloc_consistent(pci_dev,
|
||||
sizeof(struct ring_desc) * (np->rx_ring_size + np->tx_ring_size),
|
||||
&np->ring_addr);
|
||||
|
@ -5291,7 +5204,8 @@ static int __devinit nv_probe(struct pci_dev *pci_dev, const struct pci_device_i
|
|||
|
||||
dev->open = nv_open;
|
||||
dev->stop = nv_close;
|
||||
if (np->desc_ver == DESC_VER_1 || np->desc_ver == DESC_VER_2)
|
||||
|
||||
if (!nv_optimized(np))
|
||||
dev->hard_start_xmit = nv_start_xmit;
|
||||
else
|
||||
dev->hard_start_xmit = nv_start_xmit_optimized;
|
||||
|
|
|
@ -1178,7 +1178,7 @@ static int __devinit find_phy(struct device_node *np,
|
|||
|
||||
data = of_get_property(np, "fixed-link", NULL);
|
||||
if (data) {
|
||||
snprintf(fpi->bus_id, 16, PHY_ID_FMT, 0, *data);
|
||||
snprintf(fpi->bus_id, 16, "%x:%02x", 0, *data);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -1202,7 +1202,7 @@ static int __devinit find_phy(struct device_node *np,
|
|||
if (!data || len != 4)
|
||||
goto out_put_mdio;
|
||||
|
||||
snprintf(fpi->bus_id, 16, PHY_ID_FMT, res.start, *data);
|
||||
snprintf(fpi->bus_id, 16, "%x:%02x", res.start, *data);
|
||||
|
||||
out_put_mdio:
|
||||
of_node_put(mdionode);
|
||||
|
|
|
@ -130,7 +130,7 @@ static int __devinit fs_mii_bitbang_init(struct mii_bus *bus,
|
|||
* we get is an int, and the odds of multiple bitbang mdio buses
|
||||
* is low enough that it's not worth going too crazy.
|
||||
*/
|
||||
bus->id = res.start;
|
||||
snprintf(bus->id, MII_BUS_ID_SIZE, "%x", res.start);
|
||||
|
||||
data = of_get_property(np, "fsl,mdio-pin", &len);
|
||||
if (!data || len != 4)
|
||||
|
@ -307,7 +307,7 @@ static int __devinit fs_enet_mdio_probe(struct device *dev)
|
|||
return -ENOMEM;
|
||||
|
||||
new_bus->name = "BB MII Bus",
|
||||
new_bus->id = pdev->id;
|
||||
snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", pdev->id);
|
||||
|
||||
new_bus->phy_mask = ~0x9;
|
||||
pdata = (struct fs_mii_bb_platform_info *)pdev->dev.platform_data;
|
||||
|
|
|
@ -196,7 +196,7 @@ static int __devinit fs_enet_mdio_probe(struct of_device *ofdev,
|
|||
if (ret)
|
||||
return ret;
|
||||
|
||||
new_bus->id = res.start;
|
||||
snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", res.start);
|
||||
|
||||
fec->fecp = ioremap(res.start, res.end - res.start + 1);
|
||||
if (!fec->fecp)
|
||||
|
@ -309,7 +309,7 @@ static int __devinit fs_enet_fec_mdio_probe(struct device *dev)
|
|||
new_bus->read = &fs_enet_fec_mii_read,
|
||||
new_bus->write = &fs_enet_fec_mii_write,
|
||||
new_bus->reset = &fs_enet_fec_mii_reset,
|
||||
new_bus->id = pdev->id;
|
||||
snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", pdev->id);
|
||||
|
||||
pdata = (struct fs_mii_fec_platform_info *)pdev->dev.platform_data;
|
||||
|
||||
|
|
|
@ -1250,17 +1250,12 @@ static void gfar_timeout(struct net_device *dev)
|
|||
}
|
||||
|
||||
/* Interrupt Handler for Transmit complete */
|
||||
static irqreturn_t gfar_transmit(int irq, void *dev_id)
|
||||
int gfar_clean_tx_ring(struct net_device *dev)
|
||||
{
|
||||
struct net_device *dev = (struct net_device *) dev_id;
|
||||
struct gfar_private *priv = netdev_priv(dev);
|
||||
struct txbd8 *bdp;
|
||||
struct gfar_private *priv = netdev_priv(dev);
|
||||
int howmany = 0;
|
||||
|
||||
/* Clear IEVENT */
|
||||
gfar_write(&priv->regs->ievent, IEVENT_TX_MASK);
|
||||
|
||||
/* Lock priv */
|
||||
spin_lock(&priv->txlock);
|
||||
bdp = priv->dirty_tx;
|
||||
while ((bdp->status & TXBD_READY) == 0) {
|
||||
/* If dirty_tx and cur_tx are the same, then either the */
|
||||
|
@ -1269,7 +1264,7 @@ static irqreturn_t gfar_transmit(int irq, void *dev_id)
|
|||
if ((bdp == priv->cur_tx) && (netif_queue_stopped(dev) == 0))
|
||||
break;
|
||||
|
||||
dev->stats.tx_packets++;
|
||||
howmany++;
|
||||
|
||||
/* Deferred means some collisions occurred during transmit, */
|
||||
/* but we eventually sent the packet. */
|
||||
|
@ -1278,11 +1273,15 @@ static irqreturn_t gfar_transmit(int irq, void *dev_id)
|
|||
|
||||
/* Free the sk buffer associated with this TxBD */
|
||||
dev_kfree_skb_irq(priv->tx_skbuff[priv->skb_dirtytx]);
|
||||
|
||||
priv->tx_skbuff[priv->skb_dirtytx] = NULL;
|
||||
priv->skb_dirtytx =
|
||||
(priv->skb_dirtytx +
|
||||
1) & TX_RING_MOD_MASK(priv->tx_ring_size);
|
||||
|
||||
/* Clean BD length for empty detection */
|
||||
bdp->length = 0;
|
||||
|
||||
/* update bdp to point at next bd in the ring (wrapping if necessary) */
|
||||
if (bdp->status & TXBD_WRAP)
|
||||
bdp = priv->tx_bd_base;
|
||||
|
@ -1297,6 +1296,25 @@ static irqreturn_t gfar_transmit(int irq, void *dev_id)
|
|||
netif_wake_queue(dev);
|
||||
} /* while ((bdp->status & TXBD_READY) == 0) */
|
||||
|
||||
dev->stats.tx_packets += howmany;
|
||||
|
||||
return howmany;
|
||||
}
|
||||
|
||||
/* Interrupt Handler for Transmit complete */
|
||||
static irqreturn_t gfar_transmit(int irq, void *dev_id)
|
||||
{
|
||||
struct net_device *dev = (struct net_device *) dev_id;
|
||||
struct gfar_private *priv = netdev_priv(dev);
|
||||
|
||||
/* Clear IEVENT */
|
||||
gfar_write(&priv->regs->ievent, IEVENT_TX_MASK);
|
||||
|
||||
/* Lock priv */
|
||||
spin_lock(&priv->txlock);
|
||||
|
||||
gfar_clean_tx_ring(dev);
|
||||
|
||||
/* If we are coalescing the interrupts, reset the timer */
|
||||
/* Otherwise, clear it */
|
||||
if (likely(priv->txcoalescing)) {
|
||||
|
@ -1392,15 +1410,15 @@ irqreturn_t gfar_receive(int irq, void *dev_id)
|
|||
unsigned long flags;
|
||||
#endif
|
||||
|
||||
/* Clear IEVENT, so rx interrupt isn't called again
|
||||
* because of this interrupt */
|
||||
gfar_write(&priv->regs->ievent, IEVENT_RX_MASK);
|
||||
|
||||
/* support NAPI */
|
||||
#ifdef CONFIG_GFAR_NAPI
|
||||
/* Clear IEVENT, so interrupts aren't called again
|
||||
* because of the packets that have already arrived */
|
||||
gfar_write(&priv->regs->ievent, IEVENT_RTX_MASK);
|
||||
|
||||
if (netif_rx_schedule_prep(dev, &priv->napi)) {
|
||||
tempval = gfar_read(&priv->regs->imask);
|
||||
tempval &= IMASK_RX_DISABLED;
|
||||
tempval &= IMASK_RTX_DISABLED;
|
||||
gfar_write(&priv->regs->imask, tempval);
|
||||
|
||||
__netif_rx_schedule(dev, &priv->napi);
|
||||
|
@ -1411,6 +1429,9 @@ irqreturn_t gfar_receive(int irq, void *dev_id)
|
|||
gfar_read(&priv->regs->imask));
|
||||
}
|
||||
#else
|
||||
/* Clear IEVENT, so rx interrupt isn't called again
|
||||
* because of this interrupt */
|
||||
gfar_write(&priv->regs->ievent, IEVENT_RX_MASK);
|
||||
|
||||
spin_lock_irqsave(&priv->rxlock, flags);
|
||||
gfar_clean_rx_ring(dev, priv->rx_ring_size);
|
||||
|
@ -1580,6 +1601,13 @@ static int gfar_poll(struct napi_struct *napi, int budget)
|
|||
struct gfar_private *priv = container_of(napi, struct gfar_private, napi);
|
||||
struct net_device *dev = priv->dev;
|
||||
int howmany;
|
||||
unsigned long flags;
|
||||
|
||||
/* If we fail to get the lock, don't bother with the TX BDs */
|
||||
if (spin_trylock_irqsave(&priv->txlock, flags)) {
|
||||
gfar_clean_tx_ring(dev);
|
||||
spin_unlock_irqrestore(&priv->txlock, flags);
|
||||
}
|
||||
|
||||
howmany = gfar_clean_rx_ring(dev, budget);
|
||||
|
||||
|
|
|
@ -126,9 +126,16 @@ extern const char gfar_driver_version[];
|
|||
#define DEFAULT_TXCOUNT 16
|
||||
#define DEFAULT_TXTIME 21
|
||||
|
||||
#define DEFAULT_RXTIME 21
|
||||
|
||||
/* Non NAPI Case */
|
||||
#ifndef CONFIG_GFAR_NAPI
|
||||
#define DEFAULT_RX_COALESCE 1
|
||||
#define DEFAULT_RXCOUNT 16
|
||||
#define DEFAULT_RXTIME 21
|
||||
#else
|
||||
#define DEFAULT_RX_COALESCE 0
|
||||
#define DEFAULT_RXCOUNT 0
|
||||
#endif /* CONFIG_GFAR_NAPI */
|
||||
|
||||
#define TBIPA_VALUE 0x1f
|
||||
#define MIIMCFG_INIT_VALUE 0x00000007
|
||||
|
@ -242,6 +249,7 @@ extern const char gfar_driver_version[];
|
|||
#define IEVENT_PERR 0x00000001
|
||||
#define IEVENT_RX_MASK (IEVENT_RXB0 | IEVENT_RXF0)
|
||||
#define IEVENT_TX_MASK (IEVENT_TXB | IEVENT_TXF)
|
||||
#define IEVENT_RTX_MASK (IEVENT_RX_MASK | IEVENT_TX_MASK)
|
||||
#define IEVENT_ERR_MASK \
|
||||
(IEVENT_RXC | IEVENT_BSY | IEVENT_EBERR | IEVENT_MSRO | \
|
||||
IEVENT_BABT | IEVENT_TXC | IEVENT_TXE | IEVENT_LC \
|
||||
|
@ -269,11 +277,12 @@ extern const char gfar_driver_version[];
|
|||
#define IMASK_FIQ 0x00000004
|
||||
#define IMASK_DPE 0x00000002
|
||||
#define IMASK_PERR 0x00000001
|
||||
#define IMASK_RX_DISABLED ~(IMASK_RXFEN0 | IMASK_BSY)
|
||||
#define IMASK_DEFAULT (IMASK_TXEEN | IMASK_TXFEN | IMASK_TXBEN | \
|
||||
IMASK_RXFEN0 | IMASK_BSY | IMASK_EBERR | IMASK_BABR | \
|
||||
IMASK_XFUN | IMASK_RXC | IMASK_BABT | IMASK_DPE \
|
||||
| IMASK_PERR)
|
||||
#define IMASK_RTX_DISABLED ((~(IMASK_RXFEN0 | IMASK_TXFEN | IMASK_BSY)) \
|
||||
& IMASK_DEFAULT)
|
||||
|
||||
/* Fifo management */
|
||||
#define FIFO_TX_THR_MASK 0x01ff
|
||||
|
|
|
@ -173,7 +173,7 @@ int gfar_mdio_probe(struct device *dev)
|
|||
new_bus->read = &gfar_mdio_read,
|
||||
new_bus->write = &gfar_mdio_write,
|
||||
new_bus->reset = &gfar_mdio_reset,
|
||||
new_bus->id = pdev->id;
|
||||
snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", pdev->id);
|
||||
|
||||
pdata = (struct gianfar_mdio_data *)pdev->dev.platform_data;
|
||||
|
||||
|
|
|
@ -117,8 +117,8 @@ struct ixgb_buffer {
|
|||
struct sk_buff *skb;
|
||||
dma_addr_t dma;
|
||||
unsigned long time_stamp;
|
||||
uint16_t length;
|
||||
uint16_t next_to_watch;
|
||||
u16 length;
|
||||
u16 next_to_watch;
|
||||
};
|
||||
|
||||
struct ixgb_desc_ring {
|
||||
|
@ -152,11 +152,11 @@ struct ixgb_desc_ring {
|
|||
struct ixgb_adapter {
|
||||
struct timer_list watchdog_timer;
|
||||
struct vlan_group *vlgrp;
|
||||
uint32_t bd_number;
|
||||
uint32_t rx_buffer_len;
|
||||
uint32_t part_num;
|
||||
uint16_t link_speed;
|
||||
uint16_t link_duplex;
|
||||
u32 bd_number;
|
||||
u32 rx_buffer_len;
|
||||
u32 part_num;
|
||||
u16 link_speed;
|
||||
u16 link_duplex;
|
||||
spinlock_t tx_lock;
|
||||
struct work_struct tx_timeout_task;
|
||||
|
||||
|
@ -167,19 +167,19 @@ struct ixgb_adapter {
|
|||
struct ixgb_desc_ring tx_ring ____cacheline_aligned_in_smp;
|
||||
unsigned int restart_queue;
|
||||
unsigned long timeo_start;
|
||||
uint32_t tx_cmd_type;
|
||||
uint64_t hw_csum_tx_good;
|
||||
uint64_t hw_csum_tx_error;
|
||||
uint32_t tx_int_delay;
|
||||
uint32_t tx_timeout_count;
|
||||
u32 tx_cmd_type;
|
||||
u64 hw_csum_tx_good;
|
||||
u64 hw_csum_tx_error;
|
||||
u32 tx_int_delay;
|
||||
u32 tx_timeout_count;
|
||||
bool tx_int_delay_enable;
|
||||
bool detect_tx_hung;
|
||||
|
||||
/* RX */
|
||||
struct ixgb_desc_ring rx_ring;
|
||||
uint64_t hw_csum_rx_error;
|
||||
uint64_t hw_csum_rx_good;
|
||||
uint32_t rx_int_delay;
|
||||
u64 hw_csum_rx_error;
|
||||
u64 hw_csum_rx_good;
|
||||
u32 rx_int_delay;
|
||||
bool rx_csum;
|
||||
|
||||
/* OS defined structs */
|
||||
|
@ -192,7 +192,7 @@ struct ixgb_adapter {
|
|||
struct ixgb_hw hw;
|
||||
u16 msg_enable;
|
||||
struct ixgb_hw_stats stats;
|
||||
uint32_t alloc_rx_buff_failed;
|
||||
u32 alloc_rx_buff_failed;
|
||||
bool have_msi;
|
||||
unsigned long flags;
|
||||
};
|
||||
|
|
|
@ -29,11 +29,11 @@
|
|||
#include "ixgb_hw.h"
|
||||
#include "ixgb_ee.h"
|
||||
/* Local prototypes */
|
||||
static uint16_t ixgb_shift_in_bits(struct ixgb_hw *hw);
|
||||
static u16 ixgb_shift_in_bits(struct ixgb_hw *hw);
|
||||
|
||||
static void ixgb_shift_out_bits(struct ixgb_hw *hw,
|
||||
uint16_t data,
|
||||
uint16_t count);
|
||||
u16 data,
|
||||
u16 count);
|
||||
static void ixgb_standby_eeprom(struct ixgb_hw *hw);
|
||||
|
||||
static bool ixgb_wait_eeprom_command(struct ixgb_hw *hw);
|
||||
|
@ -48,7 +48,7 @@ static void ixgb_cleanup_eeprom(struct ixgb_hw *hw);
|
|||
*****************************************************************************/
|
||||
static void
|
||||
ixgb_raise_clock(struct ixgb_hw *hw,
|
||||
uint32_t *eecd_reg)
|
||||
u32 *eecd_reg)
|
||||
{
|
||||
/* Raise the clock input to the EEPROM (by setting the SK bit), and then
|
||||
* wait 50 microseconds.
|
||||
|
@ -67,7 +67,7 @@ ixgb_raise_clock(struct ixgb_hw *hw,
|
|||
*****************************************************************************/
|
||||
static void
|
||||
ixgb_lower_clock(struct ixgb_hw *hw,
|
||||
uint32_t *eecd_reg)
|
||||
u32 *eecd_reg)
|
||||
{
|
||||
/* Lower the clock input to the EEPROM (by clearing the SK bit), and then
|
||||
* wait 50 microseconds.
|
||||
|
@ -87,11 +87,11 @@ ixgb_lower_clock(struct ixgb_hw *hw,
|
|||
*****************************************************************************/
|
||||
static void
|
||||
ixgb_shift_out_bits(struct ixgb_hw *hw,
|
||||
uint16_t data,
|
||||
uint16_t count)
|
||||
u16 data,
|
||||
u16 count)
|
||||
{
|
||||
uint32_t eecd_reg;
|
||||
uint32_t mask;
|
||||
u32 eecd_reg;
|
||||
u32 mask;
|
||||
|
||||
/* We need to shift "count" bits out to the EEPROM. So, value in the
|
||||
* "data" parameter will be shifted out to the EEPROM one bit at a time.
|
||||
|
@ -133,12 +133,12 @@ ixgb_shift_out_bits(struct ixgb_hw *hw,
|
|||
*
|
||||
* hw - Struct containing variables accessed by shared code
|
||||
*****************************************************************************/
|
||||
static uint16_t
|
||||
static u16
|
||||
ixgb_shift_in_bits(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t eecd_reg;
|
||||
uint32_t i;
|
||||
uint16_t data;
|
||||
u32 eecd_reg;
|
||||
u32 i;
|
||||
u16 data;
|
||||
|
||||
/* In order to read a register from the EEPROM, we need to shift 16 bits
|
||||
* in from the EEPROM. Bits are "shifted in" by raising the clock input to
|
||||
|
@ -179,7 +179,7 @@ ixgb_shift_in_bits(struct ixgb_hw *hw)
|
|||
static void
|
||||
ixgb_setup_eeprom(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t eecd_reg;
|
||||
u32 eecd_reg;
|
||||
|
||||
eecd_reg = IXGB_READ_REG(hw, EECD);
|
||||
|
||||
|
@ -201,7 +201,7 @@ ixgb_setup_eeprom(struct ixgb_hw *hw)
|
|||
static void
|
||||
ixgb_standby_eeprom(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t eecd_reg;
|
||||
u32 eecd_reg;
|
||||
|
||||
eecd_reg = IXGB_READ_REG(hw, EECD);
|
||||
|
||||
|
@ -235,7 +235,7 @@ ixgb_standby_eeprom(struct ixgb_hw *hw)
|
|||
static void
|
||||
ixgb_clock_eeprom(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t eecd_reg;
|
||||
u32 eecd_reg;
|
||||
|
||||
eecd_reg = IXGB_READ_REG(hw, EECD);
|
||||
|
||||
|
@ -259,7 +259,7 @@ ixgb_clock_eeprom(struct ixgb_hw *hw)
|
|||
static void
|
||||
ixgb_cleanup_eeprom(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t eecd_reg;
|
||||
u32 eecd_reg;
|
||||
|
||||
eecd_reg = IXGB_READ_REG(hw, EECD);
|
||||
|
||||
|
@ -285,8 +285,8 @@ ixgb_cleanup_eeprom(struct ixgb_hw *hw)
|
|||
static bool
|
||||
ixgb_wait_eeprom_command(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t eecd_reg;
|
||||
uint32_t i;
|
||||
u32 eecd_reg;
|
||||
u32 i;
|
||||
|
||||
/* Toggle the CS line. This in effect tells to EEPROM to actually execute
|
||||
* the command in question.
|
||||
|
@ -325,13 +325,13 @@ ixgb_wait_eeprom_command(struct ixgb_hw *hw)
|
|||
bool
|
||||
ixgb_validate_eeprom_checksum(struct ixgb_hw *hw)
|
||||
{
|
||||
uint16_t checksum = 0;
|
||||
uint16_t i;
|
||||
u16 checksum = 0;
|
||||
u16 i;
|
||||
|
||||
for(i = 0; i < (EEPROM_CHECKSUM_REG + 1); i++)
|
||||
checksum += ixgb_read_eeprom(hw, i);
|
||||
|
||||
if(checksum == (uint16_t) EEPROM_SUM)
|
||||
if(checksum == (u16) EEPROM_SUM)
|
||||
return (true);
|
||||
else
|
||||
return (false);
|
||||
|
@ -348,13 +348,13 @@ ixgb_validate_eeprom_checksum(struct ixgb_hw *hw)
|
|||
void
|
||||
ixgb_update_eeprom_checksum(struct ixgb_hw *hw)
|
||||
{
|
||||
uint16_t checksum = 0;
|
||||
uint16_t i;
|
||||
u16 checksum = 0;
|
||||
u16 i;
|
||||
|
||||
for(i = 0; i < EEPROM_CHECKSUM_REG; i++)
|
||||
checksum += ixgb_read_eeprom(hw, i);
|
||||
|
||||
checksum = (uint16_t) EEPROM_SUM - checksum;
|
||||
checksum = (u16) EEPROM_SUM - checksum;
|
||||
|
||||
ixgb_write_eeprom(hw, EEPROM_CHECKSUM_REG, checksum);
|
||||
return;
|
||||
|
@ -372,7 +372,7 @@ ixgb_update_eeprom_checksum(struct ixgb_hw *hw)
|
|||
*
|
||||
*****************************************************************************/
|
||||
void
|
||||
ixgb_write_eeprom(struct ixgb_hw *hw, uint16_t offset, uint16_t data)
|
||||
ixgb_write_eeprom(struct ixgb_hw *hw, u16 offset, u16 data)
|
||||
{
|
||||
struct ixgb_ee_map_type *ee_map = (struct ixgb_ee_map_type *)hw->eeprom;
|
||||
|
||||
|
@ -425,11 +425,11 @@ ixgb_write_eeprom(struct ixgb_hw *hw, uint16_t offset, uint16_t data)
|
|||
* Returns:
|
||||
* The 16-bit value read from the eeprom
|
||||
*****************************************************************************/
|
||||
uint16_t
|
||||
u16
|
||||
ixgb_read_eeprom(struct ixgb_hw *hw,
|
||||
uint16_t offset)
|
||||
u16 offset)
|
||||
{
|
||||
uint16_t data;
|
||||
u16 data;
|
||||
|
||||
/* Prepare the EEPROM for reading */
|
||||
ixgb_setup_eeprom(hw);
|
||||
|
@ -463,8 +463,8 @@ ixgb_read_eeprom(struct ixgb_hw *hw,
|
|||
bool
|
||||
ixgb_get_eeprom_data(struct ixgb_hw *hw)
|
||||
{
|
||||
uint16_t i;
|
||||
uint16_t checksum = 0;
|
||||
u16 i;
|
||||
u16 checksum = 0;
|
||||
struct ixgb_ee_map_type *ee_map;
|
||||
|
||||
DEBUGFUNC("ixgb_get_eeprom_data");
|
||||
|
@ -473,13 +473,13 @@ ixgb_get_eeprom_data(struct ixgb_hw *hw)
|
|||
|
||||
DEBUGOUT("ixgb_ee: Reading eeprom data\n");
|
||||
for(i = 0; i < IXGB_EEPROM_SIZE ; i++) {
|
||||
uint16_t ee_data;
|
||||
u16 ee_data;
|
||||
ee_data = ixgb_read_eeprom(hw, i);
|
||||
checksum += ee_data;
|
||||
hw->eeprom[i] = cpu_to_le16(ee_data);
|
||||
}
|
||||
|
||||
if (checksum != (uint16_t) EEPROM_SUM) {
|
||||
if (checksum != (u16) EEPROM_SUM) {
|
||||
DEBUGOUT("ixgb_ee: Checksum invalid.\n");
|
||||
/* clear the init_ctrl_reg_1 to signify that the cache is
|
||||
* invalidated */
|
||||
|
@ -529,7 +529,7 @@ ixgb_check_and_get_eeprom_data (struct ixgb_hw* hw)
|
|||
* Word at indexed offset in eeprom, if valid, 0 otherwise.
|
||||
******************************************************************************/
|
||||
__le16
|
||||
ixgb_get_eeprom_word(struct ixgb_hw *hw, uint16_t index)
|
||||
ixgb_get_eeprom_word(struct ixgb_hw *hw, u16 index)
|
||||
{
|
||||
|
||||
if ((index < IXGB_EEPROM_SIZE) &&
|
||||
|
@ -550,7 +550,7 @@ ixgb_get_eeprom_word(struct ixgb_hw *hw, uint16_t index)
|
|||
******************************************************************************/
|
||||
void
|
||||
ixgb_get_ee_mac_addr(struct ixgb_hw *hw,
|
||||
uint8_t *mac_addr)
|
||||
u8 *mac_addr)
|
||||
{
|
||||
int i;
|
||||
struct ixgb_ee_map_type *ee_map = (struct ixgb_ee_map_type *)hw->eeprom;
|
||||
|
@ -574,7 +574,7 @@ ixgb_get_ee_mac_addr(struct ixgb_hw *hw,
|
|||
* Returns:
|
||||
* PBA number if EEPROM contents are valid, 0 otherwise
|
||||
******************************************************************************/
|
||||
uint32_t
|
||||
u32
|
||||
ixgb_get_ee_pba_number(struct ixgb_hw *hw)
|
||||
{
|
||||
if (ixgb_check_and_get_eeprom_data(hw) == true)
|
||||
|
@ -593,7 +593,7 @@ ixgb_get_ee_pba_number(struct ixgb_hw *hw)
|
|||
* Returns:
|
||||
* Device Id if EEPROM contents are valid, 0 otherwise
|
||||
******************************************************************************/
|
||||
uint16_t
|
||||
u16
|
||||
ixgb_get_ee_device_id(struct ixgb_hw *hw)
|
||||
{
|
||||
struct ixgb_ee_map_type *ee_map = (struct ixgb_ee_map_type *)hw->eeprom;
|
||||
|
|
|
@ -75,7 +75,7 @@
|
|||
|
||||
/* EEPROM structure */
|
||||
struct ixgb_ee_map_type {
|
||||
uint8_t mac_addr[IXGB_ETH_LENGTH_OF_ADDRESS];
|
||||
u8 mac_addr[IXGB_ETH_LENGTH_OF_ADDRESS];
|
||||
__le16 compatibility;
|
||||
__le16 reserved1[4];
|
||||
__le32 pba_number;
|
||||
|
@ -88,19 +88,19 @@ struct ixgb_ee_map_type {
|
|||
__le16 oem_reserved[16];
|
||||
__le16 swdpins_reg;
|
||||
__le16 circuit_ctrl_reg;
|
||||
uint8_t d3_power;
|
||||
uint8_t d0_power;
|
||||
u8 d3_power;
|
||||
u8 d0_power;
|
||||
__le16 reserved2[28];
|
||||
__le16 checksum;
|
||||
};
|
||||
|
||||
/* EEPROM Functions */
|
||||
uint16_t ixgb_read_eeprom(struct ixgb_hw *hw, uint16_t reg);
|
||||
u16 ixgb_read_eeprom(struct ixgb_hw *hw, u16 reg);
|
||||
|
||||
bool ixgb_validate_eeprom_checksum(struct ixgb_hw *hw);
|
||||
|
||||
void ixgb_update_eeprom_checksum(struct ixgb_hw *hw);
|
||||
|
||||
void ixgb_write_eeprom(struct ixgb_hw *hw, uint16_t reg, uint16_t data);
|
||||
void ixgb_write_eeprom(struct ixgb_hw *hw, u16 reg, u16 data);
|
||||
|
||||
#endif /* IXGB_EE_H */
|
||||
|
|
|
@ -185,7 +185,7 @@ ixgb_set_pauseparam(struct net_device *netdev,
|
|||
return 0;
|
||||
}
|
||||
|
||||
static uint32_t
|
||||
static u32
|
||||
ixgb_get_rx_csum(struct net_device *netdev)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
|
@ -194,7 +194,7 @@ ixgb_get_rx_csum(struct net_device *netdev)
|
|||
}
|
||||
|
||||
static int
|
||||
ixgb_set_rx_csum(struct net_device *netdev, uint32_t data)
|
||||
ixgb_set_rx_csum(struct net_device *netdev, u32 data)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
|
||||
|
@ -209,14 +209,14 @@ ixgb_set_rx_csum(struct net_device *netdev, uint32_t data)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static uint32_t
|
||||
static u32
|
||||
ixgb_get_tx_csum(struct net_device *netdev)
|
||||
{
|
||||
return (netdev->features & NETIF_F_HW_CSUM) != 0;
|
||||
}
|
||||
|
||||
static int
|
||||
ixgb_set_tx_csum(struct net_device *netdev, uint32_t data)
|
||||
ixgb_set_tx_csum(struct net_device *netdev, u32 data)
|
||||
{
|
||||
if (data)
|
||||
netdev->features |= NETIF_F_HW_CSUM;
|
||||
|
@ -227,7 +227,7 @@ ixgb_set_tx_csum(struct net_device *netdev, uint32_t data)
|
|||
}
|
||||
|
||||
static int
|
||||
ixgb_set_tso(struct net_device *netdev, uint32_t data)
|
||||
ixgb_set_tso(struct net_device *netdev, u32 data)
|
||||
{
|
||||
if(data)
|
||||
netdev->features |= NETIF_F_TSO;
|
||||
|
@ -236,7 +236,7 @@ ixgb_set_tso(struct net_device *netdev, uint32_t data)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static uint32_t
|
||||
static u32
|
||||
ixgb_get_msglevel(struct net_device *netdev)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
|
@ -244,7 +244,7 @@ ixgb_get_msglevel(struct net_device *netdev)
|
|||
}
|
||||
|
||||
static void
|
||||
ixgb_set_msglevel(struct net_device *netdev, uint32_t data)
|
||||
ixgb_set_msglevel(struct net_device *netdev, u32 data)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
adapter->msg_enable = data;
|
||||
|
@ -254,7 +254,7 @@ ixgb_set_msglevel(struct net_device *netdev, uint32_t data)
|
|||
static int
|
||||
ixgb_get_regs_len(struct net_device *netdev)
|
||||
{
|
||||
#define IXGB_REG_DUMP_LEN 136*sizeof(uint32_t)
|
||||
#define IXGB_REG_DUMP_LEN 136*sizeof(u32)
|
||||
return IXGB_REG_DUMP_LEN;
|
||||
}
|
||||
|
||||
|
@ -264,9 +264,9 @@ ixgb_get_regs(struct net_device *netdev,
|
|||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
struct ixgb_hw *hw = &adapter->hw;
|
||||
uint32_t *reg = p;
|
||||
uint32_t *reg_start = reg;
|
||||
uint8_t i;
|
||||
u32 *reg = p;
|
||||
u32 *reg_start = reg;
|
||||
u8 i;
|
||||
|
||||
/* the 1 (one) below indicates an attempt at versioning, if the
|
||||
* interface in ethtool or the driver changes, this 1 should be
|
||||
|
@ -395,7 +395,7 @@ ixgb_get_regs(struct net_device *netdev,
|
|||
*reg++ = IXGB_GET_STAT(adapter, xofftxc); /* 134 */
|
||||
*reg++ = IXGB_GET_STAT(adapter, rjc); /* 135 */
|
||||
|
||||
regs->len = (reg - reg_start) * sizeof(uint32_t);
|
||||
regs->len = (reg - reg_start) * sizeof(u32);
|
||||
}
|
||||
|
||||
static int
|
||||
|
@ -407,7 +407,7 @@ ixgb_get_eeprom_len(struct net_device *netdev)
|
|||
|
||||
static int
|
||||
ixgb_get_eeprom(struct net_device *netdev,
|
||||
struct ethtool_eeprom *eeprom, uint8_t *bytes)
|
||||
struct ethtool_eeprom *eeprom, u8 *bytes)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
struct ixgb_hw *hw = &adapter->hw;
|
||||
|
@ -445,7 +445,7 @@ ixgb_get_eeprom(struct net_device *netdev,
|
|||
eeprom_buff[i] = ixgb_get_eeprom_word(hw, (first_word + i));
|
||||
}
|
||||
|
||||
memcpy(bytes, (uint8_t *)eeprom_buff + (eeprom->offset & 1),
|
||||
memcpy(bytes, (u8 *)eeprom_buff + (eeprom->offset & 1),
|
||||
eeprom->len);
|
||||
kfree(eeprom_buff);
|
||||
|
||||
|
@ -455,14 +455,14 @@ geeprom_error:
|
|||
|
||||
static int
|
||||
ixgb_set_eeprom(struct net_device *netdev,
|
||||
struct ethtool_eeprom *eeprom, uint8_t *bytes)
|
||||
struct ethtool_eeprom *eeprom, u8 *bytes)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
struct ixgb_hw *hw = &adapter->hw;
|
||||
uint16_t *eeprom_buff;
|
||||
u16 *eeprom_buff;
|
||||
void *ptr;
|
||||
int max_len, first_word, last_word;
|
||||
uint16_t i;
|
||||
u16 i;
|
||||
|
||||
if(eeprom->len == 0)
|
||||
return -EINVAL;
|
||||
|
@ -563,12 +563,12 @@ ixgb_set_ringparam(struct net_device *netdev,
|
|||
if(netif_running(adapter->netdev))
|
||||
ixgb_down(adapter, true);
|
||||
|
||||
rxdr->count = max(ring->rx_pending,(uint32_t)MIN_RXD);
|
||||
rxdr->count = min(rxdr->count,(uint32_t)MAX_RXD);
|
||||
rxdr->count = max(ring->rx_pending,(u32)MIN_RXD);
|
||||
rxdr->count = min(rxdr->count,(u32)MAX_RXD);
|
||||
rxdr->count = ALIGN(rxdr->count, IXGB_REQ_RX_DESCRIPTOR_MULTIPLE);
|
||||
|
||||
txdr->count = max(ring->tx_pending,(uint32_t)MIN_TXD);
|
||||
txdr->count = min(txdr->count,(uint32_t)MAX_TXD);
|
||||
txdr->count = max(ring->tx_pending,(u32)MIN_TXD);
|
||||
txdr->count = min(txdr->count,(u32)MAX_TXD);
|
||||
txdr->count = ALIGN(txdr->count, IXGB_REQ_TX_DESCRIPTOR_MULTIPLE);
|
||||
|
||||
if(netif_running(adapter->netdev)) {
|
||||
|
@ -624,7 +624,7 @@ ixgb_led_blink_callback(unsigned long data)
|
|||
}
|
||||
|
||||
static int
|
||||
ixgb_phys_id(struct net_device *netdev, uint32_t data)
|
||||
ixgb_phys_id(struct net_device *netdev, u32 data)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
|
||||
|
@ -660,7 +660,7 @@ ixgb_get_sset_count(struct net_device *netdev, int sset)
|
|||
|
||||
static void
|
||||
ixgb_get_ethtool_stats(struct net_device *netdev,
|
||||
struct ethtool_stats *stats, uint64_t *data)
|
||||
struct ethtool_stats *stats, u64 *data)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
int i;
|
||||
|
@ -669,12 +669,12 @@ ixgb_get_ethtool_stats(struct net_device *netdev,
|
|||
for(i = 0; i < IXGB_STATS_LEN; i++) {
|
||||
char *p = (char *)adapter+ixgb_gstrings_stats[i].stat_offset;
|
||||
data[i] = (ixgb_gstrings_stats[i].sizeof_stat ==
|
||||
sizeof(uint64_t)) ? *(uint64_t *)p : *(uint32_t *)p;
|
||||
sizeof(u64)) ? *(u64 *)p : *(u32 *)p;
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
ixgb_get_strings(struct net_device *netdev, uint32_t stringset, uint8_t *data)
|
||||
ixgb_get_strings(struct net_device *netdev, u32 stringset, u8 *data)
|
||||
{
|
||||
int i;
|
||||
|
||||
|
|
|
@ -35,9 +35,9 @@
|
|||
|
||||
/* Local function prototypes */
|
||||
|
||||
static uint32_t ixgb_hash_mc_addr(struct ixgb_hw *hw, uint8_t * mc_addr);
|
||||
static u32 ixgb_hash_mc_addr(struct ixgb_hw *hw, u8 * mc_addr);
|
||||
|
||||
static void ixgb_mta_set(struct ixgb_hw *hw, uint32_t hash_value);
|
||||
static void ixgb_mta_set(struct ixgb_hw *hw, u32 hash_value);
|
||||
|
||||
static void ixgb_get_bus_info(struct ixgb_hw *hw);
|
||||
|
||||
|
@ -55,18 +55,18 @@ static void ixgb_clear_vfta(struct ixgb_hw *hw);
|
|||
|
||||
static void ixgb_init_rx_addrs(struct ixgb_hw *hw);
|
||||
|
||||
static uint16_t ixgb_read_phy_reg(struct ixgb_hw *hw,
|
||||
uint32_t reg_address,
|
||||
uint32_t phy_address,
|
||||
uint32_t device_type);
|
||||
static u16 ixgb_read_phy_reg(struct ixgb_hw *hw,
|
||||
u32 reg_address,
|
||||
u32 phy_address,
|
||||
u32 device_type);
|
||||
|
||||
static bool ixgb_setup_fc(struct ixgb_hw *hw);
|
||||
|
||||
static bool mac_addr_valid(uint8_t *mac_addr);
|
||||
static bool mac_addr_valid(u8 *mac_addr);
|
||||
|
||||
static uint32_t ixgb_mac_reset(struct ixgb_hw *hw)
|
||||
static u32 ixgb_mac_reset(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t ctrl_reg;
|
||||
u32 ctrl_reg;
|
||||
|
||||
ctrl_reg = IXGB_CTRL0_RST |
|
||||
IXGB_CTRL0_SDP3_DIR | /* All pins are Output=1 */
|
||||
|
@ -117,8 +117,8 @@ static uint32_t ixgb_mac_reset(struct ixgb_hw *hw)
|
|||
bool
|
||||
ixgb_adapter_stop(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t ctrl_reg;
|
||||
uint32_t icr_reg;
|
||||
u32 ctrl_reg;
|
||||
u32 icr_reg;
|
||||
|
||||
DEBUGFUNC("ixgb_adapter_stop");
|
||||
|
||||
|
@ -179,8 +179,8 @@ ixgb_adapter_stop(struct ixgb_hw *hw)
|
|||
static ixgb_xpak_vendor
|
||||
ixgb_identify_xpak_vendor(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t i;
|
||||
uint16_t vendor_name[5];
|
||||
u32 i;
|
||||
u16 vendor_name[5];
|
||||
ixgb_xpak_vendor xpak_vendor;
|
||||
|
||||
DEBUGFUNC("ixgb_identify_xpak_vendor");
|
||||
|
@ -292,8 +292,8 @@ ixgb_identify_phy(struct ixgb_hw *hw)
|
|||
bool
|
||||
ixgb_init_hw(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t i;
|
||||
uint32_t ctrl_reg;
|
||||
u32 i;
|
||||
u32 ctrl_reg;
|
||||
bool status;
|
||||
|
||||
DEBUGFUNC("ixgb_init_hw");
|
||||
|
@ -377,7 +377,7 @@ ixgb_init_hw(struct ixgb_hw *hw)
|
|||
static void
|
||||
ixgb_init_rx_addrs(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t i;
|
||||
u32 i;
|
||||
|
||||
DEBUGFUNC("ixgb_init_rx_addrs");
|
||||
|
||||
|
@ -437,13 +437,13 @@ ixgb_init_rx_addrs(struct ixgb_hw *hw)
|
|||
*****************************************************************************/
|
||||
void
|
||||
ixgb_mc_addr_list_update(struct ixgb_hw *hw,
|
||||
uint8_t *mc_addr_list,
|
||||
uint32_t mc_addr_count,
|
||||
uint32_t pad)
|
||||
u8 *mc_addr_list,
|
||||
u32 mc_addr_count,
|
||||
u32 pad)
|
||||
{
|
||||
uint32_t hash_value;
|
||||
uint32_t i;
|
||||
uint32_t rar_used_count = 1; /* RAR[0] is used for our MAC address */
|
||||
u32 hash_value;
|
||||
u32 i;
|
||||
u32 rar_used_count = 1; /* RAR[0] is used for our MAC address */
|
||||
|
||||
DEBUGFUNC("ixgb_mc_addr_list_update");
|
||||
|
||||
|
@ -515,11 +515,11 @@ ixgb_mc_addr_list_update(struct ixgb_hw *hw,
|
|||
* Returns:
|
||||
* The hash value
|
||||
*****************************************************************************/
|
||||
static uint32_t
|
||||
static u32
|
||||
ixgb_hash_mc_addr(struct ixgb_hw *hw,
|
||||
uint8_t *mc_addr)
|
||||
u8 *mc_addr)
|
||||
{
|
||||
uint32_t hash_value = 0;
|
||||
u32 hash_value = 0;
|
||||
|
||||
DEBUGFUNC("ixgb_hash_mc_addr");
|
||||
|
||||
|
@ -533,18 +533,18 @@ ixgb_hash_mc_addr(struct ixgb_hw *hw,
|
|||
case 0:
|
||||
/* [47:36] i.e. 0x563 for above example address */
|
||||
hash_value =
|
||||
((mc_addr[4] >> 4) | (((uint16_t) mc_addr[5]) << 4));
|
||||
((mc_addr[4] >> 4) | (((u16) mc_addr[5]) << 4));
|
||||
break;
|
||||
case 1: /* [46:35] i.e. 0xAC6 for above example address */
|
||||
hash_value =
|
||||
((mc_addr[4] >> 3) | (((uint16_t) mc_addr[5]) << 5));
|
||||
((mc_addr[4] >> 3) | (((u16) mc_addr[5]) << 5));
|
||||
break;
|
||||
case 2: /* [45:34] i.e. 0x5D8 for above example address */
|
||||
hash_value =
|
||||
((mc_addr[4] >> 2) | (((uint16_t) mc_addr[5]) << 6));
|
||||
((mc_addr[4] >> 2) | (((u16) mc_addr[5]) << 6));
|
||||
break;
|
||||
case 3: /* [43:32] i.e. 0x634 for above example address */
|
||||
hash_value = ((mc_addr[4]) | (((uint16_t) mc_addr[5]) << 8));
|
||||
hash_value = ((mc_addr[4]) | (((u16) mc_addr[5]) << 8));
|
||||
break;
|
||||
default:
|
||||
/* Invalid mc_filter_type, what should we do? */
|
||||
|
@ -565,10 +565,10 @@ ixgb_hash_mc_addr(struct ixgb_hw *hw,
|
|||
*****************************************************************************/
|
||||
static void
|
||||
ixgb_mta_set(struct ixgb_hw *hw,
|
||||
uint32_t hash_value)
|
||||
u32 hash_value)
|
||||
{
|
||||
uint32_t hash_bit, hash_reg;
|
||||
uint32_t mta_reg;
|
||||
u32 hash_bit, hash_reg;
|
||||
u32 mta_reg;
|
||||
|
||||
/* The MTA is a register array of 128 32-bit registers.
|
||||
* It is treated like an array of 4096 bits. We want to set
|
||||
|
@ -599,23 +599,23 @@ ixgb_mta_set(struct ixgb_hw *hw,
|
|||
*****************************************************************************/
|
||||
void
|
||||
ixgb_rar_set(struct ixgb_hw *hw,
|
||||
uint8_t *addr,
|
||||
uint32_t index)
|
||||
u8 *addr,
|
||||
u32 index)
|
||||
{
|
||||
uint32_t rar_low, rar_high;
|
||||
u32 rar_low, rar_high;
|
||||
|
||||
DEBUGFUNC("ixgb_rar_set");
|
||||
|
||||
/* HW expects these in little endian so we reverse the byte order
|
||||
* from network order (big endian) to little endian
|
||||
*/
|
||||
rar_low = ((uint32_t) addr[0] |
|
||||
((uint32_t)addr[1] << 8) |
|
||||
((uint32_t)addr[2] << 16) |
|
||||
((uint32_t)addr[3] << 24));
|
||||
rar_low = ((u32) addr[0] |
|
||||
((u32)addr[1] << 8) |
|
||||
((u32)addr[2] << 16) |
|
||||
((u32)addr[3] << 24));
|
||||
|
||||
rar_high = ((uint32_t) addr[4] |
|
||||
((uint32_t)addr[5] << 8) |
|
||||
rar_high = ((u32) addr[4] |
|
||||
((u32)addr[5] << 8) |
|
||||
IXGB_RAH_AV);
|
||||
|
||||
IXGB_WRITE_REG_ARRAY(hw, RA, (index << 1), rar_low);
|
||||
|
@ -632,8 +632,8 @@ ixgb_rar_set(struct ixgb_hw *hw,
|
|||
*****************************************************************************/
|
||||
void
|
||||
ixgb_write_vfta(struct ixgb_hw *hw,
|
||||
uint32_t offset,
|
||||
uint32_t value)
|
||||
u32 offset,
|
||||
u32 value)
|
||||
{
|
||||
IXGB_WRITE_REG_ARRAY(hw, VFTA, offset, value);
|
||||
return;
|
||||
|
@ -647,7 +647,7 @@ ixgb_write_vfta(struct ixgb_hw *hw,
|
|||
static void
|
||||
ixgb_clear_vfta(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t offset;
|
||||
u32 offset;
|
||||
|
||||
for(offset = 0; offset < IXGB_VLAN_FILTER_TBL_SIZE; offset++)
|
||||
IXGB_WRITE_REG_ARRAY(hw, VFTA, offset, 0);
|
||||
|
@ -663,8 +663,8 @@ ixgb_clear_vfta(struct ixgb_hw *hw)
|
|||
static bool
|
||||
ixgb_setup_fc(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t ctrl_reg;
|
||||
uint32_t pap_reg = 0; /* by default, assume no pause time */
|
||||
u32 ctrl_reg;
|
||||
u32 pap_reg = 0; /* by default, assume no pause time */
|
||||
bool status = true;
|
||||
|
||||
DEBUGFUNC("ixgb_setup_fc");
|
||||
|
@ -762,15 +762,15 @@ ixgb_setup_fc(struct ixgb_hw *hw)
|
|||
* This requires that first an address cycle command is sent, followed by a
|
||||
* read command.
|
||||
*****************************************************************************/
|
||||
static uint16_t
|
||||
static u16
|
||||
ixgb_read_phy_reg(struct ixgb_hw *hw,
|
||||
uint32_t reg_address,
|
||||
uint32_t phy_address,
|
||||
uint32_t device_type)
|
||||
u32 reg_address,
|
||||
u32 phy_address,
|
||||
u32 device_type)
|
||||
{
|
||||
uint32_t i;
|
||||
uint32_t data;
|
||||
uint32_t command = 0;
|
||||
u32 i;
|
||||
u32 data;
|
||||
u32 command = 0;
|
||||
|
||||
ASSERT(reg_address <= IXGB_MAX_PHY_REG_ADDRESS);
|
||||
ASSERT(phy_address <= IXGB_MAX_PHY_ADDRESS);
|
||||
|
@ -835,7 +835,7 @@ ixgb_read_phy_reg(struct ixgb_hw *hw,
|
|||
*/
|
||||
data = IXGB_READ_REG(hw, MSRWD);
|
||||
data >>= IXGB_MSRWD_READ_DATA_SHIFT;
|
||||
return((uint16_t) data);
|
||||
return((u16) data);
|
||||
}
|
||||
|
||||
/******************************************************************************
|
||||
|
@ -857,20 +857,20 @@ ixgb_read_phy_reg(struct ixgb_hw *hw,
|
|||
*****************************************************************************/
|
||||
static void
|
||||
ixgb_write_phy_reg(struct ixgb_hw *hw,
|
||||
uint32_t reg_address,
|
||||
uint32_t phy_address,
|
||||
uint32_t device_type,
|
||||
uint16_t data)
|
||||
u32 reg_address,
|
||||
u32 phy_address,
|
||||
u32 device_type,
|
||||
u16 data)
|
||||
{
|
||||
uint32_t i;
|
||||
uint32_t command = 0;
|
||||
u32 i;
|
||||
u32 command = 0;
|
||||
|
||||
ASSERT(reg_address <= IXGB_MAX_PHY_REG_ADDRESS);
|
||||
ASSERT(phy_address <= IXGB_MAX_PHY_ADDRESS);
|
||||
ASSERT(device_type <= IXGB_MAX_PHY_DEV_TYPE);
|
||||
|
||||
/* Put the data in the MDIO Read/Write Data register */
|
||||
IXGB_WRITE_REG(hw, MSRWD, (uint32_t)data);
|
||||
IXGB_WRITE_REG(hw, MSRWD, (u32)data);
|
||||
|
||||
/* Setup and write the address cycle command */
|
||||
command = ((reg_address << IXGB_MSCA_NP_ADDR_SHIFT) |
|
||||
|
@ -939,8 +939,8 @@ ixgb_write_phy_reg(struct ixgb_hw *hw,
|
|||
void
|
||||
ixgb_check_for_link(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t status_reg;
|
||||
uint32_t xpcss_reg;
|
||||
u32 status_reg;
|
||||
u32 xpcss_reg;
|
||||
|
||||
DEBUGFUNC("ixgb_check_for_link");
|
||||
|
||||
|
@ -975,7 +975,7 @@ ixgb_check_for_link(struct ixgb_hw *hw)
|
|||
*****************************************************************************/
|
||||
bool ixgb_check_for_bad_link(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t newLFC, newRFC;
|
||||
u32 newLFC, newRFC;
|
||||
bool bad_link_returncode = false;
|
||||
|
||||
if (hw->phy_type == ixgb_phy_type_txn17401) {
|
||||
|
@ -1002,7 +1002,7 @@ bool ixgb_check_for_bad_link(struct ixgb_hw *hw)
|
|||
static void
|
||||
ixgb_clear_hw_cntrs(struct ixgb_hw *hw)
|
||||
{
|
||||
volatile uint32_t temp_reg;
|
||||
volatile u32 temp_reg;
|
||||
|
||||
DEBUGFUNC("ixgb_clear_hw_cntrs");
|
||||
|
||||
|
@ -1083,7 +1083,7 @@ ixgb_clear_hw_cntrs(struct ixgb_hw *hw)
|
|||
void
|
||||
ixgb_led_on(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t ctrl0_reg = IXGB_READ_REG(hw, CTRL0);
|
||||
u32 ctrl0_reg = IXGB_READ_REG(hw, CTRL0);
|
||||
|
||||
/* To turn on the LED, clear software-definable pin 0 (SDP0). */
|
||||
ctrl0_reg &= ~IXGB_CTRL0_SDP0;
|
||||
|
@ -1099,7 +1099,7 @@ ixgb_led_on(struct ixgb_hw *hw)
|
|||
void
|
||||
ixgb_led_off(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t ctrl0_reg = IXGB_READ_REG(hw, CTRL0);
|
||||
u32 ctrl0_reg = IXGB_READ_REG(hw, CTRL0);
|
||||
|
||||
/* To turn off the LED, set software-definable pin 0 (SDP0). */
|
||||
ctrl0_reg |= IXGB_CTRL0_SDP0;
|
||||
|
@ -1115,7 +1115,7 @@ ixgb_led_off(struct ixgb_hw *hw)
|
|||
static void
|
||||
ixgb_get_bus_info(struct ixgb_hw *hw)
|
||||
{
|
||||
uint32_t status_reg;
|
||||
u32 status_reg;
|
||||
|
||||
status_reg = IXGB_READ_REG(hw, STATUS);
|
||||
|
||||
|
@ -1155,7 +1155,7 @@ ixgb_get_bus_info(struct ixgb_hw *hw)
|
|||
*
|
||||
*****************************************************************************/
|
||||
static bool
|
||||
mac_addr_valid(uint8_t *mac_addr)
|
||||
mac_addr_valid(u8 *mac_addr)
|
||||
{
|
||||
bool is_valid = true;
|
||||
DEBUGFUNC("mac_addr_valid");
|
||||
|
@ -1193,8 +1193,8 @@ static bool
|
|||
ixgb_link_reset(struct ixgb_hw *hw)
|
||||
{
|
||||
bool link_status = false;
|
||||
uint8_t wait_retries = MAX_RESET_ITERATIONS;
|
||||
uint8_t lrst_retries = MAX_RESET_ITERATIONS;
|
||||
u8 wait_retries = MAX_RESET_ITERATIONS;
|
||||
u8 lrst_retries = MAX_RESET_ITERATIONS;
|
||||
|
||||
do {
|
||||
/* Reset the link */
|
||||
|
@ -1224,7 +1224,7 @@ static void
|
|||
ixgb_optics_reset(struct ixgb_hw *hw)
|
||||
{
|
||||
if (hw->phy_type == ixgb_phy_type_txn17401) {
|
||||
uint16_t mdio_reg;
|
||||
u16 mdio_reg;
|
||||
|
||||
ixgb_write_phy_reg(hw,
|
||||
MDIO_PMA_PMD_CR1,
|
||||
|
|
|
@ -538,8 +538,8 @@ struct ixgb_rx_desc {
|
|||
__le64 buff_addr;
|
||||
__le16 length;
|
||||
__le16 reserved;
|
||||
uint8_t status;
|
||||
uint8_t errors;
|
||||
u8 status;
|
||||
u8 errors;
|
||||
__le16 special;
|
||||
};
|
||||
|
||||
|
@ -570,8 +570,8 @@ struct ixgb_rx_desc {
|
|||
struct ixgb_tx_desc {
|
||||
__le64 buff_addr;
|
||||
__le32 cmd_type_len;
|
||||
uint8_t status;
|
||||
uint8_t popts;
|
||||
u8 status;
|
||||
u8 popts;
|
||||
__le16 vlan;
|
||||
};
|
||||
|
||||
|
@ -595,15 +595,15 @@ struct ixgb_tx_desc {
|
|||
#define IXGB_TX_DESC_SPECIAL_PRI_SHIFT IXGB_RX_DESC_SPECIAL_PRI_SHIFT /* Priority is in upper 3 of 16 */
|
||||
|
||||
struct ixgb_context_desc {
|
||||
uint8_t ipcss;
|
||||
uint8_t ipcso;
|
||||
u8 ipcss;
|
||||
u8 ipcso;
|
||||
__le16 ipcse;
|
||||
uint8_t tucss;
|
||||
uint8_t tucso;
|
||||
u8 tucss;
|
||||
u8 tucso;
|
||||
__le16 tucse;
|
||||
__le32 cmd_type_len;
|
||||
uint8_t status;
|
||||
uint8_t hdr_len;
|
||||
u8 status;
|
||||
u8 hdr_len;
|
||||
__le16 mss;
|
||||
};
|
||||
|
||||
|
@ -637,32 +637,32 @@ struct ixgb_context_desc {
|
|||
|
||||
/* This structure takes a 64k flash and maps it for identification commands */
|
||||
struct ixgb_flash_buffer {
|
||||
uint8_t manufacturer_id;
|
||||
uint8_t device_id;
|
||||
uint8_t filler1[0x2AA8];
|
||||
uint8_t cmd2;
|
||||
uint8_t filler2[0x2AAA];
|
||||
uint8_t cmd1;
|
||||
uint8_t filler3[0xAAAA];
|
||||
u8 manufacturer_id;
|
||||
u8 device_id;
|
||||
u8 filler1[0x2AA8];
|
||||
u8 cmd2;
|
||||
u8 filler2[0x2AAA];
|
||||
u8 cmd1;
|
||||
u8 filler3[0xAAAA];
|
||||
};
|
||||
|
||||
/*
|
||||
* This is a little-endian specific check.
|
||||
*/
|
||||
#define IS_MULTICAST(Address) \
|
||||
(bool)(((uint8_t *)(Address))[0] & ((uint8_t)0x01))
|
||||
(bool)(((u8 *)(Address))[0] & ((u8)0x01))
|
||||
|
||||
/*
|
||||
* Check whether an address is broadcast.
|
||||
*/
|
||||
#define IS_BROADCAST(Address) \
|
||||
((((uint8_t *)(Address))[0] == ((uint8_t)0xff)) && (((uint8_t *)(Address))[1] == ((uint8_t)0xff)))
|
||||
((((u8 *)(Address))[0] == ((u8)0xff)) && (((u8 *)(Address))[1] == ((u8)0xff)))
|
||||
|
||||
/* Flow control parameters */
|
||||
struct ixgb_fc {
|
||||
uint32_t high_water; /* Flow Control High-water */
|
||||
uint32_t low_water; /* Flow Control Low-water */
|
||||
uint16_t pause_time; /* Flow Control Pause timer */
|
||||
u32 high_water; /* Flow Control High-water */
|
||||
u32 low_water; /* Flow Control Low-water */
|
||||
u16 pause_time; /* Flow Control Pause timer */
|
||||
bool send_xon; /* Flow control send XON */
|
||||
ixgb_fc_type type; /* Type of flow control */
|
||||
};
|
||||
|
@ -685,101 +685,101 @@ struct ixgb_bus {
|
|||
};
|
||||
|
||||
struct ixgb_hw {
|
||||
uint8_t __iomem *hw_addr;/* Base Address of the hardware */
|
||||
u8 __iomem *hw_addr;/* Base Address of the hardware */
|
||||
void *back; /* Pointer to OS-dependent struct */
|
||||
struct ixgb_fc fc; /* Flow control parameters */
|
||||
struct ixgb_bus bus; /* Bus parameters */
|
||||
uint32_t phy_id; /* Phy Identifier */
|
||||
uint32_t phy_addr; /* XGMII address of Phy */
|
||||
u32 phy_id; /* Phy Identifier */
|
||||
u32 phy_addr; /* XGMII address of Phy */
|
||||
ixgb_mac_type mac_type; /* Identifier for MAC controller */
|
||||
ixgb_phy_type phy_type; /* Transceiver/phy identifier */
|
||||
uint32_t max_frame_size; /* Maximum frame size supported */
|
||||
uint32_t mc_filter_type; /* Multicast filter hash type */
|
||||
uint32_t num_mc_addrs; /* Number of current Multicast addrs */
|
||||
uint8_t curr_mac_addr[IXGB_ETH_LENGTH_OF_ADDRESS]; /* Individual address currently programmed in MAC */
|
||||
uint32_t num_tx_desc; /* Number of Transmit descriptors */
|
||||
uint32_t num_rx_desc; /* Number of Receive descriptors */
|
||||
uint32_t rx_buffer_size; /* Size of Receive buffer */
|
||||
u32 max_frame_size; /* Maximum frame size supported */
|
||||
u32 mc_filter_type; /* Multicast filter hash type */
|
||||
u32 num_mc_addrs; /* Number of current Multicast addrs */
|
||||
u8 curr_mac_addr[IXGB_ETH_LENGTH_OF_ADDRESS]; /* Individual address currently programmed in MAC */
|
||||
u32 num_tx_desc; /* Number of Transmit descriptors */
|
||||
u32 num_rx_desc; /* Number of Receive descriptors */
|
||||
u32 rx_buffer_size; /* Size of Receive buffer */
|
||||
bool link_up; /* true if link is valid */
|
||||
bool adapter_stopped; /* State of adapter */
|
||||
uint16_t device_id; /* device id from PCI configuration space */
|
||||
uint16_t vendor_id; /* vendor id from PCI configuration space */
|
||||
uint8_t revision_id; /* revision id from PCI configuration space */
|
||||
uint16_t subsystem_vendor_id; /* subsystem vendor id from PCI configuration space */
|
||||
uint16_t subsystem_id; /* subsystem id from PCI configuration space */
|
||||
uint32_t bar0; /* Base Address registers */
|
||||
uint32_t bar1;
|
||||
uint32_t bar2;
|
||||
uint32_t bar3;
|
||||
uint16_t pci_cmd_word; /* PCI command register id from PCI configuration space */
|
||||
u16 device_id; /* device id from PCI configuration space */
|
||||
u16 vendor_id; /* vendor id from PCI configuration space */
|
||||
u8 revision_id; /* revision id from PCI configuration space */
|
||||
u16 subsystem_vendor_id; /* subsystem vendor id from PCI configuration space */
|
||||
u16 subsystem_id; /* subsystem id from PCI configuration space */
|
||||
u32 bar0; /* Base Address registers */
|
||||
u32 bar1;
|
||||
u32 bar2;
|
||||
u32 bar3;
|
||||
u16 pci_cmd_word; /* PCI command register id from PCI configuration space */
|
||||
__le16 eeprom[IXGB_EEPROM_SIZE]; /* EEPROM contents read at init time */
|
||||
unsigned long io_base; /* Our I/O mapped location */
|
||||
uint32_t lastLFC;
|
||||
uint32_t lastRFC;
|
||||
u32 lastLFC;
|
||||
u32 lastRFC;
|
||||
};
|
||||
|
||||
/* Statistics reported by the hardware */
|
||||
struct ixgb_hw_stats {
|
||||
uint64_t tprl;
|
||||
uint64_t tprh;
|
||||
uint64_t gprcl;
|
||||
uint64_t gprch;
|
||||
uint64_t bprcl;
|
||||
uint64_t bprch;
|
||||
uint64_t mprcl;
|
||||
uint64_t mprch;
|
||||
uint64_t uprcl;
|
||||
uint64_t uprch;
|
||||
uint64_t vprcl;
|
||||
uint64_t vprch;
|
||||
uint64_t jprcl;
|
||||
uint64_t jprch;
|
||||
uint64_t gorcl;
|
||||
uint64_t gorch;
|
||||
uint64_t torl;
|
||||
uint64_t torh;
|
||||
uint64_t rnbc;
|
||||
uint64_t ruc;
|
||||
uint64_t roc;
|
||||
uint64_t rlec;
|
||||
uint64_t crcerrs;
|
||||
uint64_t icbc;
|
||||
uint64_t ecbc;
|
||||
uint64_t mpc;
|
||||
uint64_t tptl;
|
||||
uint64_t tpth;
|
||||
uint64_t gptcl;
|
||||
uint64_t gptch;
|
||||
uint64_t bptcl;
|
||||
uint64_t bptch;
|
||||
uint64_t mptcl;
|
||||
uint64_t mptch;
|
||||
uint64_t uptcl;
|
||||
uint64_t uptch;
|
||||
uint64_t vptcl;
|
||||
uint64_t vptch;
|
||||
uint64_t jptcl;
|
||||
uint64_t jptch;
|
||||
uint64_t gotcl;
|
||||
uint64_t gotch;
|
||||
uint64_t totl;
|
||||
uint64_t toth;
|
||||
uint64_t dc;
|
||||
uint64_t plt64c;
|
||||
uint64_t tsctc;
|
||||
uint64_t tsctfc;
|
||||
uint64_t ibic;
|
||||
uint64_t rfc;
|
||||
uint64_t lfc;
|
||||
uint64_t pfrc;
|
||||
uint64_t pftc;
|
||||
uint64_t mcfrc;
|
||||
uint64_t mcftc;
|
||||
uint64_t xonrxc;
|
||||
uint64_t xontxc;
|
||||
uint64_t xoffrxc;
|
||||
uint64_t xofftxc;
|
||||
uint64_t rjc;
|
||||
u64 tprl;
|
||||
u64 tprh;
|
||||
u64 gprcl;
|
||||
u64 gprch;
|
||||
u64 bprcl;
|
||||
u64 bprch;
|
||||
u64 mprcl;
|
||||
u64 mprch;
|
||||
u64 uprcl;
|
||||
u64 uprch;
|
||||
u64 vprcl;
|
||||
u64 vprch;
|
||||
u64 jprcl;
|
||||
u64 jprch;
|
||||
u64 gorcl;
|
||||
u64 gorch;
|
||||
u64 torl;
|
||||
u64 torh;
|
||||
u64 rnbc;
|
||||
u64 ruc;
|
||||
u64 roc;
|
||||
u64 rlec;
|
||||
u64 crcerrs;
|
||||
u64 icbc;
|
||||
u64 ecbc;
|
||||
u64 mpc;
|
||||
u64 tptl;
|
||||
u64 tpth;
|
||||
u64 gptcl;
|
||||
u64 gptch;
|
||||
u64 bptcl;
|
||||
u64 bptch;
|
||||
u64 mptcl;
|
||||
u64 mptch;
|
||||
u64 uptcl;
|
||||
u64 uptch;
|
||||
u64 vptcl;
|
||||
u64 vptch;
|
||||
u64 jptcl;
|
||||
u64 jptch;
|
||||
u64 gotcl;
|
||||
u64 gotch;
|
||||
u64 totl;
|
||||
u64 toth;
|
||||
u64 dc;
|
||||
u64 plt64c;
|
||||
u64 tsctc;
|
||||
u64 tsctfc;
|
||||
u64 ibic;
|
||||
u64 rfc;
|
||||
u64 lfc;
|
||||
u64 pfrc;
|
||||
u64 pftc;
|
||||
u64 mcfrc;
|
||||
u64 mcftc;
|
||||
u64 xonrxc;
|
||||
u64 xontxc;
|
||||
u64 xoffrxc;
|
||||
u64 xofftxc;
|
||||
u64 rjc;
|
||||
};
|
||||
|
||||
/* Function Prototypes */
|
||||
|
@ -790,34 +790,34 @@ extern void ixgb_check_for_link(struct ixgb_hw *hw);
|
|||
extern bool ixgb_check_for_bad_link(struct ixgb_hw *hw);
|
||||
|
||||
extern void ixgb_rar_set(struct ixgb_hw *hw,
|
||||
uint8_t *addr,
|
||||
uint32_t index);
|
||||
u8 *addr,
|
||||
u32 index);
|
||||
|
||||
|
||||
/* Filters (multicast, vlan, receive) */
|
||||
extern void ixgb_mc_addr_list_update(struct ixgb_hw *hw,
|
||||
uint8_t *mc_addr_list,
|
||||
uint32_t mc_addr_count,
|
||||
uint32_t pad);
|
||||
u8 *mc_addr_list,
|
||||
u32 mc_addr_count,
|
||||
u32 pad);
|
||||
|
||||
/* Vfta functions */
|
||||
extern void ixgb_write_vfta(struct ixgb_hw *hw,
|
||||
uint32_t offset,
|
||||
uint32_t value);
|
||||
u32 offset,
|
||||
u32 value);
|
||||
|
||||
/* Access functions to eeprom data */
|
||||
void ixgb_get_ee_mac_addr(struct ixgb_hw *hw, uint8_t *mac_addr);
|
||||
uint32_t ixgb_get_ee_pba_number(struct ixgb_hw *hw);
|
||||
uint16_t ixgb_get_ee_device_id(struct ixgb_hw *hw);
|
||||
void ixgb_get_ee_mac_addr(struct ixgb_hw *hw, u8 *mac_addr);
|
||||
u32 ixgb_get_ee_pba_number(struct ixgb_hw *hw);
|
||||
u16 ixgb_get_ee_device_id(struct ixgb_hw *hw);
|
||||
bool ixgb_get_eeprom_data(struct ixgb_hw *hw);
|
||||
__le16 ixgb_get_eeprom_word(struct ixgb_hw *hw, uint16_t index);
|
||||
__le16 ixgb_get_eeprom_word(struct ixgb_hw *hw, u16 index);
|
||||
|
||||
/* Everything else */
|
||||
void ixgb_led_on(struct ixgb_hw *hw);
|
||||
void ixgb_led_off(struct ixgb_hw *hw);
|
||||
void ixgb_write_pci_cfg(struct ixgb_hw *hw,
|
||||
uint32_t reg,
|
||||
uint16_t * value);
|
||||
u32 reg,
|
||||
u16 * value);
|
||||
|
||||
|
||||
#endif /* _IXGB_HW_H_ */
|
||||
|
|
|
@ -108,8 +108,8 @@ static void ixgb_tx_timeout(struct net_device *dev);
|
|||
static void ixgb_tx_timeout_task(struct work_struct *work);
|
||||
static void ixgb_vlan_rx_register(struct net_device *netdev,
|
||||
struct vlan_group *grp);
|
||||
static void ixgb_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid);
|
||||
static void ixgb_vlan_rx_kill_vid(struct net_device *netdev, uint16_t vid);
|
||||
static void ixgb_vlan_rx_add_vid(struct net_device *netdev, u16 vid);
|
||||
static void ixgb_vlan_rx_kill_vid(struct net_device *netdev, u16 vid);
|
||||
static void ixgb_restore_vlan(struct ixgb_adapter *adapter);
|
||||
|
||||
#ifdef CONFIG_NET_POLL_CONTROLLER
|
||||
|
@ -271,7 +271,7 @@ ixgb_up(struct ixgb_adapter *adapter)
|
|||
|
||||
if(hw->max_frame_size >
|
||||
IXGB_MAX_ENET_FRAME_SIZE_WITHOUT_FCS + ENET_FCS_LENGTH) {
|
||||
uint32_t ctrl0 = IXGB_READ_REG(hw, CTRL0);
|
||||
u32 ctrl0 = IXGB_READ_REG(hw, CTRL0);
|
||||
|
||||
if(!(ctrl0 & IXGB_CTRL0_JFE)) {
|
||||
ctrl0 |= IXGB_CTRL0_JFE;
|
||||
|
@ -718,9 +718,9 @@ ixgb_setup_tx_resources(struct ixgb_adapter *adapter)
|
|||
static void
|
||||
ixgb_configure_tx(struct ixgb_adapter *adapter)
|
||||
{
|
||||
uint64_t tdba = adapter->tx_ring.dma;
|
||||
uint32_t tdlen = adapter->tx_ring.count * sizeof(struct ixgb_tx_desc);
|
||||
uint32_t tctl;
|
||||
u64 tdba = adapter->tx_ring.dma;
|
||||
u32 tdlen = adapter->tx_ring.count * sizeof(struct ixgb_tx_desc);
|
||||
u32 tctl;
|
||||
struct ixgb_hw *hw = &adapter->hw;
|
||||
|
||||
/* Setup the Base and Length of the Tx Descriptor Ring
|
||||
|
@ -806,7 +806,7 @@ ixgb_setup_rx_resources(struct ixgb_adapter *adapter)
|
|||
static void
|
||||
ixgb_setup_rctl(struct ixgb_adapter *adapter)
|
||||
{
|
||||
uint32_t rctl;
|
||||
u32 rctl;
|
||||
|
||||
rctl = IXGB_READ_REG(&adapter->hw, RCTL);
|
||||
|
||||
|
@ -841,12 +841,12 @@ ixgb_setup_rctl(struct ixgb_adapter *adapter)
|
|||
static void
|
||||
ixgb_configure_rx(struct ixgb_adapter *adapter)
|
||||
{
|
||||
uint64_t rdba = adapter->rx_ring.dma;
|
||||
uint32_t rdlen = adapter->rx_ring.count * sizeof(struct ixgb_rx_desc);
|
||||
u64 rdba = adapter->rx_ring.dma;
|
||||
u32 rdlen = adapter->rx_ring.count * sizeof(struct ixgb_rx_desc);
|
||||
struct ixgb_hw *hw = &adapter->hw;
|
||||
uint32_t rctl;
|
||||
uint32_t rxcsum;
|
||||
uint32_t rxdctl;
|
||||
u32 rctl;
|
||||
u32 rxcsum;
|
||||
u32 rxdctl;
|
||||
|
||||
/* make sure receives are disabled while setting up the descriptors */
|
||||
|
||||
|
@ -1079,7 +1079,7 @@ ixgb_set_multi(struct net_device *netdev)
|
|||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
struct ixgb_hw *hw = &adapter->hw;
|
||||
struct dev_mc_list *mc_ptr;
|
||||
uint32_t rctl;
|
||||
u32 rctl;
|
||||
int i;
|
||||
|
||||
/* Check for Promiscuous and All Multicast modes */
|
||||
|
@ -1099,7 +1099,7 @@ ixgb_set_multi(struct net_device *netdev)
|
|||
rctl |= IXGB_RCTL_MPE;
|
||||
IXGB_WRITE_REG(hw, RCTL, rctl);
|
||||
} else {
|
||||
uint8_t mta[IXGB_MAX_NUM_MULTICAST_ADDRESSES *
|
||||
u8 mta[IXGB_MAX_NUM_MULTICAST_ADDRESSES *
|
||||
IXGB_ETH_LENGTH_OF_ADDRESS];
|
||||
|
||||
IXGB_WRITE_REG(hw, RCTL, rctl);
|
||||
|
@ -1183,8 +1183,8 @@ ixgb_tso(struct ixgb_adapter *adapter, struct sk_buff *skb)
|
|||
{
|
||||
struct ixgb_context_desc *context_desc;
|
||||
unsigned int i;
|
||||
uint8_t ipcss, ipcso, tucss, tucso, hdr_len;
|
||||
uint16_t ipcse, tucse, mss;
|
||||
u8 ipcss, ipcso, tucss, tucso, hdr_len;
|
||||
u16 ipcse, tucse, mss;
|
||||
int err;
|
||||
|
||||
if (likely(skb_is_gso(skb))) {
|
||||
|
@ -1249,7 +1249,7 @@ ixgb_tx_csum(struct ixgb_adapter *adapter, struct sk_buff *skb)
|
|||
{
|
||||
struct ixgb_context_desc *context_desc;
|
||||
unsigned int i;
|
||||
uint8_t css, cso;
|
||||
u8 css, cso;
|
||||
|
||||
if(likely(skb->ip_summed == CHECKSUM_PARTIAL)) {
|
||||
struct ixgb_buffer *buffer_info;
|
||||
|
@ -1265,7 +1265,7 @@ ixgb_tx_csum(struct ixgb_adapter *adapter, struct sk_buff *skb)
|
|||
context_desc->tucso = cso;
|
||||
context_desc->tucse = 0;
|
||||
/* zero out any previously existing data in one instruction */
|
||||
*(uint32_t *)&(context_desc->ipcss) = 0;
|
||||
*(u32 *)&(context_desc->ipcss) = 0;
|
||||
context_desc->status = 0;
|
||||
context_desc->hdr_len = 0;
|
||||
context_desc->mss = 0;
|
||||
|
@ -1372,9 +1372,9 @@ ixgb_tx_queue(struct ixgb_adapter *adapter, int count, int vlan_id,int tx_flags)
|
|||
struct ixgb_desc_ring *tx_ring = &adapter->tx_ring;
|
||||
struct ixgb_tx_desc *tx_desc = NULL;
|
||||
struct ixgb_buffer *buffer_info;
|
||||
uint32_t cmd_type_len = adapter->tx_cmd_type;
|
||||
uint8_t status = 0;
|
||||
uint8_t popts = 0;
|
||||
u32 cmd_type_len = adapter->tx_cmd_type;
|
||||
u8 status = 0;
|
||||
u8 popts = 0;
|
||||
unsigned int i;
|
||||
|
||||
if(tx_flags & IXGB_TX_FLAGS_TSO) {
|
||||
|
@ -1750,7 +1750,7 @@ ixgb_intr(int irq, void *data)
|
|||
struct net_device *netdev = data;
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
struct ixgb_hw *hw = &adapter->hw;
|
||||
uint32_t icr = IXGB_READ_REG(hw, ICR);
|
||||
u32 icr = IXGB_READ_REG(hw, ICR);
|
||||
#ifndef CONFIG_IXGB_NAPI
|
||||
unsigned int i;
|
||||
#endif
|
||||
|
@ -1843,7 +1843,7 @@ ixgb_clean_tx_irq(struct ixgb_adapter *adapter)
|
|||
|
||||
ixgb_unmap_and_free_tx_resource(adapter, buffer_info);
|
||||
|
||||
*(uint32_t *)&(tx_desc->status) = 0;
|
||||
*(u32 *)&(tx_desc->status) = 0;
|
||||
|
||||
cleaned = (i == eop);
|
||||
if(++i == tx_ring->count) i = 0;
|
||||
|
@ -1948,7 +1948,7 @@ ixgb_clean_rx_irq(struct ixgb_adapter *adapter)
|
|||
struct pci_dev *pdev = adapter->pdev;
|
||||
struct ixgb_rx_desc *rx_desc, *next_rxd;
|
||||
struct ixgb_buffer *buffer_info, *next_buffer, *next2_buffer;
|
||||
uint32_t length;
|
||||
u32 length;
|
||||
unsigned int i, j;
|
||||
bool cleaned = false;
|
||||
|
||||
|
@ -2166,7 +2166,7 @@ static void
|
|||
ixgb_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
uint32_t ctrl, rctl;
|
||||
u32 ctrl, rctl;
|
||||
|
||||
ixgb_irq_disable(adapter);
|
||||
adapter->vlgrp = grp;
|
||||
|
@ -2203,10 +2203,10 @@ ixgb_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
|
|||
}
|
||||
|
||||
static void
|
||||
ixgb_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid)
|
||||
ixgb_vlan_rx_add_vid(struct net_device *netdev, u16 vid)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
uint32_t vfta, index;
|
||||
u32 vfta, index;
|
||||
|
||||
/* add VID to filter table */
|
||||
|
||||
|
@ -2217,10 +2217,10 @@ ixgb_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid)
|
|||
}
|
||||
|
||||
static void
|
||||
ixgb_vlan_rx_kill_vid(struct net_device *netdev, uint16_t vid)
|
||||
ixgb_vlan_rx_kill_vid(struct net_device *netdev, u16 vid)
|
||||
{
|
||||
struct ixgb_adapter *adapter = netdev_priv(netdev);
|
||||
uint32_t vfta, index;
|
||||
u32 vfta, index;
|
||||
|
||||
ixgb_irq_disable(adapter);
|
||||
|
||||
|
@ -2244,7 +2244,7 @@ ixgb_restore_vlan(struct ixgb_adapter *adapter)
|
|||
ixgb_vlan_rx_register(adapter->netdev, adapter->vlgrp);
|
||||
|
||||
if(adapter->vlgrp) {
|
||||
uint16_t vid;
|
||||
u16 vid;
|
||||
for(vid = 0; vid < VLAN_GROUP_ARRAY_LEN; vid++) {
|
||||
if(!vlan_group_get_device(adapter->vlgrp, vid))
|
||||
continue;
|
||||
|
|
|
@ -246,7 +246,7 @@ static int macb_mii_init(struct macb *bp)
|
|||
bp->mii_bus.read = &macb_mdio_read;
|
||||
bp->mii_bus.write = &macb_mdio_write;
|
||||
bp->mii_bus.reset = &macb_mdio_reset;
|
||||
bp->mii_bus.id = bp->pdev->id;
|
||||
snprintf(bp->mii_bus.id, MII_BUS_ID_SIZE, "%x", bp->pdev->id);
|
||||
bp->mii_bus.priv = bp;
|
||||
bp->mii_bus.dev = &bp->dev->dev;
|
||||
pdata = bp->pdev->dev.platform_data;
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -786,7 +786,8 @@ static int __devinit natsemi_probe1 (struct pci_dev *pdev,
|
|||
struct netdev_private *np;
|
||||
int i, option, irq, chip_idx = ent->driver_data;
|
||||
static int find_cnt = -1;
|
||||
unsigned long iostart, iosize;
|
||||
resource_size_t iostart;
|
||||
unsigned long iosize;
|
||||
void __iomem *ioaddr;
|
||||
const int pcibar = 1; /* PCI base address register */
|
||||
int prev_eedata;
|
||||
|
@ -946,10 +947,11 @@ static int __devinit natsemi_probe1 (struct pci_dev *pdev,
|
|||
goto err_create_file;
|
||||
|
||||
if (netif_msg_drv(np)) {
|
||||
printk(KERN_INFO "natsemi %s: %s at %#08lx "
|
||||
printk(KERN_INFO "natsemi %s: %s at %#08llx "
|
||||
"(%s), %s, IRQ %d",
|
||||
dev->name, natsemi_pci_info[chip_idx].name, iostart,
|
||||
pci_name(np->pci_dev), print_mac(mac, dev->dev_addr), irq);
|
||||
dev->name, natsemi_pci_info[chip_idx].name,
|
||||
(unsigned long long)iostart, pci_name(np->pci_dev),
|
||||
print_mac(mac, dev->dev_addr), irq);
|
||||
if (dev->if_port == PORT_TP)
|
||||
printk(", port TP.\n");
|
||||
else if (np->ignore_phy)
|
||||
|
|
|
@ -95,23 +95,6 @@
|
|||
|
||||
#define ADDR_IN_WINDOW1(off) \
|
||||
((off > NETXEN_CRB_PCIX_HOST2) && (off < NETXEN_CRB_MAX)) ? 1 : 0
|
||||
/*
|
||||
* In netxen_nic_down(), we must wait for any pending callback requests into
|
||||
* netxen_watchdog_task() to complete; eg otherwise the watchdog_timer could be
|
||||
* reenabled right after it is deleted in netxen_nic_down(). FLUSH_SCHEDULED_WORK()
|
||||
* does this synchronization.
|
||||
*
|
||||
* Normally, schedule_work()/flush_scheduled_work() could have worked, but
|
||||
* netxen_nic_close() is invoked with kernel rtnl lock held. netif_carrier_off()
|
||||
* call in netxen_nic_close() triggers a schedule_work(&linkwatch_work), and a
|
||||
* subsequent call to flush_scheduled_work() in netxen_nic_down() would cause
|
||||
* linkwatch_event() to be executed which also attempts to acquire the rtnl
|
||||
* lock thus causing a deadlock.
|
||||
*/
|
||||
|
||||
#define SCHEDULE_WORK(tp) queue_work(netxen_workq, tp)
|
||||
#define FLUSH_SCHEDULED_WORK() flush_workqueue(netxen_workq)
|
||||
extern struct workqueue_struct *netxen_workq;
|
||||
|
||||
/*
|
||||
* normalize a 64MB crb address to 32MB PCI window
|
||||
|
@ -1050,7 +1033,6 @@ void netxen_halt_pegs(struct netxen_adapter *adapter);
|
|||
int netxen_rom_se(struct netxen_adapter *adapter, int addr);
|
||||
|
||||
/* Functions from netxen_nic_isr.c */
|
||||
int netxen_nic_link_ok(struct netxen_adapter *adapter);
|
||||
void netxen_initialize_adapter_sw(struct netxen_adapter *adapter);
|
||||
void netxen_initialize_adapter_hw(struct netxen_adapter *adapter);
|
||||
void *netxen_alloc(struct pci_dev *pdev, size_t sz, dma_addr_t * ptr,
|
||||
|
|
|
@ -172,6 +172,7 @@ void netxen_nic_gbe_handle_phy_intr(struct netxen_adapter *adapter)
|
|||
netxen_nic_isr_other(adapter);
|
||||
}
|
||||
|
||||
#if 0
|
||||
int netxen_nic_link_ok(struct netxen_adapter *adapter)
|
||||
{
|
||||
switch (adapter->ahw.board_type) {
|
||||
|
@ -189,6 +190,7 @@ int netxen_nic_link_ok(struct netxen_adapter *adapter)
|
|||
|
||||
return 0;
|
||||
}
|
||||
#endif /* 0 */
|
||||
|
||||
void netxen_nic_xgbe_handle_phy_intr(struct netxen_adapter *adapter)
|
||||
{
|
||||
|
|
|
@ -86,7 +86,24 @@ static struct pci_device_id netxen_pci_tbl[] __devinitdata = {
|
|||
|
||||
MODULE_DEVICE_TABLE(pci, netxen_pci_tbl);
|
||||
|
||||
struct workqueue_struct *netxen_workq;
|
||||
/*
|
||||
* In netxen_nic_down(), we must wait for any pending callback requests into
|
||||
* netxen_watchdog_task() to complete; eg otherwise the watchdog_timer could be
|
||||
* reenabled right after it is deleted in netxen_nic_down().
|
||||
* FLUSH_SCHEDULED_WORK() does this synchronization.
|
||||
*
|
||||
* Normally, schedule_work()/flush_scheduled_work() could have worked, but
|
||||
* netxen_nic_close() is invoked with kernel rtnl lock held. netif_carrier_off()
|
||||
* call in netxen_nic_close() triggers a schedule_work(&linkwatch_work), and a
|
||||
* subsequent call to flush_scheduled_work() in netxen_nic_down() would cause
|
||||
* linkwatch_event() to be executed which also attempts to acquire the rtnl
|
||||
* lock thus causing a deadlock.
|
||||
*/
|
||||
|
||||
static struct workqueue_struct *netxen_workq;
|
||||
#define SCHEDULE_WORK(tp) queue_work(netxen_workq, tp)
|
||||
#define FLUSH_SCHEDULED_WORK() flush_workqueue(netxen_workq)
|
||||
|
||||
static void netxen_watchdog(unsigned long);
|
||||
|
||||
static void netxen_nic_update_cmd_producer(struct netxen_adapter *adapter,
|
||||
|
|
|
@ -1012,7 +1012,7 @@ static int pasemi_mac_phy_init(struct net_device *dev)
|
|||
goto err;
|
||||
|
||||
phy_id = *prop;
|
||||
snprintf(mac->phy_id, BUS_ID_SIZE, PHY_ID_FMT, (int)r.start, phy_id);
|
||||
snprintf(mac->phy_id, BUS_ID_SIZE, "%x:%02x", (int)r.start, phy_id);
|
||||
|
||||
of_node_put(phy_dn);
|
||||
|
||||
|
|
|
@ -176,6 +176,20 @@ static struct phy_driver bcm5461_driver = {
|
|||
.driver = { .owner = THIS_MODULE },
|
||||
};
|
||||
|
||||
static struct phy_driver bcm5464_driver = {
|
||||
.phy_id = 0x002060b0,
|
||||
.phy_id_mask = 0xfffffff0,
|
||||
.name = "Broadcom BCM5464",
|
||||
.features = PHY_GBIT_FEATURES,
|
||||
.flags = PHY_HAS_MAGICANEG | PHY_HAS_INTERRUPT,
|
||||
.config_init = bcm54xx_config_init,
|
||||
.config_aneg = genphy_config_aneg,
|
||||
.read_status = genphy_read_status,
|
||||
.ack_interrupt = bcm54xx_ack_interrupt,
|
||||
.config_intr = bcm54xx_config_intr,
|
||||
.driver = { .owner = THIS_MODULE },
|
||||
};
|
||||
|
||||
static struct phy_driver bcm5481_driver = {
|
||||
.phy_id = 0x0143bca0,
|
||||
.phy_id_mask = 0xfffffff0,
|
||||
|
@ -217,6 +231,9 @@ static int __init broadcom_init(void)
|
|||
ret = phy_driver_register(&bcm5461_driver);
|
||||
if (ret)
|
||||
goto out_5461;
|
||||
ret = phy_driver_register(&bcm5464_driver);
|
||||
if (ret)
|
||||
goto out_5464;
|
||||
ret = phy_driver_register(&bcm5481_driver);
|
||||
if (ret)
|
||||
goto out_5481;
|
||||
|
@ -228,6 +245,8 @@ static int __init broadcom_init(void)
|
|||
out_5482:
|
||||
phy_driver_unregister(&bcm5481_driver);
|
||||
out_5481:
|
||||
phy_driver_unregister(&bcm5464_driver);
|
||||
out_5464:
|
||||
phy_driver_unregister(&bcm5461_driver);
|
||||
out_5461:
|
||||
phy_driver_unregister(&bcm5421_driver);
|
||||
|
@ -241,6 +260,7 @@ static void __exit broadcom_exit(void)
|
|||
{
|
||||
phy_driver_unregister(&bcm5482_driver);
|
||||
phy_driver_unregister(&bcm5481_driver);
|
||||
phy_driver_unregister(&bcm5464_driver);
|
||||
phy_driver_unregister(&bcm5461_driver);
|
||||
phy_driver_unregister(&bcm5421_driver);
|
||||
phy_driver_unregister(&bcm5411_driver);
|
||||
|
|
|
@ -213,7 +213,7 @@ static int __init fixed_mdio_bus_init(void)
|
|||
goto err_pdev;
|
||||
}
|
||||
|
||||
fmb->mii_bus.id = 0;
|
||||
snprintf(fmb->mii_bus.id, MII_BUS_ID_SIZE, "0");
|
||||
fmb->mii_bus.name = "Fixed MDIO Bus";
|
||||
fmb->mii_bus.dev = &pdev->dev;
|
||||
fmb->mii_bus.read = &fixed_mdio_read;
|
||||
|
|
|
@ -85,6 +85,39 @@ struct phy_device* phy_device_create(struct mii_bus *bus, int addr, int phy_id)
|
|||
}
|
||||
EXPORT_SYMBOL(phy_device_create);
|
||||
|
||||
/**
|
||||
* get_phy_id - reads the specified addr for its ID.
|
||||
* @bus: the target MII bus
|
||||
* @addr: PHY address on the MII bus
|
||||
* @phy_id: where to store the ID retrieved.
|
||||
*
|
||||
* Description: Reads the ID registers of the PHY at @addr on the
|
||||
* @bus, stores it in @phy_id and returns zero on success.
|
||||
*/
|
||||
int get_phy_id(struct mii_bus *bus, int addr, u32 *phy_id)
|
||||
{
|
||||
int phy_reg;
|
||||
|
||||
/* Grab the bits from PHYIR1, and put them
|
||||
* in the upper half */
|
||||
phy_reg = bus->read(bus, addr, MII_PHYSID1);
|
||||
|
||||
if (phy_reg < 0)
|
||||
return -EIO;
|
||||
|
||||
*phy_id = (phy_reg & 0xffff) << 16;
|
||||
|
||||
/* Grab the bits from PHYIR2, and put them in the lower half */
|
||||
phy_reg = bus->read(bus, addr, MII_PHYSID2);
|
||||
|
||||
if (phy_reg < 0)
|
||||
return -EIO;
|
||||
|
||||
*phy_id |= (phy_reg & 0xffff);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* get_phy_device - reads the specified PHY device and returns its @phy_device struct
|
||||
* @bus: the target MII bus
|
||||
|
@ -95,26 +128,13 @@ EXPORT_SYMBOL(phy_device_create);
|
|||
*/
|
||||
struct phy_device * get_phy_device(struct mii_bus *bus, int addr)
|
||||
{
|
||||
int phy_reg;
|
||||
u32 phy_id;
|
||||
struct phy_device *dev = NULL;
|
||||
u32 phy_id;
|
||||
int r;
|
||||
|
||||
/* Grab the bits from PHYIR1, and put them
|
||||
* in the upper half */
|
||||
phy_reg = bus->read(bus, addr, MII_PHYSID1);
|
||||
|
||||
if (phy_reg < 0)
|
||||
return ERR_PTR(phy_reg);
|
||||
|
||||
phy_id = (phy_reg & 0xffff) << 16;
|
||||
|
||||
/* Grab the bits from PHYIR2, and put them in the lower half */
|
||||
phy_reg = bus->read(bus, addr, MII_PHYSID2);
|
||||
|
||||
if (phy_reg < 0)
|
||||
return ERR_PTR(phy_reg);
|
||||
|
||||
phy_id |= (phy_reg & 0xffff);
|
||||
r = get_phy_id(bus, addr, &phy_id);
|
||||
if (r)
|
||||
return ERR_PTR(r);
|
||||
|
||||
/* If the phy_id is all Fs, there is no device there */
|
||||
if (0xffffffff == phy_id)
|
||||
|
|
|
@ -88,31 +88,31 @@ static int sb1000_close(struct net_device *dev);
|
|||
|
||||
|
||||
/* SB1000 hardware routines to be used during open/configuration phases */
|
||||
static inline int card_wait_for_busy_clear(const int ioaddr[],
|
||||
static int card_wait_for_busy_clear(const int ioaddr[],
|
||||
const char* name);
|
||||
static inline int card_wait_for_ready(const int ioaddr[], const char* name,
|
||||
static int card_wait_for_ready(const int ioaddr[], const char* name,
|
||||
unsigned char in[]);
|
||||
static int card_send_command(const int ioaddr[], const char* name,
|
||||
const unsigned char out[], unsigned char in[]);
|
||||
|
||||
/* SB1000 hardware routines to be used during frame rx interrupt */
|
||||
static inline int sb1000_wait_for_ready(const int ioaddr[], const char* name);
|
||||
static inline int sb1000_wait_for_ready_clear(const int ioaddr[],
|
||||
static int sb1000_wait_for_ready(const int ioaddr[], const char* name);
|
||||
static int sb1000_wait_for_ready_clear(const int ioaddr[],
|
||||
const char* name);
|
||||
static inline void sb1000_send_command(const int ioaddr[], const char* name,
|
||||
static void sb1000_send_command(const int ioaddr[], const char* name,
|
||||
const unsigned char out[]);
|
||||
static inline void sb1000_read_status(const int ioaddr[], unsigned char in[]);
|
||||
static inline void sb1000_issue_read_command(const int ioaddr[],
|
||||
static void sb1000_read_status(const int ioaddr[], unsigned char in[]);
|
||||
static void sb1000_issue_read_command(const int ioaddr[],
|
||||
const char* name);
|
||||
|
||||
/* SB1000 commands for open/configuration */
|
||||
static inline int sb1000_reset(const int ioaddr[], const char* name);
|
||||
static inline int sb1000_check_CRC(const int ioaddr[], const char* name);
|
||||
static int sb1000_reset(const int ioaddr[], const char* name);
|
||||
static int sb1000_check_CRC(const int ioaddr[], const char* name);
|
||||
static inline int sb1000_start_get_set_command(const int ioaddr[],
|
||||
const char* name);
|
||||
static inline int sb1000_end_get_set_command(const int ioaddr[],
|
||||
static int sb1000_end_get_set_command(const int ioaddr[],
|
||||
const char* name);
|
||||
static inline int sb1000_activate(const int ioaddr[], const char* name);
|
||||
static int sb1000_activate(const int ioaddr[], const char* name);
|
||||
static int sb1000_get_firmware_version(const int ioaddr[],
|
||||
const char* name, unsigned char version[], int do_end);
|
||||
static int sb1000_get_frequency(const int ioaddr[], const char* name,
|
||||
|
@ -125,8 +125,8 @@ static int sb1000_set_PIDs(const int ioaddr[], const char* name,
|
|||
const short PID[]);
|
||||
|
||||
/* SB1000 commands for frame rx interrupt */
|
||||
static inline int sb1000_rx(struct net_device *dev);
|
||||
static inline void sb1000_error_dpc(struct net_device *dev);
|
||||
static int sb1000_rx(struct net_device *dev);
|
||||
static void sb1000_error_dpc(struct net_device *dev);
|
||||
|
||||
static const struct pnp_device_id sb1000_pnp_ids[] = {
|
||||
{ "GIC1000", 0 },
|
||||
|
@ -250,7 +250,7 @@ static struct pnp_driver sb1000_driver = {
|
|||
static const int TimeOutJiffies = (875 * HZ) / 100;
|
||||
|
||||
/* Card Wait For Busy Clear (cannot be used during an interrupt) */
|
||||
static inline int
|
||||
static int
|
||||
card_wait_for_busy_clear(const int ioaddr[], const char* name)
|
||||
{
|
||||
unsigned char a;
|
||||
|
@ -274,7 +274,7 @@ card_wait_for_busy_clear(const int ioaddr[], const char* name)
|
|||
}
|
||||
|
||||
/* Card Wait For Ready (cannot be used during an interrupt) */
|
||||
static inline int
|
||||
static int
|
||||
card_wait_for_ready(const int ioaddr[], const char* name, unsigned char in[])
|
||||
{
|
||||
unsigned char a;
|
||||
|
@ -354,7 +354,7 @@ card_send_command(const int ioaddr[], const char* name,
|
|||
static const int Sb1000TimeOutJiffies = 7 * HZ;
|
||||
|
||||
/* Card Wait For Ready (to be used during frame rx) */
|
||||
static inline int
|
||||
static int
|
||||
sb1000_wait_for_ready(const int ioaddr[], const char* name)
|
||||
{
|
||||
unsigned long timeout;
|
||||
|
@ -380,7 +380,7 @@ sb1000_wait_for_ready(const int ioaddr[], const char* name)
|
|||
}
|
||||
|
||||
/* Card Wait For Ready Clear (to be used during frame rx) */
|
||||
static inline int
|
||||
static int
|
||||
sb1000_wait_for_ready_clear(const int ioaddr[], const char* name)
|
||||
{
|
||||
unsigned long timeout;
|
||||
|
@ -405,7 +405,7 @@ sb1000_wait_for_ready_clear(const int ioaddr[], const char* name)
|
|||
}
|
||||
|
||||
/* Card Send Command (to be used during frame rx) */
|
||||
static inline void
|
||||
static void
|
||||
sb1000_send_command(const int ioaddr[], const char* name,
|
||||
const unsigned char out[])
|
||||
{
|
||||
|
@ -422,7 +422,7 @@ sb1000_send_command(const int ioaddr[], const char* name,
|
|||
}
|
||||
|
||||
/* Card Read Status (to be used during frame rx) */
|
||||
static inline void
|
||||
static void
|
||||
sb1000_read_status(const int ioaddr[], unsigned char in[])
|
||||
{
|
||||
in[1] = inb(ioaddr[0] + 1);
|
||||
|
@ -434,10 +434,10 @@ sb1000_read_status(const int ioaddr[], unsigned char in[])
|
|||
}
|
||||
|
||||
/* Issue Read Command (to be used during frame rx) */
|
||||
static inline void
|
||||
static void
|
||||
sb1000_issue_read_command(const int ioaddr[], const char* name)
|
||||
{
|
||||
const unsigned char Command0[6] = {0x20, 0x00, 0x00, 0x01, 0x00, 0x00};
|
||||
static const unsigned char Command0[6] = {0x20, 0x00, 0x00, 0x01, 0x00, 0x00};
|
||||
|
||||
sb1000_wait_for_ready_clear(ioaddr, name);
|
||||
outb(0xa0, ioaddr[0] + 6);
|
||||
|
@ -450,12 +450,13 @@ sb1000_issue_read_command(const int ioaddr[], const char* name)
|
|||
* SB1000 commands for open/configuration
|
||||
*/
|
||||
/* reset SB1000 card */
|
||||
static inline int
|
||||
static int
|
||||
sb1000_reset(const int ioaddr[], const char* name)
|
||||
{
|
||||
static const unsigned char Command0[6] = {0x80, 0x16, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
unsigned char st[7];
|
||||
int port, status;
|
||||
const unsigned char Command0[6] = {0x80, 0x16, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
port = ioaddr[1] + 6;
|
||||
outb(0x4, port);
|
||||
|
@ -479,12 +480,13 @@ sb1000_reset(const int ioaddr[], const char* name)
|
|||
}
|
||||
|
||||
/* check SB1000 firmware CRC */
|
||||
static inline int
|
||||
static int
|
||||
sb1000_check_CRC(const int ioaddr[], const char* name)
|
||||
{
|
||||
static const unsigned char Command0[6] = {0x80, 0x1f, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
unsigned char st[7];
|
||||
int crc, status;
|
||||
const unsigned char Command0[6] = {0x80, 0x1f, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
/* check CRC */
|
||||
if ((status = card_send_command(ioaddr, name, Command0, st)))
|
||||
|
@ -498,32 +500,35 @@ sb1000_check_CRC(const int ioaddr[], const char* name)
|
|||
static inline int
|
||||
sb1000_start_get_set_command(const int ioaddr[], const char* name)
|
||||
{
|
||||
static const unsigned char Command0[6] = {0x80, 0x1b, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
unsigned char st[7];
|
||||
const unsigned char Command0[6] = {0x80, 0x1b, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
return card_send_command(ioaddr, name, Command0, st);
|
||||
}
|
||||
|
||||
static inline int
|
||||
static int
|
||||
sb1000_end_get_set_command(const int ioaddr[], const char* name)
|
||||
{
|
||||
static const unsigned char Command0[6] = {0x80, 0x1b, 0x02, 0x00, 0x00, 0x00};
|
||||
static const unsigned char Command1[6] = {0x20, 0x00, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
unsigned char st[7];
|
||||
int status;
|
||||
const unsigned char Command0[6] = {0x80, 0x1b, 0x02, 0x00, 0x00, 0x00};
|
||||
const unsigned char Command1[6] = {0x20, 0x00, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
if ((status = card_send_command(ioaddr, name, Command0, st)))
|
||||
return status;
|
||||
return card_send_command(ioaddr, name, Command1, st);
|
||||
}
|
||||
|
||||
static inline int
|
||||
static int
|
||||
sb1000_activate(const int ioaddr[], const char* name)
|
||||
{
|
||||
static const unsigned char Command0[6] = {0x80, 0x11, 0x00, 0x00, 0x00, 0x00};
|
||||
static const unsigned char Command1[6] = {0x80, 0x16, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
unsigned char st[7];
|
||||
int status;
|
||||
const unsigned char Command0[6] = {0x80, 0x11, 0x00, 0x00, 0x00, 0x00};
|
||||
const unsigned char Command1[6] = {0x80, 0x16, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
ssleep(1);
|
||||
if ((status = card_send_command(ioaddr, name, Command0, st)))
|
||||
|
@ -544,9 +549,10 @@ static int
|
|||
sb1000_get_firmware_version(const int ioaddr[], const char* name,
|
||||
unsigned char version[], int do_end)
|
||||
{
|
||||
static const unsigned char Command0[6] = {0x80, 0x23, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
unsigned char st[7];
|
||||
int status;
|
||||
const unsigned char Command0[6] = {0x80, 0x23, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
if ((status = sb1000_start_get_set_command(ioaddr, name)))
|
||||
return status;
|
||||
|
@ -566,9 +572,10 @@ sb1000_get_firmware_version(const int ioaddr[], const char* name,
|
|||
static int
|
||||
sb1000_get_frequency(const int ioaddr[], const char* name, int* frequency)
|
||||
{
|
||||
static const unsigned char Command0[6] = {0x80, 0x44, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
unsigned char st[7];
|
||||
int status;
|
||||
const unsigned char Command0[6] = {0x80, 0x44, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
udelay(1000);
|
||||
if ((status = sb1000_start_get_set_command(ioaddr, name)))
|
||||
|
@ -613,12 +620,13 @@ sb1000_set_frequency(const int ioaddr[], const char* name, int frequency)
|
|||
static int
|
||||
sb1000_get_PIDs(const int ioaddr[], const char* name, short PID[])
|
||||
{
|
||||
static const unsigned char Command0[6] = {0x80, 0x40, 0x00, 0x00, 0x00, 0x00};
|
||||
static const unsigned char Command1[6] = {0x80, 0x41, 0x00, 0x00, 0x00, 0x00};
|
||||
static const unsigned char Command2[6] = {0x80, 0x42, 0x00, 0x00, 0x00, 0x00};
|
||||
static const unsigned char Command3[6] = {0x80, 0x43, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
unsigned char st[7];
|
||||
int status;
|
||||
const unsigned char Command0[6] = {0x80, 0x40, 0x00, 0x00, 0x00, 0x00};
|
||||
const unsigned char Command1[6] = {0x80, 0x41, 0x00, 0x00, 0x00, 0x00};
|
||||
const unsigned char Command2[6] = {0x80, 0x42, 0x00, 0x00, 0x00, 0x00};
|
||||
const unsigned char Command3[6] = {0x80, 0x43, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
udelay(1000);
|
||||
if ((status = sb1000_start_get_set_command(ioaddr, name)))
|
||||
|
@ -647,6 +655,8 @@ sb1000_get_PIDs(const int ioaddr[], const char* name, short PID[])
|
|||
static int
|
||||
sb1000_set_PIDs(const int ioaddr[], const char* name, const short PID[])
|
||||
{
|
||||
static const unsigned char Command4[6] = {0x80, 0x2e, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
unsigned char st[7];
|
||||
short p;
|
||||
int status;
|
||||
|
@ -654,7 +664,6 @@ sb1000_set_PIDs(const int ioaddr[], const char* name, const short PID[])
|
|||
unsigned char Command1[6] = {0x80, 0x32, 0x00, 0x00, 0x00, 0x00};
|
||||
unsigned char Command2[6] = {0x80, 0x33, 0x00, 0x00, 0x00, 0x00};
|
||||
unsigned char Command3[6] = {0x80, 0x34, 0x00, 0x00, 0x00, 0x00};
|
||||
const unsigned char Command4[6] = {0x80, 0x2e, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
udelay(1000);
|
||||
if ((status = sb1000_start_get_set_command(ioaddr, name)))
|
||||
|
@ -694,7 +703,7 @@ sb1000_set_PIDs(const int ioaddr[], const char* name, const short PID[])
|
|||
}
|
||||
|
||||
|
||||
static inline void
|
||||
static void
|
||||
sb1000_print_status_buffer(const char* name, unsigned char st[],
|
||||
unsigned char buffer[], int size)
|
||||
{
|
||||
|
@ -725,7 +734,7 @@ sb1000_print_status_buffer(const char* name, unsigned char st[],
|
|||
/* receive a single frame and assemble datagram
|
||||
* (this is the heart of the interrupt routine)
|
||||
*/
|
||||
static inline int
|
||||
static int
|
||||
sb1000_rx(struct net_device *dev)
|
||||
{
|
||||
|
||||
|
@ -888,14 +897,15 @@ dropped_frame:
|
|||
return -1;
|
||||
}
|
||||
|
||||
static inline void
|
||||
static void
|
||||
sb1000_error_dpc(struct net_device *dev)
|
||||
{
|
||||
static const unsigned char Command0[6] = {0x80, 0x26, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
char *name;
|
||||
unsigned char st[5];
|
||||
int ioaddr[2];
|
||||
struct sb1000_private *lp = netdev_priv(dev);
|
||||
const unsigned char Command0[6] = {0x80, 0x26, 0x00, 0x00, 0x00, 0x00};
|
||||
const int ErrorDpcCounterInitialize = 200;
|
||||
|
||||
ioaddr[0] = dev->base_addr;
|
||||
|
@ -1077,14 +1087,15 @@ sb1000_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
|||
/* SB1000 interrupt handler. */
|
||||
static irqreturn_t sb1000_interrupt(int irq, void *dev_id)
|
||||
{
|
||||
static const unsigned char Command0[6] = {0x80, 0x2c, 0x00, 0x00, 0x00, 0x00};
|
||||
static const unsigned char Command1[6] = {0x80, 0x2e, 0x00, 0x00, 0x00, 0x00};
|
||||
|
||||
char *name;
|
||||
unsigned char st;
|
||||
int ioaddr[2];
|
||||
struct net_device *dev = dev_id;
|
||||
struct sb1000_private *lp = netdev_priv(dev);
|
||||
|
||||
const unsigned char Command0[6] = {0x80, 0x2c, 0x00, 0x00, 0x00, 0x00};
|
||||
const unsigned char Command1[6] = {0x80, 0x2e, 0x00, 0x00, 0x00, 0x00};
|
||||
const int MaxRxErrorCount = 6;
|
||||
|
||||
ioaddr[0] = dev->base_addr;
|
||||
|
|
|
@ -2374,7 +2374,7 @@ static int sbmac_init(struct platform_device *pldev, long long base)
|
|||
dev->name, base, print_mac(mac, eaddr));
|
||||
|
||||
sc->mii_bus.name = sbmac_mdio_string;
|
||||
sc->mii_bus.id = idx;
|
||||
snprintf(sc->mii_bus.id, MII_BUS_ID_SIZE, "%x", idx);
|
||||
sc->mii_bus.priv = sc;
|
||||
sc->mii_bus.read = sbmac_mii_read;
|
||||
sc->mii_bus.write = sbmac_mii_write;
|
||||
|
|
|
@ -311,7 +311,6 @@ struct sc92031_priv {
|
|||
|
||||
/* for dev->get_stats */
|
||||
long rx_value;
|
||||
struct net_device_stats stats;
|
||||
};
|
||||
|
||||
/* I don't know which registers can be safely read; however, I can guess
|
||||
|
@ -421,7 +420,7 @@ static void _sc92031_tx_clear(struct net_device *dev)
|
|||
|
||||
while (priv->tx_head - priv->tx_tail > 0) {
|
||||
priv->tx_tail++;
|
||||
priv->stats.tx_dropped++;
|
||||
dev->stats.tx_dropped++;
|
||||
}
|
||||
priv->tx_head = priv->tx_tail = 0;
|
||||
}
|
||||
|
@ -676,27 +675,27 @@ static void _sc92031_tx_tasklet(struct net_device *dev)
|
|||
priv->tx_tail++;
|
||||
|
||||
if (tx_status & TxStatOK) {
|
||||
priv->stats.tx_bytes += tx_status & 0x1fff;
|
||||
priv->stats.tx_packets++;
|
||||
dev->stats.tx_bytes += tx_status & 0x1fff;
|
||||
dev->stats.tx_packets++;
|
||||
/* Note: TxCarrierLost is always asserted at 100mbps. */
|
||||
priv->stats.collisions += (tx_status >> 22) & 0xf;
|
||||
dev->stats.collisions += (tx_status >> 22) & 0xf;
|
||||
}
|
||||
|
||||
if (tx_status & (TxOutOfWindow | TxAborted)) {
|
||||
priv->stats.tx_errors++;
|
||||
dev->stats.tx_errors++;
|
||||
|
||||
if (tx_status & TxAborted)
|
||||
priv->stats.tx_aborted_errors++;
|
||||
dev->stats.tx_aborted_errors++;
|
||||
|
||||
if (tx_status & TxCarrierLost)
|
||||
priv->stats.tx_carrier_errors++;
|
||||
dev->stats.tx_carrier_errors++;
|
||||
|
||||
if (tx_status & TxOutOfWindow)
|
||||
priv->stats.tx_window_errors++;
|
||||
dev->stats.tx_window_errors++;
|
||||
}
|
||||
|
||||
if (tx_status & TxUnderrun)
|
||||
priv->stats.tx_fifo_errors++;
|
||||
dev->stats.tx_fifo_errors++;
|
||||
}
|
||||
|
||||
if (priv->tx_tail != old_tx_tail)
|
||||
|
@ -704,27 +703,29 @@ static void _sc92031_tx_tasklet(struct net_device *dev)
|
|||
netif_wake_queue(dev);
|
||||
}
|
||||
|
||||
static void _sc92031_rx_tasklet_error(u32 rx_status,
|
||||
struct sc92031_priv *priv, unsigned rx_size)
|
||||
static void _sc92031_rx_tasklet_error(struct net_device *dev,
|
||||
u32 rx_status, unsigned rx_size)
|
||||
{
|
||||
if(rx_size > (MAX_ETH_FRAME_SIZE + 4) || rx_size < 16) {
|
||||
priv->stats.rx_errors++;
|
||||
priv->stats.rx_length_errors++;
|
||||
dev->stats.rx_errors++;
|
||||
dev->stats.rx_length_errors++;
|
||||
}
|
||||
|
||||
if (!(rx_status & RxStatesOK)) {
|
||||
priv->stats.rx_errors++;
|
||||
dev->stats.rx_errors++;
|
||||
|
||||
if (rx_status & (RxHugeFrame | RxSmallFrame))
|
||||
priv->stats.rx_length_errors++;
|
||||
dev->stats.rx_length_errors++;
|
||||
|
||||
if (rx_status & RxBadAlign)
|
||||
priv->stats.rx_frame_errors++;
|
||||
dev->stats.rx_frame_errors++;
|
||||
|
||||
if (!(rx_status & RxCRCOK))
|
||||
priv->stats.rx_crc_errors++;
|
||||
} else
|
||||
dev->stats.rx_crc_errors++;
|
||||
} else {
|
||||
struct sc92031_priv *priv = netdev_priv(dev);
|
||||
priv->rx_loss++;
|
||||
}
|
||||
}
|
||||
|
||||
static void _sc92031_rx_tasklet(struct net_device *dev)
|
||||
|
@ -783,7 +784,7 @@ static void _sc92031_rx_tasklet(struct net_device *dev)
|
|||
|| rx_size > (MAX_ETH_FRAME_SIZE + 4)
|
||||
|| rx_size < 16
|
||||
|| !(rx_status & RxStatesOK))) {
|
||||
_sc92031_rx_tasklet_error(rx_status, priv, rx_size);
|
||||
_sc92031_rx_tasklet_error(dev, rx_status, rx_size);
|
||||
break;
|
||||
}
|
||||
|
||||
|
@ -795,7 +796,7 @@ static void _sc92031_rx_tasklet(struct net_device *dev)
|
|||
|
||||
rx_len -= rx_size_align + 4;
|
||||
|
||||
skb = dev_alloc_skb(pkt_size + NET_IP_ALIGN);
|
||||
skb = netdev_alloc_skb(dev, pkt_size + NET_IP_ALIGN);
|
||||
if (unlikely(!skb)) {
|
||||
if (printk_ratelimit())
|
||||
printk(KERN_ERR "%s: Couldn't allocate a skb_buff for a packet of size %u\n",
|
||||
|
@ -818,11 +819,11 @@ static void _sc92031_rx_tasklet(struct net_device *dev)
|
|||
dev->last_rx = jiffies;
|
||||
netif_rx(skb);
|
||||
|
||||
priv->stats.rx_bytes += pkt_size;
|
||||
priv->stats.rx_packets++;
|
||||
dev->stats.rx_bytes += pkt_size;
|
||||
dev->stats.rx_packets++;
|
||||
|
||||
if (rx_status & Rx_Multicast)
|
||||
priv->stats.multicast++;
|
||||
dev->stats.multicast++;
|
||||
|
||||
next:
|
||||
rx_ring_offset = (rx_ring_offset + rx_size_align) % RX_BUF_LEN;
|
||||
|
@ -835,13 +836,11 @@ static void _sc92031_rx_tasklet(struct net_device *dev)
|
|||
|
||||
static void _sc92031_link_tasklet(struct net_device *dev)
|
||||
{
|
||||
struct sc92031_priv *priv = netdev_priv(dev);
|
||||
|
||||
if (_sc92031_check_media(dev))
|
||||
netif_wake_queue(dev);
|
||||
else {
|
||||
netif_stop_queue(dev);
|
||||
priv->stats.tx_carrier_errors++;
|
||||
dev->stats.tx_carrier_errors++;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -866,11 +865,11 @@ static void sc92031_tasklet(unsigned long data)
|
|||
_sc92031_rx_tasklet(dev);
|
||||
|
||||
if (intr_status & RxOverflow)
|
||||
priv->stats.rx_errors++;
|
||||
dev->stats.rx_errors++;
|
||||
|
||||
if (intr_status & TimeOut) {
|
||||
priv->stats.rx_errors++;
|
||||
priv->stats.rx_length_errors++;
|
||||
dev->stats.rx_errors++;
|
||||
dev->stats.rx_length_errors++;
|
||||
}
|
||||
|
||||
if (intr_status & (LinkFail | LinkOK))
|
||||
|
@ -936,38 +935,36 @@ static struct net_device_stats *sc92031_get_stats(struct net_device *dev)
|
|||
|
||||
if (temp == 0xffff) {
|
||||
priv->rx_value += temp;
|
||||
priv->stats.rx_fifo_errors = priv->rx_value;
|
||||
} else {
|
||||
priv->stats.rx_fifo_errors = temp + priv->rx_value;
|
||||
}
|
||||
dev->stats.rx_fifo_errors = priv->rx_value;
|
||||
} else
|
||||
dev->stats.rx_fifo_errors = temp + priv->rx_value;
|
||||
|
||||
spin_unlock_bh(&priv->lock);
|
||||
}
|
||||
|
||||
return &priv->stats;
|
||||
return &dev->stats;
|
||||
}
|
||||
|
||||
static int sc92031_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||
{
|
||||
int err = 0;
|
||||
struct sc92031_priv *priv = netdev_priv(dev);
|
||||
void __iomem *port_base = priv->port_base;
|
||||
|
||||
unsigned len;
|
||||
unsigned entry;
|
||||
u32 tx_status;
|
||||
|
||||
if (skb_padto(skb, ETH_ZLEN))
|
||||
return NETDEV_TX_OK;
|
||||
|
||||
if (unlikely(skb->len > TX_BUF_SIZE)) {
|
||||
err = -EMSGSIZE;
|
||||
priv->stats.tx_dropped++;
|
||||
dev->stats.tx_dropped++;
|
||||
goto out;
|
||||
}
|
||||
|
||||
spin_lock(&priv->lock);
|
||||
|
||||
if (unlikely(!netif_carrier_ok(dev))) {
|
||||
err = -ENOLINK;
|
||||
priv->stats.tx_dropped++;
|
||||
dev->stats.tx_dropped++;
|
||||
goto out_unlock;
|
||||
}
|
||||
|
||||
|
@ -978,11 +975,6 @@ static int sc92031_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
|||
skb_copy_and_csum_dev(skb, priv->tx_bufs + entry * TX_BUF_SIZE);
|
||||
|
||||
len = skb->len;
|
||||
if (unlikely(len < ETH_ZLEN)) {
|
||||
memset(priv->tx_bufs + entry * TX_BUF_SIZE + len,
|
||||
0, ETH_ZLEN - len);
|
||||
len = ETH_ZLEN;
|
||||
}
|
||||
|
||||
wmb();
|
||||
|
||||
|
@ -1009,7 +1001,7 @@ out_unlock:
|
|||
out:
|
||||
dev_kfree_skb(skb);
|
||||
|
||||
return err;
|
||||
return NETDEV_TX_OK;
|
||||
}
|
||||
|
||||
static int sc92031_open(struct net_device *dev)
|
||||
|
|
|
@ -1399,6 +1399,8 @@ spider_net_link_reset(struct net_device *netdev)
|
|||
spider_net_write_reg(card, SPIDER_NET_GMACINTEN, 0);
|
||||
|
||||
/* reset phy and setup aneg */
|
||||
card->aneg_count = 0;
|
||||
card->medium = BCM54XX_COPPER;
|
||||
spider_net_setup_aneg(card);
|
||||
mod_timer(&card->aneg_timer, jiffies + SPIDER_NET_ANEG_TIMER);
|
||||
|
||||
|
@ -1413,18 +1415,12 @@ spider_net_link_reset(struct net_device *netdev)
|
|||
* found when an interrupt is presented
|
||||
*/
|
||||
static void
|
||||
spider_net_handle_error_irq(struct spider_net_card *card, u32 status_reg)
|
||||
spider_net_handle_error_irq(struct spider_net_card *card, u32 status_reg,
|
||||
u32 error_reg1, u32 error_reg2)
|
||||
{
|
||||
u32 error_reg1, error_reg2;
|
||||
u32 i;
|
||||
int show_error = 1;
|
||||
|
||||
error_reg1 = spider_net_read_reg(card, SPIDER_NET_GHIINT1STS);
|
||||
error_reg2 = spider_net_read_reg(card, SPIDER_NET_GHIINT2STS);
|
||||
|
||||
error_reg1 &= SPIDER_NET_INT1_MASK_VALUE;
|
||||
error_reg2 &= SPIDER_NET_INT2_MASK_VALUE;
|
||||
|
||||
/* check GHIINT0STS ************************************/
|
||||
if (status_reg)
|
||||
for (i = 0; i < 32; i++)
|
||||
|
@ -1654,12 +1650,15 @@ spider_net_interrupt(int irq, void *ptr)
|
|||
{
|
||||
struct net_device *netdev = ptr;
|
||||
struct spider_net_card *card = netdev_priv(netdev);
|
||||
u32 status_reg;
|
||||
u32 status_reg, error_reg1, error_reg2;
|
||||
|
||||
status_reg = spider_net_read_reg(card, SPIDER_NET_GHIINT0STS);
|
||||
status_reg &= SPIDER_NET_INT0_MASK_VALUE;
|
||||
error_reg1 = spider_net_read_reg(card, SPIDER_NET_GHIINT1STS);
|
||||
error_reg2 = spider_net_read_reg(card, SPIDER_NET_GHIINT2STS);
|
||||
|
||||
if (!status_reg)
|
||||
if (!(status_reg & SPIDER_NET_INT0_MASK_VALUE) &&
|
||||
!(error_reg1 & SPIDER_NET_INT1_MASK_VALUE) &&
|
||||
!(error_reg2 & SPIDER_NET_INT2_MASK_VALUE))
|
||||
return IRQ_NONE;
|
||||
|
||||
if (status_reg & SPIDER_NET_RXINT ) {
|
||||
|
@ -1674,7 +1673,8 @@ spider_net_interrupt(int irq, void *ptr)
|
|||
spider_net_link_reset(netdev);
|
||||
|
||||
if (status_reg & SPIDER_NET_ERRINT )
|
||||
spider_net_handle_error_irq(card, status_reg);
|
||||
spider_net_handle_error_irq(card, status_reg,
|
||||
error_reg1, error_reg2);
|
||||
|
||||
/* clear interrupt sources */
|
||||
spider_net_write_reg(card, SPIDER_NET_GHIINT0STS, status_reg);
|
||||
|
@ -1982,6 +1982,8 @@ spider_net_open(struct net_device *netdev)
|
|||
goto init_firmware_failed;
|
||||
|
||||
/* start probing with copper */
|
||||
card->aneg_count = 0;
|
||||
card->medium = BCM54XX_COPPER;
|
||||
spider_net_setup_aneg(card);
|
||||
if (card->phy.def->phy_id)
|
||||
mod_timer(&card->aneg_timer, jiffies + SPIDER_NET_ANEG_TIMER);
|
||||
|
@ -2043,7 +2045,8 @@ static void spider_net_link_phy(unsigned long data)
|
|||
/* if link didn't come up after SPIDER_NET_ANEG_TIMEOUT tries, setup phy again */
|
||||
if (card->aneg_count > SPIDER_NET_ANEG_TIMEOUT) {
|
||||
|
||||
pr_info("%s: link is down trying to bring it up\n", card->netdev->name);
|
||||
pr_debug("%s: link is down trying to bring it up\n",
|
||||
card->netdev->name);
|
||||
|
||||
switch (card->medium) {
|
||||
case BCM54XX_COPPER:
|
||||
|
@ -2094,9 +2097,10 @@ static void spider_net_link_phy(unsigned long data)
|
|||
|
||||
card->aneg_count = 0;
|
||||
|
||||
pr_debug("Found %s with %i Mbps, %s-duplex %sautoneg.\n",
|
||||
phy->def->name, phy->speed, phy->duplex==1 ? "Full" : "Half",
|
||||
phy->autoneg==1 ? "" : "no ");
|
||||
pr_info("%s: link up, %i Mbps, %s-duplex %sautoneg.\n",
|
||||
card->netdev->name, phy->speed,
|
||||
phy->duplex == 1 ? "Full" : "Half",
|
||||
phy->autoneg == 1 ? "" : "no ");
|
||||
|
||||
return;
|
||||
}
|
||||
|
|
|
@ -52,7 +52,7 @@ extern char spider_net_driver_name[];
|
|||
|
||||
#define SPIDER_NET_TX_TIMER (HZ/5)
|
||||
#define SPIDER_NET_ANEG_TIMER (HZ)
|
||||
#define SPIDER_NET_ANEG_TIMEOUT 2
|
||||
#define SPIDER_NET_ANEG_TIMEOUT 5
|
||||
|
||||
#define SPIDER_NET_RX_CSUM_DEFAULT 1
|
||||
|
||||
|
@ -159,9 +159,8 @@ extern char spider_net_driver_name[];
|
|||
|
||||
/** interrupt mask registers */
|
||||
#define SPIDER_NET_INT0_MASK_VALUE 0x3f7fe2c7
|
||||
#define SPIDER_NET_INT1_MASK_VALUE 0xffff7ff7
|
||||
/* no MAC aborts -> auto retransmission */
|
||||
#define SPIDER_NET_INT2_MASK_VALUE 0xffef7ff1
|
||||
#define SPIDER_NET_INT1_MASK_VALUE 0x0000fff2
|
||||
#define SPIDER_NET_INT2_MASK_VALUE 0x000003f1
|
||||
|
||||
/* we rely on flagged descriptor interrupts */
|
||||
#define SPIDER_NET_FRAMENUM_VALUE 0x00000000
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -268,7 +268,12 @@ enum t21143_csr6_bits {
|
|||
#define RX_RING_SIZE 128
|
||||
#define MEDIA_MASK 31
|
||||
|
||||
#define PKT_BUF_SZ 1536 /* Size of each temporary Rx buffer. */
|
||||
/* The receiver on the DC21143 rev 65 can fail to close the last
|
||||
* receive descriptor in certain circumstances (see errata) when
|
||||
* using MWI. This can only occur if the receive buffer ends on
|
||||
* a cache line boundary, so the "+ 4" below ensures it doesn't.
|
||||
*/
|
||||
#define PKT_BUF_SZ (1536 + 4) /* Size of each temporary Rx buffer. */
|
||||
|
||||
#define TULIP_MIN_CACHE_LINE 8 /* in units of 32-bit words */
|
||||
|
||||
|
|
|
@ -1154,18 +1154,13 @@ static void __devinit tulip_mwi_config (struct pci_dev *pdev,
|
|||
|
||||
tp->csr0 = csr0 = 0;
|
||||
|
||||
/* if we have any cache line size at all, we can do MRM */
|
||||
csr0 |= MRM;
|
||||
/* if we have any cache line size at all, we can do MRM and MWI */
|
||||
csr0 |= MRM | MWI;
|
||||
|
||||
/* ...and barring hardware bugs, MWI */
|
||||
if (!(tp->chip_id == DC21143 && tp->revision == 65))
|
||||
csr0 |= MWI;
|
||||
|
||||
/* set or disable MWI in the standard PCI command bit.
|
||||
* Check for the case where mwi is desired but not available
|
||||
/* Enable MWI in the standard PCI command bit.
|
||||
* Check for the case where MWI is desired but not available
|
||||
*/
|
||||
if (csr0 & MWI) pci_try_set_mwi(pdev);
|
||||
else pci_clear_mwi(pdev);
|
||||
pci_try_set_mwi(pdev);
|
||||
|
||||
/* read result from hardware (in case bit refused to enable) */
|
||||
pci_read_config_word(pdev, PCI_COMMAND, &pci_command);
|
||||
|
@ -1401,10 +1396,6 @@ static int __devinit tulip_init_one (struct pci_dev *pdev,
|
|||
#ifdef CONFIG_TULIP_MWI
|
||||
if (!force_csr0 && (tp->flags & HAS_PCI_MWI))
|
||||
tulip_mwi_config (pdev, dev);
|
||||
#else
|
||||
/* MWI is broken for DC21143 rev 65... */
|
||||
if (chip_idx == DC21143 && pdev->revision == 65)
|
||||
tp->csr0 &= ~MWI;
|
||||
#endif
|
||||
|
||||
/* Stop the chip's Tx and Rx processes. */
|
||||
|
|
|
@ -107,8 +107,6 @@ static int full_duplex[MAX_UNITS] = {-1, -1, -1, -1, -1, -1, -1, -1};
|
|||
/* Time in jiffies before concluding the transmitter is hung. */
|
||||
#define TX_TIMEOUT (2*HZ)
|
||||
|
||||
#define PKT_BUF_SZ 1536 /* Size of each temporary Rx buffer.*/
|
||||
|
||||
/* Include files, designed to support most kernel versions 2.0.0 and later. */
|
||||
#include <linux/module.h>
|
||||
#include <linux/kernel.h>
|
||||
|
@ -137,6 +135,9 @@ static int full_duplex[MAX_UNITS] = {-1, -1, -1, -1, -1, -1, -1, -1};
|
|||
|
||||
#include "tulip.h"
|
||||
|
||||
#undef PKT_BUF_SZ /* tulip.h also defines this */
|
||||
#define PKT_BUF_SZ 1536 /* Size of each temporary Rx buffer.*/
|
||||
|
||||
/* These identify the driver base version and may not be removed. */
|
||||
static char version[] =
|
||||
KERN_INFO DRV_NAME ".c:v" DRV_VERSION " (2.4 port) " DRV_RELDATE " Donald Becker <becker@scyld.com>\n"
|
||||
|
|
|
@ -3954,7 +3954,7 @@ static int ucc_geth_probe(struct of_device* ofdev, const struct of_device_id *ma
|
|||
if (err)
|
||||
return -1;
|
||||
|
||||
ug_info->mdio_bus = res.start;
|
||||
snprintf(ug_info->mdio_bus, MII_BUS_ID_SIZE, "%x", res.start);
|
||||
}
|
||||
|
||||
/* get the phy interface type, or default to MII */
|
||||
|
|
|
@ -1156,7 +1156,7 @@ struct ucc_geth_info {
|
|||
u16 pausePeriod;
|
||||
u16 extensionField;
|
||||
u8 phy_address;
|
||||
u32 mdio_bus;
|
||||
char mdio_bus[MII_BUS_ID_SIZE];
|
||||
u8 weightfactor[NUM_TX_QUEUES];
|
||||
u8 interruptcoalescingmaxvalue[NUM_RX_QUEUES];
|
||||
u8 l2qt[UCC_GETH_VLAN_PRIORITY_MAX];
|
||||
|
|
|
@ -157,7 +157,7 @@ static int uec_mdio_probe(struct of_device *ofdev, const struct of_device_id *ma
|
|||
if (err)
|
||||
goto reg_map_fail;
|
||||
|
||||
new_bus->id = res.start;
|
||||
snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", res.start);
|
||||
|
||||
new_bus->irq = kmalloc(32 * sizeof(int), GFP_KERNEL);
|
||||
|
||||
|
|
|
@ -34,59 +34,53 @@
|
|||
|
||||
#include "qeth_core_mpc.h"
|
||||
|
||||
#define KMSG_COMPONENT "qeth"
|
||||
|
||||
/**
|
||||
* Debug Facility stuff
|
||||
*/
|
||||
#define QETH_DBF_SETUP_NAME "qeth_setup"
|
||||
#define QETH_DBF_SETUP_LEN 8
|
||||
#define QETH_DBF_SETUP_PAGES 8
|
||||
#define QETH_DBF_SETUP_NR_AREAS 1
|
||||
#define QETH_DBF_SETUP_LEVEL 5
|
||||
enum qeth_dbf_names {
|
||||
QETH_DBF_SETUP,
|
||||
QETH_DBF_QERR,
|
||||
QETH_DBF_TRACE,
|
||||
QETH_DBF_MSG,
|
||||
QETH_DBF_SENSE,
|
||||
QETH_DBF_MISC,
|
||||
QETH_DBF_CTRL,
|
||||
QETH_DBF_INFOS /* must be last element */
|
||||
};
|
||||
|
||||
#define QETH_DBF_MISC_NAME "qeth_misc"
|
||||
#define QETH_DBF_MISC_LEN 128
|
||||
#define QETH_DBF_MISC_PAGES 2
|
||||
#define QETH_DBF_MISC_NR_AREAS 1
|
||||
#define QETH_DBF_MISC_LEVEL 2
|
||||
struct qeth_dbf_info {
|
||||
char name[DEBUG_MAX_NAME_LEN];
|
||||
int pages;
|
||||
int areas;
|
||||
int len;
|
||||
int level;
|
||||
struct debug_view *view;
|
||||
debug_info_t *id;
|
||||
};
|
||||
|
||||
#define QETH_DBF_DATA_NAME "qeth_data"
|
||||
#define QETH_DBF_DATA_LEN 96
|
||||
#define QETH_DBF_DATA_PAGES 8
|
||||
#define QETH_DBF_DATA_NR_AREAS 1
|
||||
#define QETH_DBF_DATA_LEVEL 2
|
||||
|
||||
#define QETH_DBF_CONTROL_NAME "qeth_control"
|
||||
#define QETH_DBF_CONTROL_LEN 256
|
||||
#define QETH_DBF_CONTROL_PAGES 8
|
||||
#define QETH_DBF_CONTROL_NR_AREAS 1
|
||||
#define QETH_DBF_CONTROL_LEVEL 5
|
||||
|
||||
#define QETH_DBF_TRACE_NAME "qeth_trace"
|
||||
#define QETH_DBF_TRACE_LEN 8
|
||||
#define QETH_DBF_TRACE_PAGES 4
|
||||
#define QETH_DBF_TRACE_NR_AREAS 1
|
||||
#define QETH_DBF_TRACE_LEVEL 3
|
||||
|
||||
#define QETH_DBF_SENSE_NAME "qeth_sense"
|
||||
#define QETH_DBF_SENSE_LEN 64
|
||||
#define QETH_DBF_SENSE_PAGES 2
|
||||
#define QETH_DBF_SENSE_NR_AREAS 1
|
||||
#define QETH_DBF_SENSE_LEVEL 2
|
||||
|
||||
#define QETH_DBF_QERR_NAME "qeth_qerr"
|
||||
#define QETH_DBF_QERR_LEN 8
|
||||
#define QETH_DBF_QERR_PAGES 2
|
||||
#define QETH_DBF_QERR_NR_AREAS 1
|
||||
#define QETH_DBF_QERR_LEVEL 2
|
||||
#define QETH_DBF_CTRL_LEN 256
|
||||
|
||||
#define QETH_DBF_TEXT(name, level, text) \
|
||||
do { \
|
||||
debug_text_event(qeth_dbf_##name, level, text); \
|
||||
} while (0)
|
||||
debug_text_event(qeth_dbf[QETH_DBF_##name].id, level, text)
|
||||
|
||||
#define QETH_DBF_HEX(name, level, addr, len) \
|
||||
debug_event(qeth_dbf[QETH_DBF_##name].id, level, (void *)(addr), len)
|
||||
|
||||
#define QETH_DBF_MESSAGE(level, text...) \
|
||||
debug_sprintf_event(qeth_dbf[QETH_DBF_MSG].id, level, text)
|
||||
|
||||
#define QETH_DBF_TEXT_(name, level, text...) \
|
||||
do { \
|
||||
debug_event(qeth_dbf_##name, level, (void *)(addr), len); \
|
||||
if (qeth_dbf_passes(qeth_dbf[QETH_DBF_##name].id, level)) { \
|
||||
char *dbf_txt_buf = \
|
||||
get_cpu_var(QETH_DBF_TXT_BUF); \
|
||||
sprintf(dbf_txt_buf, text); \
|
||||
debug_text_event(qeth_dbf[QETH_DBF_##name].id, \
|
||||
level, dbf_txt_buf); \
|
||||
put_cpu_var(QETH_DBF_TXT_BUF); \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
/* Allow to sort out low debug levels early to avoid wasted sprints */
|
||||
|
@ -826,13 +820,8 @@ void qeth_core_remove_osn_attributes(struct device *);
|
|||
|
||||
/* exports for qeth discipline device drivers */
|
||||
extern struct qeth_card_list_struct qeth_core_card_list;
|
||||
extern debug_info_t *qeth_dbf_setup;
|
||||
extern debug_info_t *qeth_dbf_data;
|
||||
extern debug_info_t *qeth_dbf_misc;
|
||||
extern debug_info_t *qeth_dbf_control;
|
||||
extern debug_info_t *qeth_dbf_trace;
|
||||
extern debug_info_t *qeth_dbf_sense;
|
||||
extern debug_info_t *qeth_dbf_qerr;
|
||||
|
||||
extern struct qeth_dbf_info qeth_dbf[QETH_DBF_INFOS];
|
||||
|
||||
void qeth_set_allowed_threads(struct qeth_card *, unsigned long , int);
|
||||
int qeth_threads_running(struct qeth_card *, unsigned long);
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -195,7 +195,7 @@ static struct ipa_rc_msg qeth_ipa_rc_msg[] = {
|
|||
{IPA_RC_SETIP_NO_STARTLAN, "Setip no startlan received"},
|
||||
{IPA_RC_SETIP_ALREADY_RECEIVED, "Setip already received"},
|
||||
{IPA_RC_IP_ADDR_ALREADY_USED, "IP address already in use on LAN"},
|
||||
{IPA_RC_MULTICAST_FULL, "No task available, multicast full"},
|
||||
{IPA_RC_MC_ADDR_NOT_FOUND, "Multicast address not found"},
|
||||
{IPA_RC_SETIP_INVALID_VERSION, "SETIP invalid IP version"},
|
||||
{IPA_RC_UNSUPPORTED_SUBCMD, "Unsupported assist subcommand"},
|
||||
{IPA_RC_ARP_ASSIST_NO_ENABLE, "Only partial success, no enable"},
|
||||
|
@ -230,7 +230,7 @@ static struct ipa_cmd_names qeth_ipa_cmd_names[] = {
|
|||
{IPA_CMD_STARTLAN, "startlan"},
|
||||
{IPA_CMD_STOPLAN, "stoplan"},
|
||||
{IPA_CMD_SETVMAC, "setvmac"},
|
||||
{IPA_CMD_DELVMAC, "delvmca"},
|
||||
{IPA_CMD_DELVMAC, "delvmac"},
|
||||
{IPA_CMD_SETGMAC, "setgmac"},
|
||||
{IPA_CMD_DELGMAC, "delgmac"},
|
||||
{IPA_CMD_SETVLAN, "setvlan"},
|
||||
|
|
|
@ -182,7 +182,7 @@ enum qeth_ipa_return_codes {
|
|||
IPA_RC_SETIP_NO_STARTLAN = 0xe008,
|
||||
IPA_RC_SETIP_ALREADY_RECEIVED = 0xe009,
|
||||
IPA_RC_IP_ADDR_ALREADY_USED = 0xe00a,
|
||||
IPA_RC_MULTICAST_FULL = 0xe00b,
|
||||
IPA_RC_MC_ADDR_NOT_FOUND = 0xe00b,
|
||||
IPA_RC_SETIP_INVALID_VERSION = 0xe00d,
|
||||
IPA_RC_UNSUPPORTED_SUBCMD = 0xe00e,
|
||||
IPA_RC_ARP_ASSIST_NO_ENABLE = 0xe00f,
|
||||
|
|
|
@ -31,7 +31,7 @@ int qeth_eddp_check_buffers_for_context(struct qeth_qdio_out_q *queue,
|
|||
int skbs_in_buffer;
|
||||
int buffers_needed = 0;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpcbfc");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpcbfc");
|
||||
while (elements_needed > 0) {
|
||||
buffers_needed++;
|
||||
if (atomic_read(&queue->bufs[index].state) !=
|
||||
|
@ -51,7 +51,7 @@ static void qeth_eddp_free_context(struct qeth_eddp_context *ctx)
|
|||
{
|
||||
int i;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpfctx");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpfctx");
|
||||
for (i = 0; i < ctx->num_pages; ++i)
|
||||
free_page((unsigned long)ctx->pages[i]);
|
||||
kfree(ctx->pages);
|
||||
|
@ -76,7 +76,7 @@ void qeth_eddp_buf_release_contexts(struct qeth_qdio_out_buffer *buf)
|
|||
{
|
||||
struct qeth_eddp_context_reference *ref;
|
||||
|
||||
QETH_DBF_TEXT(trace, 6, "eddprctx");
|
||||
QETH_DBF_TEXT(TRACE, 6, "eddprctx");
|
||||
while (!list_empty(&buf->ctx_list)) {
|
||||
ref = list_entry(buf->ctx_list.next,
|
||||
struct qeth_eddp_context_reference, list);
|
||||
|
@ -91,7 +91,7 @@ static int qeth_eddp_buf_ref_context(struct qeth_qdio_out_buffer *buf,
|
|||
{
|
||||
struct qeth_eddp_context_reference *ref;
|
||||
|
||||
QETH_DBF_TEXT(trace, 6, "eddprfcx");
|
||||
QETH_DBF_TEXT(TRACE, 6, "eddprfcx");
|
||||
ref = kmalloc(sizeof(struct qeth_eddp_context_reference), GFP_ATOMIC);
|
||||
if (ref == NULL)
|
||||
return -ENOMEM;
|
||||
|
@ -112,7 +112,7 @@ int qeth_eddp_fill_buffer(struct qeth_qdio_out_q *queue,
|
|||
int must_refcnt = 1;
|
||||
int i;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpfibu");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpfibu");
|
||||
while (elements > 0) {
|
||||
buf = &queue->bufs[index];
|
||||
if (atomic_read(&buf->state) != QETH_QDIO_BUF_EMPTY) {
|
||||
|
@ -166,7 +166,7 @@ int qeth_eddp_fill_buffer(struct qeth_qdio_out_q *queue,
|
|||
}
|
||||
out_check:
|
||||
if (!queue->do_pack) {
|
||||
QETH_DBF_TEXT(trace, 6, "fillbfnp");
|
||||
QETH_DBF_TEXT(TRACE, 6, "fillbfnp");
|
||||
/* set state to PRIMED -> will be flushed */
|
||||
if (buf->next_element_to_fill > 0) {
|
||||
atomic_set(&buf->state, QETH_QDIO_BUF_PRIMED);
|
||||
|
@ -175,7 +175,7 @@ out_check:
|
|||
} else {
|
||||
if (queue->card->options.performance_stats)
|
||||
queue->card->perf_stats.skbs_sent_pack++;
|
||||
QETH_DBF_TEXT(trace, 6, "fillbfpa");
|
||||
QETH_DBF_TEXT(TRACE, 6, "fillbfpa");
|
||||
if (buf->next_element_to_fill >=
|
||||
QETH_MAX_BUFFER_ELEMENTS(queue->card)) {
|
||||
/*
|
||||
|
@ -199,7 +199,7 @@ static void qeth_eddp_create_segment_hdrs(struct qeth_eddp_context *ctx,
|
|||
int pkt_len;
|
||||
struct qeth_eddp_element *element;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpcrsh");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpcrsh");
|
||||
page = ctx->pages[ctx->offset >> PAGE_SHIFT];
|
||||
page_offset = ctx->offset % PAGE_SIZE;
|
||||
element = &ctx->elements[ctx->num_elements];
|
||||
|
@ -257,7 +257,7 @@ static void qeth_eddp_copy_data_tcp(char *dst, struct qeth_eddp_data *eddp,
|
|||
int copy_len;
|
||||
u8 *src;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpcdtc");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpcdtc");
|
||||
if (skb_shinfo(eddp->skb)->nr_frags == 0) {
|
||||
skb_copy_from_linear_data_offset(eddp->skb, eddp->skb_offset,
|
||||
dst, len);
|
||||
|
@ -305,7 +305,7 @@ static void qeth_eddp_create_segment_data_tcp(struct qeth_eddp_context *ctx,
|
|||
struct qeth_eddp_element *element;
|
||||
int first_lap = 1;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpcsdt");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpcsdt");
|
||||
page = ctx->pages[ctx->offset >> PAGE_SHIFT];
|
||||
page_offset = ctx->offset % PAGE_SIZE;
|
||||
element = &ctx->elements[ctx->num_elements];
|
||||
|
@ -346,7 +346,7 @@ static __wsum qeth_eddp_check_tcp4_hdr(struct qeth_eddp_data *eddp,
|
|||
{
|
||||
__wsum phcsum; /* pseudo header checksum */
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpckt4");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpckt4");
|
||||
eddp->th.tcp.h.check = 0;
|
||||
/* compute pseudo header checksum */
|
||||
phcsum = csum_tcpudp_nofold(eddp->nh.ip4.h.saddr, eddp->nh.ip4.h.daddr,
|
||||
|
@ -361,7 +361,7 @@ static __wsum qeth_eddp_check_tcp6_hdr(struct qeth_eddp_data *eddp,
|
|||
__be32 proto;
|
||||
__wsum phcsum; /* pseudo header checksum */
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpckt6");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpckt6");
|
||||
eddp->th.tcp.h.check = 0;
|
||||
/* compute pseudo header checksum */
|
||||
phcsum = csum_partial((u8 *)&eddp->nh.ip6.h.saddr,
|
||||
|
@ -378,7 +378,7 @@ static struct qeth_eddp_data *qeth_eddp_create_eddp_data(struct qeth_hdr *qh,
|
|||
{
|
||||
struct qeth_eddp_data *eddp;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpcrda");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpcrda");
|
||||
eddp = kzalloc(sizeof(struct qeth_eddp_data), GFP_ATOMIC);
|
||||
if (eddp) {
|
||||
eddp->nhl = nhl;
|
||||
|
@ -398,7 +398,7 @@ static void __qeth_eddp_fill_context_tcp(struct qeth_eddp_context *ctx,
|
|||
int data_len;
|
||||
__wsum hcsum;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpftcp");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpftcp");
|
||||
eddp->skb_offset = sizeof(struct qeth_hdr) + eddp->nhl + eddp->thl;
|
||||
if (eddp->qh.hdr.l2.id == QETH_HEADER_TYPE_LAYER2) {
|
||||
eddp->skb_offset += sizeof(struct ethhdr);
|
||||
|
@ -457,7 +457,7 @@ static int qeth_eddp_fill_context_tcp(struct qeth_eddp_context *ctx,
|
|||
{
|
||||
struct qeth_eddp_data *eddp = NULL;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpficx");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpficx");
|
||||
/* create our segmentation headers and copy original headers */
|
||||
if (skb->protocol == htons(ETH_P_IP))
|
||||
eddp = qeth_eddp_create_eddp_data(qhdr,
|
||||
|
@ -473,7 +473,7 @@ static int qeth_eddp_fill_context_tcp(struct qeth_eddp_context *ctx,
|
|||
tcp_hdrlen(skb));
|
||||
|
||||
if (eddp == NULL) {
|
||||
QETH_DBF_TEXT(trace, 2, "eddpfcnm");
|
||||
QETH_DBF_TEXT(TRACE, 2, "eddpfcnm");
|
||||
return -ENOMEM;
|
||||
}
|
||||
if (qhdr->hdr.l2.id == QETH_HEADER_TYPE_LAYER2) {
|
||||
|
@ -499,7 +499,7 @@ static void qeth_eddp_calc_num_pages(struct qeth_eddp_context *ctx,
|
|||
{
|
||||
int skbs_per_page;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "eddpcanp");
|
||||
QETH_DBF_TEXT(TRACE, 5, "eddpcanp");
|
||||
/* can we put multiple skbs in one page? */
|
||||
skbs_per_page = PAGE_SIZE / (skb_shinfo(skb)->gso_size + hdr_len);
|
||||
if (skbs_per_page > 1) {
|
||||
|
@ -524,30 +524,30 @@ static struct qeth_eddp_context *qeth_eddp_create_context_generic(
|
|||
u8 *addr;
|
||||
int i;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "creddpcg");
|
||||
QETH_DBF_TEXT(TRACE, 5, "creddpcg");
|
||||
/* create the context and allocate pages */
|
||||
ctx = kzalloc(sizeof(struct qeth_eddp_context), GFP_ATOMIC);
|
||||
if (ctx == NULL) {
|
||||
QETH_DBF_TEXT(trace, 2, "ceddpcn1");
|
||||
QETH_DBF_TEXT(TRACE, 2, "ceddpcn1");
|
||||
return NULL;
|
||||
}
|
||||
ctx->type = QETH_LARGE_SEND_EDDP;
|
||||
qeth_eddp_calc_num_pages(ctx, skb, hdr_len);
|
||||
if (ctx->elements_per_skb > QETH_MAX_BUFFER_ELEMENTS(card)) {
|
||||
QETH_DBF_TEXT(trace, 2, "ceddpcis");
|
||||
QETH_DBF_TEXT(TRACE, 2, "ceddpcis");
|
||||
kfree(ctx);
|
||||
return NULL;
|
||||
}
|
||||
ctx->pages = kcalloc(ctx->num_pages, sizeof(u8 *), GFP_ATOMIC);
|
||||
if (ctx->pages == NULL) {
|
||||
QETH_DBF_TEXT(trace, 2, "ceddpcn2");
|
||||
QETH_DBF_TEXT(TRACE, 2, "ceddpcn2");
|
||||
kfree(ctx);
|
||||
return NULL;
|
||||
}
|
||||
for (i = 0; i < ctx->num_pages; ++i) {
|
||||
addr = (u8 *)get_zeroed_page(GFP_ATOMIC);
|
||||
if (addr == NULL) {
|
||||
QETH_DBF_TEXT(trace, 2, "ceddpcn3");
|
||||
QETH_DBF_TEXT(TRACE, 2, "ceddpcn3");
|
||||
ctx->num_pages = i;
|
||||
qeth_eddp_free_context(ctx);
|
||||
return NULL;
|
||||
|
@ -557,7 +557,7 @@ static struct qeth_eddp_context *qeth_eddp_create_context_generic(
|
|||
ctx->elements = kcalloc(ctx->num_elements,
|
||||
sizeof(struct qeth_eddp_element), GFP_ATOMIC);
|
||||
if (ctx->elements == NULL) {
|
||||
QETH_DBF_TEXT(trace, 2, "ceddpcn4");
|
||||
QETH_DBF_TEXT(TRACE, 2, "ceddpcn4");
|
||||
qeth_eddp_free_context(ctx);
|
||||
return NULL;
|
||||
}
|
||||
|
@ -573,7 +573,7 @@ static struct qeth_eddp_context *qeth_eddp_create_context_tcp(
|
|||
{
|
||||
struct qeth_eddp_context *ctx = NULL;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "creddpct");
|
||||
QETH_DBF_TEXT(TRACE, 5, "creddpct");
|
||||
if (skb->protocol == htons(ETH_P_IP))
|
||||
ctx = qeth_eddp_create_context_generic(card, skb,
|
||||
(sizeof(struct qeth_hdr) +
|
||||
|
@ -584,14 +584,14 @@ static struct qeth_eddp_context *qeth_eddp_create_context_tcp(
|
|||
sizeof(struct qeth_hdr) + sizeof(struct ipv6hdr) +
|
||||
tcp_hdrlen(skb));
|
||||
else
|
||||
QETH_DBF_TEXT(trace, 2, "cetcpinv");
|
||||
QETH_DBF_TEXT(TRACE, 2, "cetcpinv");
|
||||
|
||||
if (ctx == NULL) {
|
||||
QETH_DBF_TEXT(trace, 2, "creddpnl");
|
||||
QETH_DBF_TEXT(TRACE, 2, "creddpnl");
|
||||
return NULL;
|
||||
}
|
||||
if (qeth_eddp_fill_context_tcp(ctx, skb, qhdr)) {
|
||||
QETH_DBF_TEXT(trace, 2, "ceddptfe");
|
||||
QETH_DBF_TEXT(TRACE, 2, "ceddptfe");
|
||||
qeth_eddp_free_context(ctx);
|
||||
return NULL;
|
||||
}
|
||||
|
@ -603,12 +603,12 @@ struct qeth_eddp_context *qeth_eddp_create_context(struct qeth_card *card,
|
|||
struct sk_buff *skb, struct qeth_hdr *qhdr,
|
||||
unsigned char sk_protocol)
|
||||
{
|
||||
QETH_DBF_TEXT(trace, 5, "creddpc");
|
||||
QETH_DBF_TEXT(TRACE, 5, "creddpc");
|
||||
switch (sk_protocol) {
|
||||
case IPPROTO_TCP:
|
||||
return qeth_eddp_create_context_tcp(card, skb, qhdr);
|
||||
default:
|
||||
QETH_DBF_TEXT(trace, 2, "eddpinvp");
|
||||
QETH_DBF_TEXT(TRACE, 2, "eddpinvp");
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
@ -622,7 +622,7 @@ void qeth_tso_fill_header(struct qeth_card *card, struct qeth_hdr *qhdr,
|
|||
struct iphdr *iph = ip_hdr(skb);
|
||||
struct ipv6hdr *ip6h = ipv6_hdr(skb);
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "tsofhdr");
|
||||
QETH_DBF_TEXT(TRACE, 5, "tsofhdr");
|
||||
|
||||
/*fix header to TSO values ...*/
|
||||
hdr->hdr.hdr.l3.id = QETH_HEADER_TYPE_TSO;
|
||||
|
|
|
@ -22,16 +22,7 @@
|
|||
#include "qeth_core.h"
|
||||
#include "qeth_core_offl.h"
|
||||
|
||||
#define QETH_DBF_TEXT_(name, level, text...) \
|
||||
do { \
|
||||
if (qeth_dbf_passes(qeth_dbf_##name, level)) { \
|
||||
char *dbf_txt_buf = get_cpu_var(qeth_l2_dbf_txt_buf); \
|
||||
sprintf(dbf_txt_buf, text); \
|
||||
debug_text_event(qeth_dbf_##name, level, dbf_txt_buf); \
|
||||
put_cpu_var(qeth_l2_dbf_txt_buf); \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
#define QETH_DBF_TXT_BUF qeth_l2_dbf_txt_buf
|
||||
static DEFINE_PER_CPU(char[256], qeth_l2_dbf_txt_buf);
|
||||
|
||||
static int qeth_l2_set_offline(struct ccwgroup_device *);
|
||||
|
@ -87,7 +78,7 @@ static int qeth_l2_do_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
|
|||
rc = -EOPNOTSUPP;
|
||||
}
|
||||
if (rc)
|
||||
QETH_DBF_TEXT_(trace, 2, "ioce%d", rc);
|
||||
QETH_DBF_TEXT_(TRACE, 2, "ioce%d", rc);
|
||||
return rc;
|
||||
}
|
||||
|
||||
|
@ -141,7 +132,7 @@ static int qeth_l2_send_setgroupmac_cb(struct qeth_card *card,
|
|||
struct qeth_ipa_cmd *cmd;
|
||||
__u8 *mac;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "L2Sgmacb");
|
||||
QETH_DBF_TEXT(TRACE, 2, "L2Sgmacb");
|
||||
cmd = (struct qeth_ipa_cmd *) data;
|
||||
mac = &cmd->data.setdelmac.mac[0];
|
||||
/* MAC already registered, needed in couple/uncouple case */
|
||||
|
@ -162,7 +153,7 @@ static int qeth_l2_send_setgroupmac_cb(struct qeth_card *card,
|
|||
|
||||
static int qeth_l2_send_setgroupmac(struct qeth_card *card, __u8 *mac)
|
||||
{
|
||||
QETH_DBF_TEXT(trace, 2, "L2Sgmac");
|
||||
QETH_DBF_TEXT(TRACE, 2, "L2Sgmac");
|
||||
return qeth_l2_send_setdelmac(card, mac, IPA_CMD_SETGMAC,
|
||||
qeth_l2_send_setgroupmac_cb);
|
||||
}
|
||||
|
@ -174,7 +165,7 @@ static int qeth_l2_send_delgroupmac_cb(struct qeth_card *card,
|
|||
struct qeth_ipa_cmd *cmd;
|
||||
__u8 *mac;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "L2Dgmacb");
|
||||
QETH_DBF_TEXT(TRACE, 2, "L2Dgmacb");
|
||||
cmd = (struct qeth_ipa_cmd *) data;
|
||||
mac = &cmd->data.setdelmac.mac[0];
|
||||
if (cmd->hdr.return_code)
|
||||
|
@ -187,7 +178,7 @@ static int qeth_l2_send_delgroupmac_cb(struct qeth_card *card,
|
|||
|
||||
static int qeth_l2_send_delgroupmac(struct qeth_card *card, __u8 *mac)
|
||||
{
|
||||
QETH_DBF_TEXT(trace, 2, "L2Dgmac");
|
||||
QETH_DBF_TEXT(TRACE, 2, "L2Dgmac");
|
||||
return qeth_l2_send_setdelmac(card, mac, IPA_CMD_DELGMAC,
|
||||
qeth_l2_send_delgroupmac_cb);
|
||||
}
|
||||
|
@ -289,15 +280,15 @@ static int qeth_l2_send_setdelvlan_cb(struct qeth_card *card,
|
|||
{
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "L2sdvcb");
|
||||
QETH_DBF_TEXT(TRACE, 2, "L2sdvcb");
|
||||
cmd = (struct qeth_ipa_cmd *) data;
|
||||
if (cmd->hdr.return_code) {
|
||||
PRINT_ERR("Error in processing VLAN %i on %s: 0x%x. "
|
||||
"Continuing\n", cmd->data.setdelvlan.vlan_id,
|
||||
QETH_CARD_IFNAME(card), cmd->hdr.return_code);
|
||||
QETH_DBF_TEXT_(trace, 2, "L2VL%4x", cmd->hdr.command);
|
||||
QETH_DBF_TEXT_(trace, 2, "L2%s", CARD_BUS_ID(card));
|
||||
QETH_DBF_TEXT_(trace, 2, "err%d", cmd->hdr.return_code);
|
||||
QETH_DBF_TEXT_(TRACE, 2, "L2VL%4x", cmd->hdr.command);
|
||||
QETH_DBF_TEXT_(TRACE, 2, "L2%s", CARD_BUS_ID(card));
|
||||
QETH_DBF_TEXT_(TRACE, 2, "err%d", cmd->hdr.return_code);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
@ -308,7 +299,7 @@ static int qeth_l2_send_setdelvlan(struct qeth_card *card, __u16 i,
|
|||
struct qeth_ipa_cmd *cmd;
|
||||
struct qeth_cmd_buffer *iob;
|
||||
|
||||
QETH_DBF_TEXT_(trace, 4, "L2sdv%x", ipacmd);
|
||||
QETH_DBF_TEXT_(TRACE, 4, "L2sdv%x", ipacmd);
|
||||
iob = qeth_get_ipacmd_buffer(card, ipacmd, QETH_PROT_IPV4);
|
||||
cmd = (struct qeth_ipa_cmd *)(iob->data+IPA_PDU_HEADER_SIZE);
|
||||
cmd->data.setdelvlan.vlan_id = i;
|
||||
|
@ -319,7 +310,7 @@ static int qeth_l2_send_setdelvlan(struct qeth_card *card, __u16 i,
|
|||
static void qeth_l2_process_vlans(struct qeth_card *card, int clear)
|
||||
{
|
||||
struct qeth_vlan_vid *id;
|
||||
QETH_DBF_TEXT(trace, 3, "L2prcvln");
|
||||
QETH_DBF_TEXT(TRACE, 3, "L2prcvln");
|
||||
spin_lock_bh(&card->vlanlock);
|
||||
list_for_each_entry(id, &card->vid_list, list) {
|
||||
if (clear)
|
||||
|
@ -337,7 +328,7 @@ static void qeth_l2_vlan_rx_add_vid(struct net_device *dev, unsigned short vid)
|
|||
struct qeth_card *card = netdev_priv(dev);
|
||||
struct qeth_vlan_vid *id;
|
||||
|
||||
QETH_DBF_TEXT_(trace, 4, "aid:%d", vid);
|
||||
QETH_DBF_TEXT_(TRACE, 4, "aid:%d", vid);
|
||||
id = kmalloc(sizeof(struct qeth_vlan_vid), GFP_ATOMIC);
|
||||
if (id) {
|
||||
id->vid = vid;
|
||||
|
@ -355,7 +346,7 @@ static void qeth_l2_vlan_rx_kill_vid(struct net_device *dev, unsigned short vid)
|
|||
struct qeth_vlan_vid *id, *tmpid = NULL;
|
||||
struct qeth_card *card = netdev_priv(dev);
|
||||
|
||||
QETH_DBF_TEXT_(trace, 4, "kid:%d", vid);
|
||||
QETH_DBF_TEXT_(TRACE, 4, "kid:%d", vid);
|
||||
spin_lock_bh(&card->vlanlock);
|
||||
list_for_each_entry(id, &card->vid_list, list) {
|
||||
if (id->vid == vid) {
|
||||
|
@ -376,8 +367,8 @@ static int qeth_l2_stop_card(struct qeth_card *card, int recovery_mode)
|
|||
{
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(setup , 2, "stopcard");
|
||||
QETH_DBF_HEX(setup, 2, &card, sizeof(void *));
|
||||
QETH_DBF_TEXT(SETUP , 2, "stopcard");
|
||||
QETH_DBF_HEX(SETUP, 2, &card, sizeof(void *));
|
||||
|
||||
qeth_set_allowed_threads(card, 0, 1);
|
||||
if (qeth_wait_for_threads(card, ~QETH_RECOVER_THREAD))
|
||||
|
@ -396,7 +387,7 @@ static int qeth_l2_stop_card(struct qeth_card *card, int recovery_mode)
|
|||
if (!card->use_hard_stop) {
|
||||
__u8 *mac = &card->dev->dev_addr[0];
|
||||
rc = qeth_l2_send_delmac(card, mac);
|
||||
QETH_DBF_TEXT_(setup, 2, "Lerr%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "Lerr%d", rc);
|
||||
}
|
||||
card->state = CARD_STATE_SOFTSETUP;
|
||||
}
|
||||
|
@ -451,7 +442,8 @@ static void qeth_l2_process_inbound_buffer(struct qeth_card *card,
|
|||
skb->ip_summed = CHECKSUM_UNNECESSARY;
|
||||
else
|
||||
skb->ip_summed = CHECKSUM_NONE;
|
||||
*((__u32 *)skb->cb) = ++card->seqno.pkt_seqno;
|
||||
if (skb->protocol == htons(ETH_P_802_2))
|
||||
*((__u32 *)skb->cb) = ++card->seqno.pkt_seqno;
|
||||
len = skb->len;
|
||||
netif_rx(skb);
|
||||
break;
|
||||
|
@ -464,8 +456,8 @@ static void qeth_l2_process_inbound_buffer(struct qeth_card *card,
|
|||
break;
|
||||
default:
|
||||
dev_kfree_skb_any(skb);
|
||||
QETH_DBF_TEXT(trace, 3, "inbunkno");
|
||||
QETH_DBF_HEX(control, 3, hdr, QETH_DBF_CONTROL_LEN);
|
||||
QETH_DBF_TEXT(TRACE, 3, "inbunkno");
|
||||
QETH_DBF_HEX(CTRL, 3, hdr, QETH_DBF_CTRL_LEN);
|
||||
continue;
|
||||
}
|
||||
card->dev->last_rx = jiffies;
|
||||
|
@ -483,7 +475,7 @@ static int qeth_l2_send_setdelmac(struct qeth_card *card, __u8 *mac,
|
|||
struct qeth_ipa_cmd *cmd;
|
||||
struct qeth_cmd_buffer *iob;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "L2sdmac");
|
||||
QETH_DBF_TEXT(TRACE, 2, "L2sdmac");
|
||||
iob = qeth_get_ipacmd_buffer(card, ipacmd, QETH_PROT_IPV4);
|
||||
cmd = (struct qeth_ipa_cmd *)(iob->data+IPA_PDU_HEADER_SIZE);
|
||||
cmd->data.setdelmac.mac_length = OSA_ADDR_LEN;
|
||||
|
@ -497,10 +489,10 @@ static int qeth_l2_send_setmac_cb(struct qeth_card *card,
|
|||
{
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "L2Smaccb");
|
||||
QETH_DBF_TEXT(TRACE, 2, "L2Smaccb");
|
||||
cmd = (struct qeth_ipa_cmd *) data;
|
||||
if (cmd->hdr.return_code) {
|
||||
QETH_DBF_TEXT_(trace, 2, "L2er%x", cmd->hdr.return_code);
|
||||
QETH_DBF_TEXT_(TRACE, 2, "L2er%x", cmd->hdr.return_code);
|
||||
card->info.mac_bits &= ~QETH_LAYER2_MAC_REGISTERED;
|
||||
cmd->hdr.return_code = -EIO;
|
||||
} else {
|
||||
|
@ -519,7 +511,7 @@ static int qeth_l2_send_setmac_cb(struct qeth_card *card,
|
|||
|
||||
static int qeth_l2_send_setmac(struct qeth_card *card, __u8 *mac)
|
||||
{
|
||||
QETH_DBF_TEXT(trace, 2, "L2Setmac");
|
||||
QETH_DBF_TEXT(TRACE, 2, "L2Setmac");
|
||||
return qeth_l2_send_setdelmac(card, mac, IPA_CMD_SETVMAC,
|
||||
qeth_l2_send_setmac_cb);
|
||||
}
|
||||
|
@ -530,10 +522,10 @@ static int qeth_l2_send_delmac_cb(struct qeth_card *card,
|
|||
{
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "L2Dmaccb");
|
||||
QETH_DBF_TEXT(TRACE, 2, "L2Dmaccb");
|
||||
cmd = (struct qeth_ipa_cmd *) data;
|
||||
if (cmd->hdr.return_code) {
|
||||
QETH_DBF_TEXT_(trace, 2, "err%d", cmd->hdr.return_code);
|
||||
QETH_DBF_TEXT_(TRACE, 2, "err%d", cmd->hdr.return_code);
|
||||
cmd->hdr.return_code = -EIO;
|
||||
return 0;
|
||||
}
|
||||
|
@ -544,7 +536,7 @@ static int qeth_l2_send_delmac_cb(struct qeth_card *card,
|
|||
|
||||
static int qeth_l2_send_delmac(struct qeth_card *card, __u8 *mac)
|
||||
{
|
||||
QETH_DBF_TEXT(trace, 2, "L2Delmac");
|
||||
QETH_DBF_TEXT(TRACE, 2, "L2Delmac");
|
||||
if (!(card->info.mac_bits & QETH_LAYER2_MAC_REGISTERED))
|
||||
return 0;
|
||||
return qeth_l2_send_setdelmac(card, mac, IPA_CMD_DELVMAC,
|
||||
|
@ -556,8 +548,8 @@ static int qeth_l2_request_initial_mac(struct qeth_card *card)
|
|||
int rc = 0;
|
||||
char vendor_pre[] = {0x02, 0x00, 0x00};
|
||||
|
||||
QETH_DBF_TEXT(setup, 2, "doL2init");
|
||||
QETH_DBF_TEXT_(setup, 2, "doL2%s", CARD_BUS_ID(card));
|
||||
QETH_DBF_TEXT(SETUP, 2, "doL2init");
|
||||
QETH_DBF_TEXT_(SETUP, 2, "doL2%s", CARD_BUS_ID(card));
|
||||
|
||||
rc = qeth_query_setadapterparms(card);
|
||||
if (rc) {
|
||||
|
@ -571,10 +563,10 @@ static int qeth_l2_request_initial_mac(struct qeth_card *card)
|
|||
PRINT_WARN("couldn't get MAC address on "
|
||||
"device %s: x%x\n",
|
||||
CARD_BUS_ID(card), rc);
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
return rc;
|
||||
}
|
||||
QETH_DBF_HEX(setup, 2, card->dev->dev_addr, OSA_ADDR_LEN);
|
||||
QETH_DBF_HEX(SETUP, 2, card->dev->dev_addr, OSA_ADDR_LEN);
|
||||
} else {
|
||||
random_ether_addr(card->dev->dev_addr);
|
||||
memcpy(card->dev->dev_addr, vendor_pre, 3);
|
||||
|
@ -588,21 +580,21 @@ static int qeth_l2_set_mac_address(struct net_device *dev, void *p)
|
|||
struct qeth_card *card = netdev_priv(dev);
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "setmac");
|
||||
QETH_DBF_TEXT(TRACE, 3, "setmac");
|
||||
|
||||
if (qeth_l2_verify_dev(dev) != QETH_REAL_CARD) {
|
||||
QETH_DBF_TEXT(trace, 3, "setmcINV");
|
||||
QETH_DBF_TEXT(TRACE, 3, "setmcINV");
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
|
||||
if (card->info.type == QETH_CARD_TYPE_OSN) {
|
||||
PRINT_WARN("Setting MAC address on %s is not supported.\n",
|
||||
dev->name);
|
||||
QETH_DBF_TEXT(trace, 3, "setmcOSN");
|
||||
QETH_DBF_TEXT(TRACE, 3, "setmcOSN");
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
QETH_DBF_TEXT_(trace, 3, "%s", CARD_BUS_ID(card));
|
||||
QETH_DBF_HEX(trace, 3, addr->sa_data, OSA_ADDR_LEN);
|
||||
QETH_DBF_TEXT_(TRACE, 3, "%s", CARD_BUS_ID(card));
|
||||
QETH_DBF_HEX(TRACE, 3, addr->sa_data, OSA_ADDR_LEN);
|
||||
rc = qeth_l2_send_delmac(card, &card->dev->dev_addr[0]);
|
||||
if (!rc)
|
||||
rc = qeth_l2_send_setmac(card, addr->sa_data);
|
||||
|
@ -617,7 +609,7 @@ static void qeth_l2_set_multicast_list(struct net_device *dev)
|
|||
if (card->info.type == QETH_CARD_TYPE_OSN)
|
||||
return ;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "setmulti");
|
||||
QETH_DBF_TEXT(TRACE, 3, "setmulti");
|
||||
qeth_l2_del_all_mc(card);
|
||||
spin_lock_bh(&card->mclock);
|
||||
for (dm = dev->mc_list; dm; dm = dm->next)
|
||||
|
@ -643,7 +635,7 @@ static int qeth_l2_hard_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
|||
enum qeth_large_send_types large_send = QETH_LARGE_SEND_NO;
|
||||
struct qeth_eddp_context *ctx = NULL;
|
||||
|
||||
QETH_DBF_TEXT(trace, 6, "l2xmit");
|
||||
QETH_DBF_TEXT(TRACE, 6, "l2xmit");
|
||||
|
||||
if ((card->state != CARD_STATE_UP) || !card->lan_online) {
|
||||
card->stats.tx_carrier_errors++;
|
||||
|
@ -755,7 +747,7 @@ static void qeth_l2_qdio_input_handler(struct ccw_device *ccwdev,
|
|||
int index;
|
||||
int i;
|
||||
|
||||
QETH_DBF_TEXT(trace, 6, "qdinput");
|
||||
QETH_DBF_TEXT(TRACE, 6, "qdinput");
|
||||
card = (struct qeth_card *) card_ptr;
|
||||
net_dev = card->dev;
|
||||
if (card->options.performance_stats) {
|
||||
|
@ -764,11 +756,11 @@ static void qeth_l2_qdio_input_handler(struct ccw_device *ccwdev,
|
|||
}
|
||||
if (status & QDIO_STATUS_LOOK_FOR_ERROR) {
|
||||
if (status & QDIO_STATUS_ACTIVATE_CHECK_CONDITION) {
|
||||
QETH_DBF_TEXT(trace, 1, "qdinchk");
|
||||
QETH_DBF_TEXT_(trace, 1, "%s", CARD_BUS_ID(card));
|
||||
QETH_DBF_TEXT_(trace, 1, "%04X%04X", first_element,
|
||||
QETH_DBF_TEXT(TRACE, 1, "qdinchk");
|
||||
QETH_DBF_TEXT_(TRACE, 1, "%s", CARD_BUS_ID(card));
|
||||
QETH_DBF_TEXT_(TRACE, 1, "%04X%04X", first_element,
|
||||
count);
|
||||
QETH_DBF_TEXT_(trace, 1, "%04X%04X", queue, status);
|
||||
QETH_DBF_TEXT_(TRACE, 1, "%04X%04X", queue, status);
|
||||
qeth_schedule_recovery(card);
|
||||
return;
|
||||
}
|
||||
|
@ -793,13 +785,13 @@ static int qeth_l2_open(struct net_device *dev)
|
|||
{
|
||||
struct qeth_card *card = netdev_priv(dev);
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "qethopen");
|
||||
QETH_DBF_TEXT(TRACE, 4, "qethopen");
|
||||
if (card->state != CARD_STATE_SOFTSETUP)
|
||||
return -ENODEV;
|
||||
|
||||
if ((card->info.type != QETH_CARD_TYPE_OSN) &&
|
||||
(!(card->info.mac_bits & QETH_LAYER2_MAC_REGISTERED))) {
|
||||
QETH_DBF_TEXT(trace, 4, "nomacadr");
|
||||
QETH_DBF_TEXT(TRACE, 4, "nomacadr");
|
||||
return -EPERM;
|
||||
}
|
||||
card->data.state = CH_STATE_UP;
|
||||
|
@ -817,7 +809,7 @@ static int qeth_l2_stop(struct net_device *dev)
|
|||
{
|
||||
struct qeth_card *card = netdev_priv(dev);
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "qethstop");
|
||||
QETH_DBF_TEXT(TRACE, 4, "qethstop");
|
||||
netif_tx_disable(dev);
|
||||
card->dev->flags &= ~IFF_UP;
|
||||
if (card->state == CARD_STATE_UP)
|
||||
|
@ -933,8 +925,8 @@ static int __qeth_l2_set_online(struct ccwgroup_device *gdev, int recovery_mode)
|
|||
enum qeth_card_states recover_flag;
|
||||
|
||||
BUG_ON(!card);
|
||||
QETH_DBF_TEXT(setup, 2, "setonlin");
|
||||
QETH_DBF_HEX(setup, 2, &card, sizeof(void *));
|
||||
QETH_DBF_TEXT(SETUP, 2, "setonlin");
|
||||
QETH_DBF_HEX(SETUP, 2, &card, sizeof(void *));
|
||||
|
||||
qeth_set_allowed_threads(card, QETH_RECOVER_THREAD, 1);
|
||||
if (qeth_wait_for_threads(card, ~QETH_RECOVER_THREAD)) {
|
||||
|
@ -946,23 +938,23 @@ static int __qeth_l2_set_online(struct ccwgroup_device *gdev, int recovery_mode)
|
|||
recover_flag = card->state;
|
||||
rc = ccw_device_set_online(CARD_RDEV(card));
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
return -EIO;
|
||||
}
|
||||
rc = ccw_device_set_online(CARD_WDEV(card));
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
return -EIO;
|
||||
}
|
||||
rc = ccw_device_set_online(CARD_DDEV(card));
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
rc = qeth_core_hardsetup_card(card);
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "2err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "2err%d", rc);
|
||||
goto out_remove;
|
||||
}
|
||||
|
||||
|
@ -976,11 +968,11 @@ static int __qeth_l2_set_online(struct ccwgroup_device *gdev, int recovery_mode)
|
|||
qeth_print_status_message(card);
|
||||
|
||||
/* softsetup */
|
||||
QETH_DBF_TEXT(setup, 2, "softsetp");
|
||||
QETH_DBF_TEXT(SETUP, 2, "softsetp");
|
||||
|
||||
rc = qeth_send_startlan(card);
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
if (rc == 0xe080) {
|
||||
PRINT_WARN("LAN on card %s if offline! "
|
||||
"Waiting for STARTLAN from card.\n",
|
||||
|
@ -1000,7 +992,7 @@ static int __qeth_l2_set_online(struct ccwgroup_device *gdev, int recovery_mode)
|
|||
|
||||
rc = qeth_init_qdio_queues(card);
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "6err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "6err%d", rc);
|
||||
goto out_remove;
|
||||
}
|
||||
card->state = CARD_STATE_SOFTSETUP;
|
||||
|
@ -1047,8 +1039,8 @@ static int __qeth_l2_set_offline(struct ccwgroup_device *cgdev,
|
|||
int rc = 0, rc2 = 0, rc3 = 0;
|
||||
enum qeth_card_states recover_flag;
|
||||
|
||||
QETH_DBF_TEXT(setup, 3, "setoffl");
|
||||
QETH_DBF_HEX(setup, 3, &card, sizeof(void *));
|
||||
QETH_DBF_TEXT(SETUP, 3, "setoffl");
|
||||
QETH_DBF_HEX(SETUP, 3, &card, sizeof(void *));
|
||||
|
||||
if (card->dev && netif_carrier_ok(card->dev))
|
||||
netif_carrier_off(card->dev);
|
||||
|
@ -1064,7 +1056,7 @@ static int __qeth_l2_set_offline(struct ccwgroup_device *cgdev,
|
|||
if (!rc)
|
||||
rc = (rc2) ? rc2 : rc3;
|
||||
if (rc)
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
if (recover_flag == CARD_STATE_UP)
|
||||
card->state = CARD_STATE_RECOVER;
|
||||
/* let user_space know that device is offline */
|
||||
|
@ -1083,11 +1075,11 @@ static int qeth_l2_recover(void *ptr)
|
|||
int rc = 0;
|
||||
|
||||
card = (struct qeth_card *) ptr;
|
||||
QETH_DBF_TEXT(trace, 2, "recover1");
|
||||
QETH_DBF_HEX(trace, 2, &card, sizeof(void *));
|
||||
QETH_DBF_TEXT(TRACE, 2, "recover1");
|
||||
QETH_DBF_HEX(TRACE, 2, &card, sizeof(void *));
|
||||
if (!qeth_do_run_thread(card, QETH_RECOVER_THREAD))
|
||||
return 0;
|
||||
QETH_DBF_TEXT(trace, 2, "recover2");
|
||||
QETH_DBF_TEXT(TRACE, 2, "recover2");
|
||||
PRINT_WARN("Recovery of device %s started ...\n",
|
||||
CARD_BUS_ID(card));
|
||||
card->use_hard_stop = 1;
|
||||
|
@ -1138,12 +1130,12 @@ static int qeth_osn_send_control_data(struct qeth_card *card, int len,
|
|||
unsigned long flags;
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "osndctrd");
|
||||
QETH_DBF_TEXT(TRACE, 5, "osndctrd");
|
||||
|
||||
wait_event(card->wait_q,
|
||||
atomic_cmpxchg(&card->write.irq_pending, 0, 1) == 0);
|
||||
qeth_prepare_control_data(card, len, iob);
|
||||
QETH_DBF_TEXT(trace, 6, "osnoirqp");
|
||||
QETH_DBF_TEXT(TRACE, 6, "osnoirqp");
|
||||
spin_lock_irqsave(get_ccwdev_lock(card->write.ccwdev), flags);
|
||||
rc = ccw_device_start(card->write.ccwdev, &card->write.ccw,
|
||||
(addr_t) iob, 0, 0);
|
||||
|
@ -1151,7 +1143,7 @@ static int qeth_osn_send_control_data(struct qeth_card *card, int len,
|
|||
if (rc) {
|
||||
PRINT_WARN("qeth_osn_send_control_data: "
|
||||
"ccw_device_start rc = %i\n", rc);
|
||||
QETH_DBF_TEXT_(trace, 2, " err%d", rc);
|
||||
QETH_DBF_TEXT_(TRACE, 2, " err%d", rc);
|
||||
qeth_release_buffer(iob->channel, iob);
|
||||
atomic_set(&card->write.irq_pending, 0);
|
||||
wake_up(&card->wait_q);
|
||||
|
@ -1164,7 +1156,7 @@ static int qeth_osn_send_ipa_cmd(struct qeth_card *card,
|
|||
{
|
||||
u16 s1, s2;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "osndipa");
|
||||
QETH_DBF_TEXT(TRACE, 4, "osndipa");
|
||||
|
||||
qeth_prepare_ipa_cmd(card, iob, QETH_PROT_OSN2);
|
||||
s1 = (u16)(IPA_PDU_HEADER_SIZE + data_len);
|
||||
|
@ -1182,7 +1174,7 @@ int qeth_osn_assist(struct net_device *dev, void *data, int data_len)
|
|||
struct qeth_card *card;
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "osnsdmc");
|
||||
QETH_DBF_TEXT(TRACE, 2, "osnsdmc");
|
||||
if (!dev)
|
||||
return -ENODEV;
|
||||
card = netdev_priv(dev);
|
||||
|
@ -1204,7 +1196,7 @@ int qeth_osn_register(unsigned char *read_dev_no, struct net_device **dev,
|
|||
{
|
||||
struct qeth_card *card;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "osnreg");
|
||||
QETH_DBF_TEXT(TRACE, 2, "osnreg");
|
||||
*dev = qeth_l2_netdev_by_devno(read_dev_no);
|
||||
if (*dev == NULL)
|
||||
return -ENODEV;
|
||||
|
@ -1223,7 +1215,7 @@ void qeth_osn_deregister(struct net_device *dev)
|
|||
{
|
||||
struct qeth_card *card;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "osndereg");
|
||||
QETH_DBF_TEXT(TRACE, 2, "osndereg");
|
||||
if (!dev)
|
||||
return;
|
||||
card = netdev_priv(dev);
|
||||
|
|
|
@ -13,16 +13,7 @@
|
|||
|
||||
#include "qeth_core.h"
|
||||
|
||||
#define QETH_DBF_TEXT_(name, level, text...) \
|
||||
do { \
|
||||
if (qeth_dbf_passes(qeth_dbf_##name, level)) { \
|
||||
char *dbf_txt_buf = get_cpu_var(qeth_l3_dbf_txt_buf); \
|
||||
sprintf(dbf_txt_buf, text); \
|
||||
debug_text_event(qeth_dbf_##name, level, dbf_txt_buf); \
|
||||
put_cpu_var(qeth_l3_dbf_txt_buf); \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
#define QETH_DBF_TXT_BUF qeth_l3_dbf_txt_buf
|
||||
DECLARE_PER_CPU(char[256], qeth_l3_dbf_txt_buf);
|
||||
|
||||
struct qeth_ipaddr {
|
||||
|
|
|
@ -259,7 +259,7 @@ static int __qeth_l3_insert_ip_todo(struct qeth_card *card,
|
|||
addr->users += add ? 1 : -1;
|
||||
if (add && (addr->type == QETH_IP_TYPE_NORMAL) &&
|
||||
qeth_l3_is_addr_covered_by_ipato(card, addr)) {
|
||||
QETH_DBF_TEXT(trace, 2, "tkovaddr");
|
||||
QETH_DBF_TEXT(TRACE, 2, "tkovaddr");
|
||||
addr->set_flags |= QETH_IPA_SETIP_TAKEOVER_FLAG;
|
||||
}
|
||||
list_add_tail(&addr->entry, card->ip_tbd_list);
|
||||
|
@ -273,13 +273,13 @@ static int qeth_l3_delete_ip(struct qeth_card *card, struct qeth_ipaddr *addr)
|
|||
unsigned long flags;
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "delip");
|
||||
QETH_DBF_TEXT(TRACE, 4, "delip");
|
||||
|
||||
if (addr->proto == QETH_PROT_IPV4)
|
||||
QETH_DBF_HEX(trace, 4, &addr->u.a4.addr, 4);
|
||||
QETH_DBF_HEX(TRACE, 4, &addr->u.a4.addr, 4);
|
||||
else {
|
||||
QETH_DBF_HEX(trace, 4, &addr->u.a6.addr, 8);
|
||||
QETH_DBF_HEX(trace, 4, ((char *)&addr->u.a6.addr) + 8, 8);
|
||||
QETH_DBF_HEX(TRACE, 4, &addr->u.a6.addr, 8);
|
||||
QETH_DBF_HEX(TRACE, 4, ((char *)&addr->u.a6.addr) + 8, 8);
|
||||
}
|
||||
spin_lock_irqsave(&card->ip_lock, flags);
|
||||
rc = __qeth_l3_insert_ip_todo(card, addr, 0);
|
||||
|
@ -292,12 +292,12 @@ static int qeth_l3_add_ip(struct qeth_card *card, struct qeth_ipaddr *addr)
|
|||
unsigned long flags;
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "addip");
|
||||
QETH_DBF_TEXT(TRACE, 4, "addip");
|
||||
if (addr->proto == QETH_PROT_IPV4)
|
||||
QETH_DBF_HEX(trace, 4, &addr->u.a4.addr, 4);
|
||||
QETH_DBF_HEX(TRACE, 4, &addr->u.a4.addr, 4);
|
||||
else {
|
||||
QETH_DBF_HEX(trace, 4, &addr->u.a6.addr, 8);
|
||||
QETH_DBF_HEX(trace, 4, ((char *)&addr->u.a6.addr) + 8, 8);
|
||||
QETH_DBF_HEX(TRACE, 4, &addr->u.a6.addr, 8);
|
||||
QETH_DBF_HEX(TRACE, 4, ((char *)&addr->u.a6.addr) + 8, 8);
|
||||
}
|
||||
spin_lock_irqsave(&card->ip_lock, flags);
|
||||
rc = __qeth_l3_insert_ip_todo(card, addr, 1);
|
||||
|
@ -326,10 +326,10 @@ static void qeth_l3_delete_mc_addresses(struct qeth_card *card)
|
|||
struct qeth_ipaddr *iptodo;
|
||||
unsigned long flags;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "delmc");
|
||||
QETH_DBF_TEXT(TRACE, 4, "delmc");
|
||||
iptodo = qeth_l3_get_addr_buffer(QETH_PROT_IPV4);
|
||||
if (!iptodo) {
|
||||
QETH_DBF_TEXT(trace, 2, "dmcnomem");
|
||||
QETH_DBF_TEXT(TRACE, 2, "dmcnomem");
|
||||
return;
|
||||
}
|
||||
iptodo->type = QETH_IP_TYPE_DEL_ALL_MC;
|
||||
|
@ -401,8 +401,11 @@ static int __qeth_l3_ref_ip_on_card(struct qeth_card *card,
|
|||
static void __qeth_l3_delete_all_mc(struct qeth_card *card,
|
||||
unsigned long *flags)
|
||||
{
|
||||
struct list_head fail_list;
|
||||
struct qeth_ipaddr *addr, *tmp;
|
||||
int rc;
|
||||
|
||||
INIT_LIST_HEAD(&fail_list);
|
||||
again:
|
||||
list_for_each_entry_safe(addr, tmp, &card->ip_list, entry) {
|
||||
if (addr->is_multicast) {
|
||||
|
@ -410,13 +413,14 @@ again:
|
|||
spin_unlock_irqrestore(&card->ip_lock, *flags);
|
||||
rc = qeth_l3_deregister_addr_entry(card, addr);
|
||||
spin_lock_irqsave(&card->ip_lock, *flags);
|
||||
if (!rc) {
|
||||
if (!rc || (rc == IPA_RC_MC_ADDR_NOT_FOUND))
|
||||
kfree(addr);
|
||||
goto again;
|
||||
} else
|
||||
list_add(&addr->entry, &card->ip_list);
|
||||
else
|
||||
list_add_tail(&addr->entry, &fail_list);
|
||||
goto again;
|
||||
}
|
||||
}
|
||||
list_splice(&fail_list, &card->ip_list);
|
||||
}
|
||||
|
||||
static void qeth_l3_set_ip_addr_list(struct qeth_card *card)
|
||||
|
@ -426,14 +430,14 @@ static void qeth_l3_set_ip_addr_list(struct qeth_card *card)
|
|||
unsigned long flags;
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "sdiplist");
|
||||
QETH_DBF_HEX(trace, 2, &card, sizeof(void *));
|
||||
QETH_DBF_TEXT(TRACE, 2, "sdiplist");
|
||||
QETH_DBF_HEX(TRACE, 2, &card, sizeof(void *));
|
||||
|
||||
spin_lock_irqsave(&card->ip_lock, flags);
|
||||
tbd_list = card->ip_tbd_list;
|
||||
card->ip_tbd_list = kmalloc(sizeof(struct list_head), GFP_ATOMIC);
|
||||
if (!card->ip_tbd_list) {
|
||||
QETH_DBF_TEXT(trace, 0, "silnomem");
|
||||
QETH_DBF_TEXT(TRACE, 0, "silnomem");
|
||||
card->ip_tbd_list = tbd_list;
|
||||
spin_unlock_irqrestore(&card->ip_lock, flags);
|
||||
return;
|
||||
|
@ -457,7 +461,7 @@ static void qeth_l3_set_ip_addr_list(struct qeth_card *card)
|
|||
spin_unlock_irqrestore(&card->ip_lock, flags);
|
||||
rc = qeth_l3_register_addr_entry(card, todo);
|
||||
spin_lock_irqsave(&card->ip_lock, flags);
|
||||
if (!rc)
|
||||
if (!rc || (rc == IPA_RC_LAN_OFFLINE))
|
||||
list_add_tail(&todo->entry, &card->ip_list);
|
||||
else
|
||||
kfree(todo);
|
||||
|
@ -467,7 +471,7 @@ static void qeth_l3_set_ip_addr_list(struct qeth_card *card)
|
|||
spin_unlock_irqrestore(&card->ip_lock, flags);
|
||||
rc = qeth_l3_deregister_addr_entry(card, addr);
|
||||
spin_lock_irqsave(&card->ip_lock, flags);
|
||||
if (!rc)
|
||||
if (!rc || (rc == IPA_RC_PRIMARY_ALREADY_DEFINED))
|
||||
kfree(addr);
|
||||
else
|
||||
list_add_tail(&addr->entry, &card->ip_list);
|
||||
|
@ -484,7 +488,7 @@ static void qeth_l3_clear_ip_list(struct qeth_card *card, int clean,
|
|||
struct qeth_ipaddr *addr, *tmp;
|
||||
unsigned long flags;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "clearip");
|
||||
QETH_DBF_TEXT(TRACE, 4, "clearip");
|
||||
spin_lock_irqsave(&card->ip_lock, flags);
|
||||
/* clear todo list */
|
||||
list_for_each_entry_safe(addr, tmp, card->ip_tbd_list, entry) {
|
||||
|
@ -542,7 +546,7 @@ static int qeth_l3_send_setdelmc(struct qeth_card *card,
|
|||
struct qeth_cmd_buffer *iob;
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "setdelmc");
|
||||
QETH_DBF_TEXT(TRACE, 4, "setdelmc");
|
||||
|
||||
iob = qeth_get_ipacmd_buffer(card, ipacmd, addr->proto);
|
||||
cmd = (struct qeth_ipa_cmd *)(iob->data+IPA_PDU_HEADER_SIZE);
|
||||
|
@ -580,8 +584,8 @@ static int qeth_l3_send_setdelip(struct qeth_card *card,
|
|||
struct qeth_ipa_cmd *cmd;
|
||||
__u8 netmask[16];
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "setdelip");
|
||||
QETH_DBF_TEXT_(trace, 4, "flags%02X", flags);
|
||||
QETH_DBF_TEXT(TRACE, 4, "setdelip");
|
||||
QETH_DBF_TEXT_(TRACE, 4, "flags%02X", flags);
|
||||
|
||||
iob = qeth_get_ipacmd_buffer(card, ipacmd, addr->proto);
|
||||
cmd = (struct qeth_ipa_cmd *)(iob->data+IPA_PDU_HEADER_SIZE);
|
||||
|
@ -610,7 +614,7 @@ static int qeth_l3_send_setrouting(struct qeth_card *card,
|
|||
struct qeth_ipa_cmd *cmd;
|
||||
struct qeth_cmd_buffer *iob;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "setroutg");
|
||||
QETH_DBF_TEXT(TRACE, 4, "setroutg");
|
||||
iob = qeth_get_ipacmd_buffer(card, IPA_CMD_SETRTG, prot);
|
||||
cmd = (struct qeth_ipa_cmd *)(iob->data+IPA_PDU_HEADER_SIZE);
|
||||
cmd->data.setrtg.type = (type);
|
||||
|
@ -663,7 +667,7 @@ int qeth_l3_setrouting_v4(struct qeth_card *card)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "setrtg4");
|
||||
QETH_DBF_TEXT(TRACE, 3, "setrtg4");
|
||||
|
||||
qeth_l3_correct_routing_type(card, &card->options.route4.type,
|
||||
QETH_PROT_IPV4);
|
||||
|
@ -683,7 +687,7 @@ int qeth_l3_setrouting_v6(struct qeth_card *card)
|
|||
{
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "setrtg6");
|
||||
QETH_DBF_TEXT(TRACE, 3, "setrtg6");
|
||||
#ifdef CONFIG_QETH_IPV6
|
||||
|
||||
if (!qeth_is_supported(card, IPA_IPV6))
|
||||
|
@ -727,7 +731,7 @@ int qeth_l3_add_ipato_entry(struct qeth_card *card,
|
|||
unsigned long flags;
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "addipato");
|
||||
QETH_DBF_TEXT(TRACE, 2, "addipato");
|
||||
spin_lock_irqsave(&card->ip_lock, flags);
|
||||
list_for_each_entry(ipatoe, &card->ipato.entries, entry) {
|
||||
if (ipatoe->proto != new->proto)
|
||||
|
@ -753,7 +757,7 @@ void qeth_l3_del_ipato_entry(struct qeth_card *card,
|
|||
struct qeth_ipato_entry *ipatoe, *tmp;
|
||||
unsigned long flags;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "delipato");
|
||||
QETH_DBF_TEXT(TRACE, 2, "delipato");
|
||||
spin_lock_irqsave(&card->ip_lock, flags);
|
||||
list_for_each_entry_safe(ipatoe, tmp, &card->ipato.entries, entry) {
|
||||
if (ipatoe->proto != proto)
|
||||
|
@ -781,11 +785,11 @@ int qeth_l3_add_vipa(struct qeth_card *card, enum qeth_prot_versions proto,
|
|||
ipaddr = qeth_l3_get_addr_buffer(proto);
|
||||
if (ipaddr) {
|
||||
if (proto == QETH_PROT_IPV4) {
|
||||
QETH_DBF_TEXT(trace, 2, "addvipa4");
|
||||
QETH_DBF_TEXT(TRACE, 2, "addvipa4");
|
||||
memcpy(&ipaddr->u.a4.addr, addr, 4);
|
||||
ipaddr->u.a4.mask = 0;
|
||||
} else if (proto == QETH_PROT_IPV6) {
|
||||
QETH_DBF_TEXT(trace, 2, "addvipa6");
|
||||
QETH_DBF_TEXT(TRACE, 2, "addvipa6");
|
||||
memcpy(&ipaddr->u.a6.addr, addr, 16);
|
||||
ipaddr->u.a6.pfxlen = 0;
|
||||
}
|
||||
|
@ -817,11 +821,11 @@ void qeth_l3_del_vipa(struct qeth_card *card, enum qeth_prot_versions proto,
|
|||
ipaddr = qeth_l3_get_addr_buffer(proto);
|
||||
if (ipaddr) {
|
||||
if (proto == QETH_PROT_IPV4) {
|
||||
QETH_DBF_TEXT(trace, 2, "delvipa4");
|
||||
QETH_DBF_TEXT(TRACE, 2, "delvipa4");
|
||||
memcpy(&ipaddr->u.a4.addr, addr, 4);
|
||||
ipaddr->u.a4.mask = 0;
|
||||
} else if (proto == QETH_PROT_IPV6) {
|
||||
QETH_DBF_TEXT(trace, 2, "delvipa6");
|
||||
QETH_DBF_TEXT(TRACE, 2, "delvipa6");
|
||||
memcpy(&ipaddr->u.a6.addr, addr, 16);
|
||||
ipaddr->u.a6.pfxlen = 0;
|
||||
}
|
||||
|
@ -846,11 +850,11 @@ int qeth_l3_add_rxip(struct qeth_card *card, enum qeth_prot_versions proto,
|
|||
ipaddr = qeth_l3_get_addr_buffer(proto);
|
||||
if (ipaddr) {
|
||||
if (proto == QETH_PROT_IPV4) {
|
||||
QETH_DBF_TEXT(trace, 2, "addrxip4");
|
||||
QETH_DBF_TEXT(TRACE, 2, "addrxip4");
|
||||
memcpy(&ipaddr->u.a4.addr, addr, 4);
|
||||
ipaddr->u.a4.mask = 0;
|
||||
} else if (proto == QETH_PROT_IPV6) {
|
||||
QETH_DBF_TEXT(trace, 2, "addrxip6");
|
||||
QETH_DBF_TEXT(TRACE, 2, "addrxip6");
|
||||
memcpy(&ipaddr->u.a6.addr, addr, 16);
|
||||
ipaddr->u.a6.pfxlen = 0;
|
||||
}
|
||||
|
@ -882,11 +886,11 @@ void qeth_l3_del_rxip(struct qeth_card *card, enum qeth_prot_versions proto,
|
|||
ipaddr = qeth_l3_get_addr_buffer(proto);
|
||||
if (ipaddr) {
|
||||
if (proto == QETH_PROT_IPV4) {
|
||||
QETH_DBF_TEXT(trace, 2, "addrxip4");
|
||||
QETH_DBF_TEXT(TRACE, 2, "addrxip4");
|
||||
memcpy(&ipaddr->u.a4.addr, addr, 4);
|
||||
ipaddr->u.a4.mask = 0;
|
||||
} else if (proto == QETH_PROT_IPV6) {
|
||||
QETH_DBF_TEXT(trace, 2, "addrxip6");
|
||||
QETH_DBF_TEXT(TRACE, 2, "addrxip6");
|
||||
memcpy(&ipaddr->u.a6.addr, addr, 16);
|
||||
ipaddr->u.a6.pfxlen = 0;
|
||||
}
|
||||
|
@ -906,15 +910,15 @@ static int qeth_l3_register_addr_entry(struct qeth_card *card,
|
|||
int cnt = 3;
|
||||
|
||||
if (addr->proto == QETH_PROT_IPV4) {
|
||||
QETH_DBF_TEXT(trace, 2, "setaddr4");
|
||||
QETH_DBF_HEX(trace, 3, &addr->u.a4.addr, sizeof(int));
|
||||
QETH_DBF_TEXT(TRACE, 2, "setaddr4");
|
||||
QETH_DBF_HEX(TRACE, 3, &addr->u.a4.addr, sizeof(int));
|
||||
} else if (addr->proto == QETH_PROT_IPV6) {
|
||||
QETH_DBF_TEXT(trace, 2, "setaddr6");
|
||||
QETH_DBF_HEX(trace, 3, &addr->u.a6.addr, 8);
|
||||
QETH_DBF_HEX(trace, 3, ((char *)&addr->u.a6.addr) + 8, 8);
|
||||
QETH_DBF_TEXT(TRACE, 2, "setaddr6");
|
||||
QETH_DBF_HEX(TRACE, 3, &addr->u.a6.addr, 8);
|
||||
QETH_DBF_HEX(TRACE, 3, ((char *)&addr->u.a6.addr) + 8, 8);
|
||||
} else {
|
||||
QETH_DBF_TEXT(trace, 2, "setaddr?");
|
||||
QETH_DBF_HEX(trace, 3, addr, sizeof(struct qeth_ipaddr));
|
||||
QETH_DBF_TEXT(TRACE, 2, "setaddr?");
|
||||
QETH_DBF_HEX(TRACE, 3, addr, sizeof(struct qeth_ipaddr));
|
||||
}
|
||||
do {
|
||||
if (addr->is_multicast)
|
||||
|
@ -923,10 +927,10 @@ static int qeth_l3_register_addr_entry(struct qeth_card *card,
|
|||
rc = qeth_l3_send_setdelip(card, addr, IPA_CMD_SETIP,
|
||||
addr->set_flags);
|
||||
if (rc)
|
||||
QETH_DBF_TEXT(trace, 2, "failed");
|
||||
QETH_DBF_TEXT(TRACE, 2, "failed");
|
||||
} while ((--cnt > 0) && rc);
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT(trace, 2, "FAILED");
|
||||
QETH_DBF_TEXT(TRACE, 2, "FAILED");
|
||||
qeth_l3_ipaddr_to_string(addr->proto, (u8 *)&addr->u, buf);
|
||||
PRINT_WARN("Could not register IP address %s (rc=0x%x/%d)\n",
|
||||
buf, rc, rc);
|
||||
|
@ -940,15 +944,15 @@ static int qeth_l3_deregister_addr_entry(struct qeth_card *card,
|
|||
int rc = 0;
|
||||
|
||||
if (addr->proto == QETH_PROT_IPV4) {
|
||||
QETH_DBF_TEXT(trace, 2, "deladdr4");
|
||||
QETH_DBF_HEX(trace, 3, &addr->u.a4.addr, sizeof(int));
|
||||
QETH_DBF_TEXT(TRACE, 2, "deladdr4");
|
||||
QETH_DBF_HEX(TRACE, 3, &addr->u.a4.addr, sizeof(int));
|
||||
} else if (addr->proto == QETH_PROT_IPV6) {
|
||||
QETH_DBF_TEXT(trace, 2, "deladdr6");
|
||||
QETH_DBF_HEX(trace, 3, &addr->u.a6.addr, 8);
|
||||
QETH_DBF_HEX(trace, 3, ((char *)&addr->u.a6.addr) + 8, 8);
|
||||
QETH_DBF_TEXT(TRACE, 2, "deladdr6");
|
||||
QETH_DBF_HEX(TRACE, 3, &addr->u.a6.addr, 8);
|
||||
QETH_DBF_HEX(TRACE, 3, ((char *)&addr->u.a6.addr) + 8, 8);
|
||||
} else {
|
||||
QETH_DBF_TEXT(trace, 2, "deladdr?");
|
||||
QETH_DBF_HEX(trace, 3, addr, sizeof(struct qeth_ipaddr));
|
||||
QETH_DBF_TEXT(TRACE, 2, "deladdr?");
|
||||
QETH_DBF_HEX(TRACE, 3, addr, sizeof(struct qeth_ipaddr));
|
||||
}
|
||||
if (addr->is_multicast)
|
||||
rc = qeth_l3_send_setdelmc(card, addr, IPA_CMD_DELIPM);
|
||||
|
@ -956,7 +960,7 @@ static int qeth_l3_deregister_addr_entry(struct qeth_card *card,
|
|||
rc = qeth_l3_send_setdelip(card, addr, IPA_CMD_DELIP,
|
||||
addr->del_flags);
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT(trace, 2, "failed");
|
||||
QETH_DBF_TEXT(TRACE, 2, "failed");
|
||||
/* TODO: re-activate this warning as soon as we have a
|
||||
* clean mirco code
|
||||
qeth_ipaddr_to_string(addr->proto, (u8 *)&addr->u, buf);
|
||||
|
@ -996,7 +1000,7 @@ static int qeth_l3_send_setadp_mode(struct qeth_card *card, __u32 command,
|
|||
struct qeth_cmd_buffer *iob;
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "adpmode");
|
||||
QETH_DBF_TEXT(TRACE, 4, "adpmode");
|
||||
|
||||
iob = qeth_get_adapter_cmd(card, command,
|
||||
sizeof(struct qeth_ipacmd_setadpparms));
|
||||
|
@ -1011,7 +1015,7 @@ static int qeth_l3_setadapter_hstr(struct qeth_card *card)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "adphstr");
|
||||
QETH_DBF_TEXT(TRACE, 4, "adphstr");
|
||||
|
||||
if (qeth_adp_supported(card, IPA_SETADP_SET_BROADCAST_MODE)) {
|
||||
rc = qeth_l3_send_setadp_mode(card,
|
||||
|
@ -1044,13 +1048,13 @@ static int qeth_l3_setadapter_parms(struct qeth_card *card)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(setup, 2, "setadprm");
|
||||
QETH_DBF_TEXT(SETUP, 2, "setadprm");
|
||||
|
||||
if (!qeth_is_supported(card, IPA_SETADAPTERPARMS)) {
|
||||
PRINT_WARN("set adapter parameters not supported "
|
||||
"on device %s.\n",
|
||||
CARD_BUS_ID(card));
|
||||
QETH_DBF_TEXT(setup, 2, " notsupp");
|
||||
QETH_DBF_TEXT(SETUP, 2, " notsupp");
|
||||
return 0;
|
||||
}
|
||||
rc = qeth_query_setadapterparms(card);
|
||||
|
@ -1079,7 +1083,7 @@ static int qeth_l3_default_setassparms_cb(struct qeth_card *card,
|
|||
{
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "defadpcb");
|
||||
QETH_DBF_TEXT(TRACE, 4, "defadpcb");
|
||||
|
||||
cmd = (struct qeth_ipa_cmd *) data;
|
||||
if (cmd->hdr.return_code == 0) {
|
||||
|
@ -1092,7 +1096,7 @@ static int qeth_l3_default_setassparms_cb(struct qeth_card *card,
|
|||
if (cmd->data.setassparms.hdr.assist_no == IPA_INBOUND_CHECKSUM &&
|
||||
cmd->data.setassparms.hdr.command_code == IPA_CMD_ASS_START) {
|
||||
card->info.csum_mask = cmd->data.setassparms.data.flags_32bit;
|
||||
QETH_DBF_TEXT_(trace, 3, "csum:%d", card->info.csum_mask);
|
||||
QETH_DBF_TEXT_(TRACE, 3, "csum:%d", card->info.csum_mask);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
@ -1104,7 +1108,7 @@ static struct qeth_cmd_buffer *qeth_l3_get_setassparms_cmd(
|
|||
struct qeth_cmd_buffer *iob;
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "getasscm");
|
||||
QETH_DBF_TEXT(TRACE, 4, "getasscm");
|
||||
iob = qeth_get_ipacmd_buffer(card, IPA_CMD_SETASSPARMS, prot);
|
||||
|
||||
cmd = (struct qeth_ipa_cmd *)(iob->data+IPA_PDU_HEADER_SIZE);
|
||||
|
@ -1126,7 +1130,7 @@ static int qeth_l3_send_setassparms(struct qeth_card *card,
|
|||
int rc;
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "sendassp");
|
||||
QETH_DBF_TEXT(TRACE, 4, "sendassp");
|
||||
|
||||
cmd = (struct qeth_ipa_cmd *)(iob->data+IPA_PDU_HEADER_SIZE);
|
||||
if (len <= sizeof(__u32))
|
||||
|
@ -1145,7 +1149,7 @@ static int qeth_l3_send_simple_setassparms_ipv6(struct qeth_card *card,
|
|||
int rc;
|
||||
struct qeth_cmd_buffer *iob;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "simassp6");
|
||||
QETH_DBF_TEXT(TRACE, 4, "simassp6");
|
||||
iob = qeth_l3_get_setassparms_cmd(card, ipa_func, cmd_code,
|
||||
0, QETH_PROT_IPV6);
|
||||
rc = qeth_l3_send_setassparms(card, iob, 0, 0,
|
||||
|
@ -1161,7 +1165,7 @@ static int qeth_l3_send_simple_setassparms(struct qeth_card *card,
|
|||
int length = 0;
|
||||
struct qeth_cmd_buffer *iob;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "simassp4");
|
||||
QETH_DBF_TEXT(TRACE, 4, "simassp4");
|
||||
if (data)
|
||||
length = sizeof(__u32);
|
||||
iob = qeth_l3_get_setassparms_cmd(card, ipa_func, cmd_code,
|
||||
|
@ -1175,7 +1179,7 @@ static int qeth_l3_start_ipa_arp_processing(struct qeth_card *card)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "ipaarp");
|
||||
QETH_DBF_TEXT(TRACE, 3, "ipaarp");
|
||||
|
||||
if (!qeth_is_supported(card, IPA_ARP_PROCESSING)) {
|
||||
PRINT_WARN("ARP processing not supported "
|
||||
|
@ -1196,7 +1200,7 @@ static int qeth_l3_start_ipa_ip_fragmentation(struct qeth_card *card)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "ipaipfrg");
|
||||
QETH_DBF_TEXT(TRACE, 3, "ipaipfrg");
|
||||
|
||||
if (!qeth_is_supported(card, IPA_IP_FRAGMENTATION)) {
|
||||
PRINT_INFO("Hardware IP fragmentation not supported on %s\n",
|
||||
|
@ -1219,7 +1223,7 @@ static int qeth_l3_start_ipa_source_mac(struct qeth_card *card)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "stsrcmac");
|
||||
QETH_DBF_TEXT(TRACE, 3, "stsrcmac");
|
||||
|
||||
if (!card->options.fake_ll)
|
||||
return -EOPNOTSUPP;
|
||||
|
@ -1243,7 +1247,7 @@ static int qeth_l3_start_ipa_vlan(struct qeth_card *card)
|
|||
{
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "strtvlan");
|
||||
QETH_DBF_TEXT(TRACE, 3, "strtvlan");
|
||||
|
||||
if (!qeth_is_supported(card, IPA_FULL_VLAN)) {
|
||||
PRINT_WARN("VLAN not supported on %s\n",
|
||||
|
@ -1267,7 +1271,7 @@ static int qeth_l3_start_ipa_multicast(struct qeth_card *card)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "stmcast");
|
||||
QETH_DBF_TEXT(TRACE, 3, "stmcast");
|
||||
|
||||
if (!qeth_is_supported(card, IPA_MULTICASTING)) {
|
||||
PRINT_WARN("Multicast not supported on %s\n",
|
||||
|
@ -1293,7 +1297,7 @@ static int qeth_l3_query_ipassists_cb(struct qeth_card *card,
|
|||
{
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(setup, 2, "qipasscb");
|
||||
QETH_DBF_TEXT(SETUP, 2, "qipasscb");
|
||||
|
||||
cmd = (struct qeth_ipa_cmd *) data;
|
||||
if (cmd->hdr.prot_version == QETH_PROT_IPV4) {
|
||||
|
@ -1303,9 +1307,9 @@ static int qeth_l3_query_ipassists_cb(struct qeth_card *card,
|
|||
card->options.ipa6.supported_funcs = cmd->hdr.ipa_supported;
|
||||
card->options.ipa6.enabled_funcs = cmd->hdr.ipa_enabled;
|
||||
}
|
||||
QETH_DBF_TEXT(setup, 2, "suppenbl");
|
||||
QETH_DBF_TEXT_(setup, 2, "%x", cmd->hdr.ipa_supported);
|
||||
QETH_DBF_TEXT_(setup, 2, "%x", cmd->hdr.ipa_enabled);
|
||||
QETH_DBF_TEXT(SETUP, 2, "suppenbl");
|
||||
QETH_DBF_TEXT_(SETUP, 2, "%x", cmd->hdr.ipa_supported);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "%x", cmd->hdr.ipa_enabled);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -1315,7 +1319,7 @@ static int qeth_l3_query_ipassists(struct qeth_card *card,
|
|||
int rc;
|
||||
struct qeth_cmd_buffer *iob;
|
||||
|
||||
QETH_DBF_TEXT_(setup, 2, "qipassi%i", prot);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "qipassi%i", prot);
|
||||
iob = qeth_get_ipacmd_buffer(card, IPA_CMD_QIPASSIST, prot);
|
||||
rc = qeth_send_ipa_cmd(card, iob, qeth_l3_query_ipassists_cb, NULL);
|
||||
return rc;
|
||||
|
@ -1326,7 +1330,7 @@ static int qeth_l3_softsetup_ipv6(struct qeth_card *card)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "softipv6");
|
||||
QETH_DBF_TEXT(TRACE, 3, "softipv6");
|
||||
|
||||
if (card->info.type == QETH_CARD_TYPE_IQD)
|
||||
goto out;
|
||||
|
@ -1371,7 +1375,7 @@ static int qeth_l3_start_ipa_ipv6(struct qeth_card *card)
|
|||
{
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "strtipv6");
|
||||
QETH_DBF_TEXT(TRACE, 3, "strtipv6");
|
||||
|
||||
if (!qeth_is_supported(card, IPA_IPV6)) {
|
||||
PRINT_WARN("IPv6 not supported on %s\n",
|
||||
|
@ -1388,7 +1392,7 @@ static int qeth_l3_start_ipa_broadcast(struct qeth_card *card)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "stbrdcst");
|
||||
QETH_DBF_TEXT(TRACE, 3, "stbrdcst");
|
||||
card->info.broadcast_capable = 0;
|
||||
if (!qeth_is_supported(card, IPA_FILTERING)) {
|
||||
PRINT_WARN("Broadcast not supported on %s\n",
|
||||
|
@ -1458,7 +1462,7 @@ static int qeth_l3_start_ipa_checksum(struct qeth_card *card)
|
|||
{
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "strtcsum");
|
||||
QETH_DBF_TEXT(TRACE, 3, "strtcsum");
|
||||
|
||||
if (card->options.checksum_type == NO_CHECKSUMMING) {
|
||||
PRINT_WARN("Using no checksumming on %s.\n",
|
||||
|
@ -1489,7 +1493,7 @@ static int qeth_l3_start_ipa_tso(struct qeth_card *card)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "sttso");
|
||||
QETH_DBF_TEXT(TRACE, 3, "sttso");
|
||||
|
||||
if (!qeth_is_supported(card, IPA_OUTBOUND_TSO)) {
|
||||
PRINT_WARN("Outbound TSO not supported on %s\n",
|
||||
|
@ -1514,7 +1518,7 @@ static int qeth_l3_start_ipa_tso(struct qeth_card *card)
|
|||
|
||||
static int qeth_l3_start_ipassists(struct qeth_card *card)
|
||||
{
|
||||
QETH_DBF_TEXT(trace, 3, "strtipas");
|
||||
QETH_DBF_TEXT(TRACE, 3, "strtipas");
|
||||
qeth_l3_start_ipa_arp_processing(card); /* go on*/
|
||||
qeth_l3_start_ipa_ip_fragmentation(card); /* go on*/
|
||||
qeth_l3_start_ipa_source_mac(card); /* go on*/
|
||||
|
@ -1534,7 +1538,7 @@ static int qeth_l3_put_unique_id(struct qeth_card *card)
|
|||
struct qeth_cmd_buffer *iob;
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(trace, 2, "puniqeid");
|
||||
QETH_DBF_TEXT(TRACE, 2, "puniqeid");
|
||||
|
||||
if ((card->info.unique_id & UNIQUE_ID_NOT_BY_CARD) ==
|
||||
UNIQUE_ID_NOT_BY_CARD)
|
||||
|
@ -1571,7 +1575,7 @@ static int qeth_l3_iqd_read_initial_mac(struct qeth_card *card)
|
|||
struct qeth_cmd_buffer *iob;
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(setup, 2, "hsrmac");
|
||||
QETH_DBF_TEXT(SETUP, 2, "hsrmac");
|
||||
|
||||
iob = qeth_get_ipacmd_buffer(card, IPA_CMD_CREATE_ADDR,
|
||||
QETH_PROT_IPV6);
|
||||
|
@ -1612,7 +1616,7 @@ static int qeth_l3_get_unique_id(struct qeth_card *card)
|
|||
struct qeth_cmd_buffer *iob;
|
||||
struct qeth_ipa_cmd *cmd;
|
||||
|
||||
QETH_DBF_TEXT(setup, 2, "guniqeid");
|
||||
QETH_DBF_TEXT(SETUP, 2, "guniqeid");
|
||||
|
||||
if (!qeth_is_supported(card, IPA_IPV6)) {
|
||||
card->info.unique_id = UNIQUE_ID_IF_CREATE_ADDR_FAILED |
|
||||
|
@ -1645,7 +1649,7 @@ static void qeth_l3_add_mc(struct qeth_card *card, struct in_device *in4_dev)
|
|||
struct ip_mc_list *im4;
|
||||
char buf[MAX_ADDR_LEN];
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "addmc");
|
||||
QETH_DBF_TEXT(TRACE, 4, "addmc");
|
||||
for (im4 = in4_dev->mc_list; im4; im4 = im4->next) {
|
||||
qeth_l3_get_mac_for_ipm(im4->multiaddr, buf, in4_dev->dev);
|
||||
ipm = qeth_l3_get_addr_buffer(QETH_PROT_IPV4);
|
||||
|
@ -1665,7 +1669,7 @@ static void qeth_l3_add_vlan_mc(struct qeth_card *card)
|
|||
struct vlan_group *vg;
|
||||
int i;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "addmcvl");
|
||||
QETH_DBF_TEXT(TRACE, 4, "addmcvl");
|
||||
if (!qeth_is_supported(card, IPA_FULL_VLAN) || (card->vlangrp == NULL))
|
||||
return;
|
||||
|
||||
|
@ -1689,7 +1693,7 @@ static void qeth_l3_add_multicast_ipv4(struct qeth_card *card)
|
|||
{
|
||||
struct in_device *in4_dev;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "chkmcv4");
|
||||
QETH_DBF_TEXT(TRACE, 4, "chkmcv4");
|
||||
in4_dev = in_dev_get(card->dev);
|
||||
if (in4_dev == NULL)
|
||||
return;
|
||||
|
@ -1707,7 +1711,7 @@ static void qeth_l3_add_mc6(struct qeth_card *card, struct inet6_dev *in6_dev)
|
|||
struct ifmcaddr6 *im6;
|
||||
char buf[MAX_ADDR_LEN];
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "addmc6");
|
||||
QETH_DBF_TEXT(TRACE, 4, "addmc6");
|
||||
for (im6 = in6_dev->mc_list; im6 != NULL; im6 = im6->next) {
|
||||
ndisc_mc_map(&im6->mca_addr, buf, in6_dev->dev, 0);
|
||||
ipm = qeth_l3_get_addr_buffer(QETH_PROT_IPV6);
|
||||
|
@ -1728,7 +1732,7 @@ static void qeth_l3_add_vlan_mc6(struct qeth_card *card)
|
|||
struct vlan_group *vg;
|
||||
int i;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "admc6vl");
|
||||
QETH_DBF_TEXT(TRACE, 4, "admc6vl");
|
||||
if (!qeth_is_supported(card, IPA_FULL_VLAN) || (card->vlangrp == NULL))
|
||||
return;
|
||||
|
||||
|
@ -1752,7 +1756,7 @@ static void qeth_l3_add_multicast_ipv6(struct qeth_card *card)
|
|||
{
|
||||
struct inet6_dev *in6_dev;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "chkmcv6");
|
||||
QETH_DBF_TEXT(TRACE, 4, "chkmcv6");
|
||||
if (!qeth_is_supported(card, IPA_IPV6))
|
||||
return ;
|
||||
in6_dev = in6_dev_get(card->dev);
|
||||
|
@ -1773,7 +1777,7 @@ static void qeth_l3_free_vlan_addresses4(struct qeth_card *card,
|
|||
struct in_ifaddr *ifa;
|
||||
struct qeth_ipaddr *addr;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "frvaddr4");
|
||||
QETH_DBF_TEXT(TRACE, 4, "frvaddr4");
|
||||
|
||||
in_dev = in_dev_get(vlan_group_get_device(card->vlangrp, vid));
|
||||
if (!in_dev)
|
||||
|
@ -1799,7 +1803,7 @@ static void qeth_l3_free_vlan_addresses6(struct qeth_card *card,
|
|||
struct inet6_ifaddr *ifa;
|
||||
struct qeth_ipaddr *addr;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "frvaddr6");
|
||||
QETH_DBF_TEXT(TRACE, 4, "frvaddr6");
|
||||
|
||||
in6_dev = in6_dev_get(vlan_group_get_device(card->vlangrp, vid));
|
||||
if (!in6_dev)
|
||||
|
@ -1834,7 +1838,7 @@ static void qeth_l3_vlan_rx_register(struct net_device *dev,
|
|||
struct qeth_card *card = netdev_priv(dev);
|
||||
unsigned long flags;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "vlanreg");
|
||||
QETH_DBF_TEXT(TRACE, 4, "vlanreg");
|
||||
spin_lock_irqsave(&card->vlanlock, flags);
|
||||
card->vlangrp = grp;
|
||||
spin_unlock_irqrestore(&card->vlanlock, flags);
|
||||
|
@ -1872,7 +1876,7 @@ static void qeth_l3_vlan_rx_kill_vid(struct net_device *dev, unsigned short vid)
|
|||
struct qeth_card *card = netdev_priv(dev);
|
||||
unsigned long flags;
|
||||
|
||||
QETH_DBF_TEXT_(trace, 4, "kid:%d", vid);
|
||||
QETH_DBF_TEXT_(TRACE, 4, "kid:%d", vid);
|
||||
spin_lock_irqsave(&card->vlanlock, flags);
|
||||
/* unregister IP addresses of vlan device */
|
||||
qeth_l3_free_vlan_addresses(card, vid);
|
||||
|
@ -2002,8 +2006,8 @@ static void qeth_l3_process_inbound_buffer(struct qeth_card *card,
|
|||
break;
|
||||
default:
|
||||
dev_kfree_skb_any(skb);
|
||||
QETH_DBF_TEXT(trace, 3, "inbunkno");
|
||||
QETH_DBF_HEX(control, 3, hdr, QETH_DBF_CONTROL_LEN);
|
||||
QETH_DBF_TEXT(TRACE, 3, "inbunkno");
|
||||
QETH_DBF_HEX(CTRL, 3, hdr, QETH_DBF_CTRL_LEN);
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@ -2070,7 +2074,7 @@ static struct qeth_card *qeth_l3_get_card_from_dev(struct net_device *dev)
|
|||
card = netdev_priv(vlan_dev_info(dev)->real_dev);
|
||||
if (card->options.layer2)
|
||||
card = NULL;
|
||||
QETH_DBF_TEXT_(trace, 4, "%d", rc);
|
||||
QETH_DBF_TEXT_(TRACE, 4, "%d", rc);
|
||||
return card ;
|
||||
}
|
||||
|
||||
|
@ -2078,8 +2082,8 @@ static int qeth_l3_stop_card(struct qeth_card *card, int recovery_mode)
|
|||
{
|
||||
int rc = 0;
|
||||
|
||||
QETH_DBF_TEXT(setup, 2, "stopcard");
|
||||
QETH_DBF_HEX(setup, 2, &card, sizeof(void *));
|
||||
QETH_DBF_TEXT(SETUP, 2, "stopcard");
|
||||
QETH_DBF_HEX(SETUP, 2, &card, sizeof(void *));
|
||||
|
||||
qeth_set_allowed_threads(card, 0, 1);
|
||||
if (qeth_wait_for_threads(card, ~QETH_RECOVER_THREAD))
|
||||
|
@ -2092,7 +2096,7 @@ static int qeth_l3_stop_card(struct qeth_card *card, int recovery_mode)
|
|||
if (!card->use_hard_stop) {
|
||||
rc = qeth_send_stoplan(card);
|
||||
if (rc)
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
}
|
||||
card->state = CARD_STATE_SOFTSETUP;
|
||||
}
|
||||
|
@ -2106,7 +2110,7 @@ static int qeth_l3_stop_card(struct qeth_card *card, int recovery_mode)
|
|||
(card->info.type != QETH_CARD_TYPE_IQD)) {
|
||||
rc = qeth_l3_put_unique_id(card);
|
||||
if (rc)
|
||||
QETH_DBF_TEXT_(setup, 2, "2err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "2err%d", rc);
|
||||
}
|
||||
qeth_qdio_clear_card(card, 0);
|
||||
qeth_clear_qdio_buffers(card);
|
||||
|
@ -2125,7 +2129,7 @@ static void qeth_l3_set_multicast_list(struct net_device *dev)
|
|||
{
|
||||
struct qeth_card *card = netdev_priv(dev);
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "setmulti");
|
||||
QETH_DBF_TEXT(TRACE, 3, "setmulti");
|
||||
qeth_l3_delete_mc_addresses(card);
|
||||
qeth_l3_add_multicast_ipv4(card);
|
||||
#ifdef CONFIG_QETH_IPV6
|
||||
|
@ -2165,7 +2169,7 @@ static int qeth_l3_arp_set_no_entries(struct qeth_card *card, int no_entries)
|
|||
int tmp;
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "arpstnoe");
|
||||
QETH_DBF_TEXT(TRACE, 3, "arpstnoe");
|
||||
|
||||
/*
|
||||
* currently GuestLAN only supports the ARP assist function
|
||||
|
@ -2219,17 +2223,17 @@ static int qeth_l3_arp_query_cb(struct qeth_card *card,
|
|||
int uentry_size;
|
||||
int i;
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "arpquecb");
|
||||
QETH_DBF_TEXT(TRACE, 4, "arpquecb");
|
||||
|
||||
qinfo = (struct qeth_arp_query_info *) reply->param;
|
||||
cmd = (struct qeth_ipa_cmd *) data;
|
||||
if (cmd->hdr.return_code) {
|
||||
QETH_DBF_TEXT_(trace, 4, "qaer1%i", cmd->hdr.return_code);
|
||||
QETH_DBF_TEXT_(TRACE, 4, "qaer1%i", cmd->hdr.return_code);
|
||||
return 0;
|
||||
}
|
||||
if (cmd->data.setassparms.hdr.return_code) {
|
||||
cmd->hdr.return_code = cmd->data.setassparms.hdr.return_code;
|
||||
QETH_DBF_TEXT_(trace, 4, "qaer2%i", cmd->hdr.return_code);
|
||||
QETH_DBF_TEXT_(TRACE, 4, "qaer2%i", cmd->hdr.return_code);
|
||||
return 0;
|
||||
}
|
||||
qdata = &cmd->data.setassparms.data.query_arp;
|
||||
|
@ -2251,17 +2255,17 @@ static int qeth_l3_arp_query_cb(struct qeth_card *card,
|
|||
/* check if there is enough room in userspace */
|
||||
if ((qinfo->udata_len - qinfo->udata_offset) <
|
||||
qdata->no_entries * uentry_size){
|
||||
QETH_DBF_TEXT_(trace, 4, "qaer3%i", -ENOMEM);
|
||||
QETH_DBF_TEXT_(TRACE, 4, "qaer3%i", -ENOMEM);
|
||||
cmd->hdr.return_code = -ENOMEM;
|
||||
PRINT_WARN("query ARP user space buffer is too small for "
|
||||
"the returned number of ARP entries. "
|
||||
"Aborting query!\n");
|
||||
goto out_error;
|
||||
}
|
||||
QETH_DBF_TEXT_(trace, 4, "anore%i",
|
||||
QETH_DBF_TEXT_(TRACE, 4, "anore%i",
|
||||
cmd->data.setassparms.hdr.number_of_replies);
|
||||
QETH_DBF_TEXT_(trace, 4, "aseqn%i", cmd->data.setassparms.hdr.seq_no);
|
||||
QETH_DBF_TEXT_(trace, 4, "anoen%i", qdata->no_entries);
|
||||
QETH_DBF_TEXT_(TRACE, 4, "aseqn%i", cmd->data.setassparms.hdr.seq_no);
|
||||
QETH_DBF_TEXT_(TRACE, 4, "anoen%i", qdata->no_entries);
|
||||
|
||||
if (qinfo->mask_bits & QETH_QARP_STRIP_ENTRIES) {
|
||||
/* strip off "media specific information" */
|
||||
|
@ -2297,7 +2301,7 @@ static int qeth_l3_send_ipa_arp_cmd(struct qeth_card *card,
|
|||
unsigned long),
|
||||
void *reply_param)
|
||||
{
|
||||
QETH_DBF_TEXT(trace, 4, "sendarp");
|
||||
QETH_DBF_TEXT(TRACE, 4, "sendarp");
|
||||
|
||||
memcpy(iob->data, IPA_PDU_HEADER, IPA_PDU_HEADER_SIZE);
|
||||
memcpy(QETH_IPA_CMD_DEST_ADDR(iob->data),
|
||||
|
@ -2313,7 +2317,7 @@ static int qeth_l3_arp_query(struct qeth_card *card, char __user *udata)
|
|||
int tmp;
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "arpquery");
|
||||
QETH_DBF_TEXT(TRACE, 3, "arpquery");
|
||||
|
||||
if (!qeth_is_supported(card,/*IPA_QUERY_ARP_ADDR_INFO*/
|
||||
IPA_ARP_PROCESSING)) {
|
||||
|
@ -2358,7 +2362,7 @@ static int qeth_l3_arp_add_entry(struct qeth_card *card,
|
|||
int tmp;
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "arpadent");
|
||||
QETH_DBF_TEXT(TRACE, 3, "arpadent");
|
||||
|
||||
/*
|
||||
* currently GuestLAN only supports the ARP assist function
|
||||
|
@ -2400,7 +2404,7 @@ static int qeth_l3_arp_remove_entry(struct qeth_card *card,
|
|||
int tmp;
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "arprment");
|
||||
QETH_DBF_TEXT(TRACE, 3, "arprment");
|
||||
|
||||
/*
|
||||
* currently GuestLAN only supports the ARP assist function
|
||||
|
@ -2439,7 +2443,7 @@ static int qeth_l3_arp_flush_cache(struct qeth_card *card)
|
|||
int rc;
|
||||
int tmp;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "arpflush");
|
||||
QETH_DBF_TEXT(TRACE, 3, "arpflush");
|
||||
|
||||
/*
|
||||
* currently GuestLAN only supports the ARP assist function
|
||||
|
@ -2548,14 +2552,14 @@ static int qeth_l3_do_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
|
|||
rc = -EOPNOTSUPP;
|
||||
}
|
||||
if (rc)
|
||||
QETH_DBF_TEXT_(trace, 2, "ioce%d", rc);
|
||||
QETH_DBF_TEXT_(TRACE, 2, "ioce%d", rc);
|
||||
return rc;
|
||||
}
|
||||
|
||||
static void qeth_l3_fill_header(struct qeth_card *card, struct qeth_hdr *hdr,
|
||||
struct sk_buff *skb, int ipv, int cast_type)
|
||||
{
|
||||
QETH_DBF_TEXT(trace, 6, "fillhdr");
|
||||
QETH_DBF_TEXT(TRACE, 6, "fillhdr");
|
||||
|
||||
memset(hdr, 0, sizeof(struct qeth_hdr));
|
||||
hdr->hdr.l3.id = QETH_HEADER_TYPE_LAYER3;
|
||||
|
@ -2634,7 +2638,7 @@ static int qeth_l3_hard_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
|||
enum qeth_large_send_types large_send = QETH_LARGE_SEND_NO;
|
||||
struct qeth_eddp_context *ctx = NULL;
|
||||
|
||||
QETH_DBF_TEXT(trace, 6, "l3xmit");
|
||||
QETH_DBF_TEXT(TRACE, 6, "l3xmit");
|
||||
|
||||
if ((card->info.type == QETH_CARD_TYPE_IQD) &&
|
||||
(skb->protocol != htons(ETH_P_IPV6)) &&
|
||||
|
@ -2795,7 +2799,7 @@ static int qeth_l3_open(struct net_device *dev)
|
|||
{
|
||||
struct qeth_card *card = netdev_priv(dev);
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "qethopen");
|
||||
QETH_DBF_TEXT(TRACE, 4, "qethopen");
|
||||
if (card->state != CARD_STATE_SOFTSETUP)
|
||||
return -ENODEV;
|
||||
card->data.state = CH_STATE_UP;
|
||||
|
@ -2812,7 +2816,7 @@ static int qeth_l3_stop(struct net_device *dev)
|
|||
{
|
||||
struct qeth_card *card = netdev_priv(dev);
|
||||
|
||||
QETH_DBF_TEXT(trace, 4, "qethstop");
|
||||
QETH_DBF_TEXT(TRACE, 4, "qethstop");
|
||||
netif_tx_disable(dev);
|
||||
card->dev->flags &= ~IFF_UP;
|
||||
if (card->state == CARD_STATE_UP)
|
||||
|
@ -2957,6 +2961,7 @@ static int qeth_l3_setup_netdev(struct qeth_card *card)
|
|||
card->dev->vlan_rx_add_vid = qeth_l3_vlan_rx_add_vid;
|
||||
card->dev->vlan_rx_kill_vid = qeth_l3_vlan_rx_kill_vid;
|
||||
card->dev->mtu = card->info.initial_mtu;
|
||||
card->dev->set_mac_address = NULL;
|
||||
SET_ETHTOOL_OPS(card->dev, &qeth_l3_ethtool_ops);
|
||||
card->dev->features |= NETIF_F_HW_VLAN_TX |
|
||||
NETIF_F_HW_VLAN_RX |
|
||||
|
@ -2977,7 +2982,7 @@ static void qeth_l3_qdio_input_handler(struct ccw_device *ccwdev,
|
|||
int index;
|
||||
int i;
|
||||
|
||||
QETH_DBF_TEXT(trace, 6, "qdinput");
|
||||
QETH_DBF_TEXT(TRACE, 6, "qdinput");
|
||||
card = (struct qeth_card *) card_ptr;
|
||||
net_dev = card->dev;
|
||||
if (card->options.performance_stats) {
|
||||
|
@ -2986,11 +2991,11 @@ static void qeth_l3_qdio_input_handler(struct ccw_device *ccwdev,
|
|||
}
|
||||
if (status & QDIO_STATUS_LOOK_FOR_ERROR) {
|
||||
if (status & QDIO_STATUS_ACTIVATE_CHECK_CONDITION) {
|
||||
QETH_DBF_TEXT(trace, 1, "qdinchk");
|
||||
QETH_DBF_TEXT_(trace, 1, "%s", CARD_BUS_ID(card));
|
||||
QETH_DBF_TEXT_(trace, 1, "%04X%04X",
|
||||
QETH_DBF_TEXT(TRACE, 1, "qdinchk");
|
||||
QETH_DBF_TEXT_(TRACE, 1, "%s", CARD_BUS_ID(card));
|
||||
QETH_DBF_TEXT_(TRACE, 1, "%04X%04X",
|
||||
first_element, count);
|
||||
QETH_DBF_TEXT_(trace, 1, "%04X%04X", queue, status);
|
||||
QETH_DBF_TEXT_(TRACE, 1, "%04X%04X", queue, status);
|
||||
qeth_schedule_recovery(card);
|
||||
return;
|
||||
}
|
||||
|
@ -3054,8 +3059,8 @@ static int __qeth_l3_set_online(struct ccwgroup_device *gdev, int recovery_mode)
|
|||
enum qeth_card_states recover_flag;
|
||||
|
||||
BUG_ON(!card);
|
||||
QETH_DBF_TEXT(setup, 2, "setonlin");
|
||||
QETH_DBF_HEX(setup, 2, &card, sizeof(void *));
|
||||
QETH_DBF_TEXT(SETUP, 2, "setonlin");
|
||||
QETH_DBF_HEX(SETUP, 2, &card, sizeof(void *));
|
||||
|
||||
qeth_set_allowed_threads(card, QETH_RECOVER_THREAD, 1);
|
||||
if (qeth_wait_for_threads(card, ~QETH_RECOVER_THREAD)) {
|
||||
|
@ -3067,23 +3072,23 @@ static int __qeth_l3_set_online(struct ccwgroup_device *gdev, int recovery_mode)
|
|||
recover_flag = card->state;
|
||||
rc = ccw_device_set_online(CARD_RDEV(card));
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
return -EIO;
|
||||
}
|
||||
rc = ccw_device_set_online(CARD_WDEV(card));
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
return -EIO;
|
||||
}
|
||||
rc = ccw_device_set_online(CARD_DDEV(card));
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
rc = qeth_core_hardsetup_card(card);
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "2err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "2err%d", rc);
|
||||
goto out_remove;
|
||||
}
|
||||
|
||||
|
@ -3096,11 +3101,11 @@ static int __qeth_l3_set_online(struct ccwgroup_device *gdev, int recovery_mode)
|
|||
qeth_print_status_message(card);
|
||||
|
||||
/* softsetup */
|
||||
QETH_DBF_TEXT(setup, 2, "softsetp");
|
||||
QETH_DBF_TEXT(SETUP, 2, "softsetp");
|
||||
|
||||
rc = qeth_send_startlan(card);
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
if (rc == 0xe080) {
|
||||
PRINT_WARN("LAN on card %s if offline! "
|
||||
"Waiting for STARTLAN from card.\n",
|
||||
|
@ -3114,21 +3119,21 @@ static int __qeth_l3_set_online(struct ccwgroup_device *gdev, int recovery_mode)
|
|||
|
||||
rc = qeth_l3_setadapter_parms(card);
|
||||
if (rc)
|
||||
QETH_DBF_TEXT_(setup, 2, "2err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "2err%d", rc);
|
||||
rc = qeth_l3_start_ipassists(card);
|
||||
if (rc)
|
||||
QETH_DBF_TEXT_(setup, 2, "3err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "3err%d", rc);
|
||||
rc = qeth_l3_setrouting_v4(card);
|
||||
if (rc)
|
||||
QETH_DBF_TEXT_(setup, 2, "4err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "4err%d", rc);
|
||||
rc = qeth_l3_setrouting_v6(card);
|
||||
if (rc)
|
||||
QETH_DBF_TEXT_(setup, 2, "5err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "5err%d", rc);
|
||||
netif_tx_disable(card->dev);
|
||||
|
||||
rc = qeth_init_qdio_queues(card);
|
||||
if (rc) {
|
||||
QETH_DBF_TEXT_(setup, 2, "6err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "6err%d", rc);
|
||||
goto out_remove;
|
||||
}
|
||||
card->state = CARD_STATE_SOFTSETUP;
|
||||
|
@ -3167,8 +3172,8 @@ static int __qeth_l3_set_offline(struct ccwgroup_device *cgdev,
|
|||
int rc = 0, rc2 = 0, rc3 = 0;
|
||||
enum qeth_card_states recover_flag;
|
||||
|
||||
QETH_DBF_TEXT(setup, 3, "setoffl");
|
||||
QETH_DBF_HEX(setup, 3, &card, sizeof(void *));
|
||||
QETH_DBF_TEXT(SETUP, 3, "setoffl");
|
||||
QETH_DBF_HEX(SETUP, 3, &card, sizeof(void *));
|
||||
|
||||
if (card->dev && netif_carrier_ok(card->dev))
|
||||
netif_carrier_off(card->dev);
|
||||
|
@ -3184,7 +3189,7 @@ static int __qeth_l3_set_offline(struct ccwgroup_device *cgdev,
|
|||
if (!rc)
|
||||
rc = (rc2) ? rc2 : rc3;
|
||||
if (rc)
|
||||
QETH_DBF_TEXT_(setup, 2, "1err%d", rc);
|
||||
QETH_DBF_TEXT_(SETUP, 2, "1err%d", rc);
|
||||
if (recover_flag == CARD_STATE_UP)
|
||||
card->state = CARD_STATE_RECOVER;
|
||||
/* let user_space know that device is offline */
|
||||
|
@ -3203,11 +3208,11 @@ static int qeth_l3_recover(void *ptr)
|
|||
int rc = 0;
|
||||
|
||||
card = (struct qeth_card *) ptr;
|
||||
QETH_DBF_TEXT(trace, 2, "recover1");
|
||||
QETH_DBF_HEX(trace, 2, &card, sizeof(void *));
|
||||
QETH_DBF_TEXT(TRACE, 2, "recover1");
|
||||
QETH_DBF_HEX(TRACE, 2, &card, sizeof(void *));
|
||||
if (!qeth_do_run_thread(card, QETH_RECOVER_THREAD))
|
||||
return 0;
|
||||
QETH_DBF_TEXT(trace, 2, "recover2");
|
||||
QETH_DBF_TEXT(TRACE, 2, "recover2");
|
||||
PRINT_WARN("Recovery of device %s started ...\n",
|
||||
CARD_BUS_ID(card));
|
||||
card->use_hard_stop = 1;
|
||||
|
@ -3253,7 +3258,7 @@ static int qeth_l3_ip_event(struct notifier_block *this,
|
|||
if (dev_net(dev) != &init_net)
|
||||
return NOTIFY_DONE;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "ipevent");
|
||||
QETH_DBF_TEXT(TRACE, 3, "ipevent");
|
||||
card = qeth_l3_get_card_from_dev(dev);
|
||||
if (!card)
|
||||
return NOTIFY_DONE;
|
||||
|
@ -3300,7 +3305,7 @@ static int qeth_l3_ip6_event(struct notifier_block *this,
|
|||
struct qeth_ipaddr *addr;
|
||||
struct qeth_card *card;
|
||||
|
||||
QETH_DBF_TEXT(trace, 3, "ip6event");
|
||||
QETH_DBF_TEXT(TRACE, 3, "ip6event");
|
||||
|
||||
card = qeth_l3_get_card_from_dev(dev);
|
||||
if (!card)
|
||||
|
@ -3343,7 +3348,7 @@ static int qeth_l3_register_notifiers(void)
|
|||
{
|
||||
int rc;
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "regnotif");
|
||||
QETH_DBF_TEXT(TRACE, 5, "regnotif");
|
||||
rc = register_inetaddr_notifier(&qeth_l3_ip_notifier);
|
||||
if (rc)
|
||||
return rc;
|
||||
|
@ -3362,7 +3367,7 @@ static int qeth_l3_register_notifiers(void)
|
|||
static void qeth_l3_unregister_notifiers(void)
|
||||
{
|
||||
|
||||
QETH_DBF_TEXT(trace, 5, "unregnot");
|
||||
QETH_DBF_TEXT(TRACE, 5, "unregnot");
|
||||
BUG_ON(unregister_inetaddr_notifier(&qeth_l3_ip_notifier));
|
||||
#ifdef CONFIG_QETH_IPV6
|
||||
BUG_ON(unregister_inet6addr_notifier(&qeth_l3_ip6_notifier));
|
||||
|
|
|
@ -50,7 +50,7 @@ struct gianfar_platform_data {
|
|||
u32 device_flags;
|
||||
/* board specific information */
|
||||
u32 board_flags;
|
||||
u32 bus_id;
|
||||
char bus_id[MII_BUS_ID_SIZE];
|
||||
u32 phy_id;
|
||||
u8 mac_addr[6];
|
||||
phy_interface_t interface;
|
||||
|
|
|
@ -39,7 +39,8 @@
|
|||
SUPPORTED_1000baseT_Half | \
|
||||
SUPPORTED_1000baseT_Full)
|
||||
|
||||
/* Set phydev->irq to PHY_POLL if interrupts are not supported,
|
||||
/*
|
||||
* Set phydev->irq to PHY_POLL if interrupts are not supported,
|
||||
* or not desired for this PHY. Set to PHY_IGNORE_INTERRUPT if
|
||||
* the attached driver handles the interrupt
|
||||
*/
|
||||
|
@ -63,8 +64,6 @@ typedef enum {
|
|||
PHY_INTERFACE_MODE_RTBI
|
||||
} phy_interface_t;
|
||||
|
||||
#define MII_BUS_MAX 4
|
||||
|
||||
|
||||
#define PHY_INIT_TIMEOUT 100000
|
||||
#define PHY_STATE_TIME 1
|
||||
|
@ -74,20 +73,30 @@ typedef enum {
|
|||
#define PHY_MAX_ADDR 32
|
||||
|
||||
/* Used when trying to connect to a specific phy (mii bus id:phy device id) */
|
||||
#define PHY_ID_FMT "%x:%02x"
|
||||
#define PHY_ID_FMT "%s:%02x"
|
||||
|
||||
/* The Bus class for PHYs. Devices which provide access to
|
||||
* PHYs should register using this structure */
|
||||
/*
|
||||
* Need to be a little smaller than phydev->dev.bus_id to leave room
|
||||
* for the ":%02x"
|
||||
*/
|
||||
#define MII_BUS_ID_SIZE (BUS_ID_SIZE - 3)
|
||||
|
||||
/*
|
||||
* The Bus class for PHYs. Devices which provide access to
|
||||
* PHYs should register using this structure
|
||||
*/
|
||||
struct mii_bus {
|
||||
const char *name;
|
||||
int id;
|
||||
char id[MII_BUS_ID_SIZE];
|
||||
void *priv;
|
||||
int (*read)(struct mii_bus *bus, int phy_id, int regnum);
|
||||
int (*write)(struct mii_bus *bus, int phy_id, int regnum, u16 val);
|
||||
int (*reset)(struct mii_bus *bus);
|
||||
|
||||
/* A lock to ensure that only one thing can read/write
|
||||
* the MDIO bus at a time */
|
||||
/*
|
||||
* A lock to ensure that only one thing can read/write
|
||||
* the MDIO bus at a time
|
||||
*/
|
||||
struct mutex mdio_lock;
|
||||
|
||||
struct device *dev;
|
||||
|
@ -98,8 +107,10 @@ struct mii_bus {
|
|||
/* Phy addresses to be ignored when probing */
|
||||
u32 phy_mask;
|
||||
|
||||
/* Pointer to an array of interrupts, each PHY's
|
||||
* interrupt at the index matching its address */
|
||||
/*
|
||||
* Pointer to an array of interrupts, each PHY's
|
||||
* interrupt at the index matching its address
|
||||
*/
|
||||
int *irq;
|
||||
};
|
||||
|
||||
|
@ -251,7 +262,8 @@ struct phy_device {
|
|||
/* Bus address of the PHY (0-32) */
|
||||
int addr;
|
||||
|
||||
/* forced speed & duplex (no autoneg)
|
||||
/*
|
||||
* forced speed & duplex (no autoneg)
|
||||
* partner speed & duplex & pause (autoneg)
|
||||
*/
|
||||
int speed;
|
||||
|
@ -274,8 +286,10 @@ struct phy_device {
|
|||
|
||||
int link_timeout;
|
||||
|
||||
/* Interrupt number for this PHY
|
||||
* -1 means no interrupt */
|
||||
/*
|
||||
* Interrupt number for this PHY
|
||||
* -1 means no interrupt
|
||||
*/
|
||||
int irq;
|
||||
|
||||
/* private data pointer */
|
||||
|
@ -325,22 +339,28 @@ struct phy_driver {
|
|||
u32 features;
|
||||
u32 flags;
|
||||
|
||||
/* Called to initialize the PHY,
|
||||
* including after a reset */
|
||||
/*
|
||||
* Called to initialize the PHY,
|
||||
* including after a reset
|
||||
*/
|
||||
int (*config_init)(struct phy_device *phydev);
|
||||
|
||||
/* Called during discovery. Used to set
|
||||
* up device-specific structures, if any */
|
||||
/*
|
||||
* Called during discovery. Used to set
|
||||
* up device-specific structures, if any
|
||||
*/
|
||||
int (*probe)(struct phy_device *phydev);
|
||||
|
||||
/* PHY Power Management */
|
||||
int (*suspend)(struct phy_device *phydev);
|
||||
int (*resume)(struct phy_device *phydev);
|
||||
|
||||
/* Configures the advertisement and resets
|
||||
/*
|
||||
* Configures the advertisement and resets
|
||||
* autonegotiation if phydev->autoneg is on,
|
||||
* forces the speed to the current settings in phydev
|
||||
* if phydev->autoneg is off */
|
||||
* if phydev->autoneg is off
|
||||
*/
|
||||
int (*config_aneg)(struct phy_device *phydev);
|
||||
|
||||
/* Determines the negotiated speed and duplex */
|
||||
|
@ -361,6 +381,7 @@ struct phy_driver {
|
|||
|
||||
int phy_read(struct phy_device *phydev, u16 regnum);
|
||||
int phy_write(struct phy_device *phydev, u16 regnum, u16 val);
|
||||
int get_phy_id(struct mii_bus *bus, int addr, u32 *phy_id);
|
||||
struct phy_device* get_phy_device(struct mii_bus *bus, int addr);
|
||||
int phy_clear_interrupt(struct phy_device *phydev);
|
||||
int phy_config_interrupt(struct phy_device *phydev, u32 interrupts);
|
||||
|
|
Loading…
Reference in New Issue