diff -u linux-2.6.16.18/drivers/net/netxen/netxen_nic_isr.c linux-2.6.16.18/drivers/net/netxen/netxen_nic_isr.c --- linux-2.6.16.18/drivers/net/netxen/netxen_nic_isr.c 2006-05-25 02:43:22.000000000 -0700 +++ linux-2.6.16.18/drivers/net/netxen/netxen_nic_isr.c 2006-05-26 04:05:34.000000000 -0700 @@ -45,9 +45,6 @@ struct netxen_cmd_buffer *cmd_buff; struct netxen_skb_frag *buffrag;
- port->state = NETXEN_PORT_DOWN; - /* should we disable to phy for the port */ - /* disable phy_ints */ netxen_nic_disable_phy_interrupts(adapter, (long)port->portnum); @@ -97,7 +94,6 @@ if (netif_running(netdev)) { netif_carrier_off(netdev); netif_stop_queue(netdev); - port->state = NETXEN_PORT_SUSPEND; netxen_nic_down(port); } @@ -108,10 +104,8 @@ { u32 ret; struct net_device *netdev = pci_get_drvdata(pdev); - struct netxen_port *port = netdev_priv(netdev); ret = pci_enable_device(pdev); - port->state = NETXEN_PORT_UP; netif_device_attach(netdev); return ret; } On Thu, 2006-05-25 at 03:55 -0700, Linsys Contractor Amit S. Kale wrote: > diff -Naru linux-2.6.16.18.orig/drivers/net/netxen/netxen_nic_ioctl.h > linux-2.6.16.18/drivers/net/netxen/netxen_nic_ioctl.h > --- linux-2.6.16.18.orig/drivers/net/netxen/netxen_nic_ioctl.h > 1969-12-31 16:00:00.000000000 -0800 > +++ linux-2.6.16.18/drivers/net/netxen/netxen_nic_ioctl.h 2006-05-25 > 02:43:22.000000000 -0700 > @@ -0,0 +1,75 @@ > +/* > + * Copyright (C) 2003 - 2006 NetXen, Inc. > + * All rights reserved. > + * > + * This program is free software; you can redistribute it and/or > + * modify it under the terms of the GNU General Public License > + * as published by the Free Software Foundation; either version 2 > + * of the License, or (at your option) any later version. > + * > + * This program is distributed in the hope that it will be useful, but > + * WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + * > + * You should have received a copy of the GNU General Public License > + * along with this program; if not, write to the Free Software > + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, > + * MA 02111-1307, USA. > + * > + * The full GNU General Public License is included in this distribution > + * in the file called LICENSE. > + * > + * Contact Information: > + * [EMAIL PROTECTED] > + * NetXen, > + * 3965 Freedom Circle, Fourth floor, > + * Santa Clara, CA 95054 > + */ > + > +#ifndef __NETXEN_NIC_IOCTL_H__ > +#define __NETXEN_NIC_IOCTL_H__ > + > +#include <linux/sockios.h> > + > +#define NETXEN_CMD_START SIOCDEVPRIVATE > +#define NETXEN_NIC_CMD (NETXEN_CMD_START + 1) > +#define NETXEN_NIC_NAME (NETXEN_CMD_START + 2) > + > +typedef enum { > + netxen_nic_cmd_none = 0, > + netxen_nic_cmd_pci_read, > + netxen_nic_cmd_pci_write, > + netxen_nic_cmd_pci_mem_read, > + netxen_nic_cmd_pci_mem_write, > + netxen_nic_cmd_pci_config_read, > + netxen_nic_cmd_pci_config_write, > + netxen_nic_cmd_get_stats, > + netxen_nic_cmd_clear_stats, > + netxen_nic_cmd_get_version > +} netxen_nic_ioctl_cmd_t; > + > +struct netxen_nic_ioctl_data { > + u32 cmd; > + u32 unused1; > + u64 off; > + u32 size; > + u32 rv; > + char u[64]; > + void *ptr; > +}; > + > +struct netxen_statistics { > + u64 rx_packets; > + u64 tx_packets; > + u64 rx_bytes; > + u64 rx_errors; > + u64 tx_bytes; > + u64 tx_errors; > + u64 rx_crc_errors; > + u64 rx_short_length_error; > + u64 rx_long_length_error; > + u64 rx_mac_errors; > +}; > + > +#endif /* __NETXEN_NIC_IOCTL_H_ */ > diff -Naru linux-2.6.16.18.orig/drivers/net/netxen/netxen_nic_isr.c > linux-2.6.16.18/drivers/net/netxen/netxen_nic_isr.c > --- linux-2.6.16.18.orig/drivers/net/netxen/netxen_nic_isr.c 1969-12-31 > 16:00:00.000000000 -0800 > +++ linux-2.6.16.18/drivers/net/netxen/netxen_nic_isr.c 2006-05-25 > 02:43:22.000000000 -0700 > @@ -0,0 +1,428 @@ > +/* > + * Copyright (C) 2003 - 2006 NetXen, Inc. > + * All rights reserved. > + * > + * This program is free software; you can redistribute it and/or > + * modify it under the terms of the GNU General Public License > + * as published by the Free Software Foundation; either version 2 > + * of the License, or (at your option) any later version. > + * > + * This program is distributed in the hope that it will be useful, but > + * WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + * > + * You should have received a copy of the GNU General Public License > + * along with this program; if not, write to the Free Software > + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, > + * MA 02111-1307, USA. > + * > + * The full GNU General Public License is included in this distribution > + * in the file called LICENSE. > + * > + * Contact Information: > + * [EMAIL PROTECTED] > + * NetXen, > + * 3965 Freedom Circle, Fourth floor, > + * Santa Clara, CA 95054 > + */ > + > +#include <linux/netdevice.h> > +#include <linux/delay.h> > + > +#include "netxen_nic.h" > +#include "netxen_nic_hw.h" > +#include "netxen_nic_phan_reg.h" > + > +/* > + * This will be called when all the ports of the adapter are removed. > + * This will cleanup and disable interrupts and irq. > + */ > +void netxen_nic_down(struct netxen_port *port) > +{ > + struct netxen_adapter *adapter = port->adapter; > + int i, j; > + struct netxen_cmd_buffer *cmd_buff; > + struct netxen_skb_frag *buffrag; > + > + port->state = NETXEN_PORT_DOWN; > + /* should we disable to phy for the port */ > + > + /* disable phy_ints */ > + netxen_nic_disable_phy_interrupts(adapter, (long)port->portnum); > + > + adapter->active_ports--; > + > + if (!adapter->active_ports) { > + read_lock(&adapter->adapter_lock); > + netxen_nic_disable_int(adapter); > + read_unlock(&adapter->adapter_lock); > + cmd_buff = adapter->cmd_buf_arr; > + for (i = 0; i < adapter->max_tx_desc_count; i++) { > + buffrag = cmd_buff->frag_array; > + if (buffrag->dma) { > + pci_unmap_single(port->pdev, buffrag->dma, > + buffrag->length, > + PCI_DMA_TODEVICE); > + buffrag->dma = (u64) NULL; > + } > + for (j = 0; j < cmd_buff->frag_count; j++) { > + buffrag++; > + if (buffrag->dma) { > + pci_unmap_page(port->pdev, > + buffrag->dma, > + buffrag->length, > + PCI_DMA_TODEVICE); > + buffrag->dma = (u64) NULL; > + } > + } > + /* Free the skb we received in netxen_nic_xmit_frame */ > + if (cmd_buff->skb) { > + dev_kfree_skb_any(cmd_buff->skb); > + cmd_buff->skb = NULL; > + } > + cmd_buff++; > + } > + } > + del_timer_sync(&adapter->watchdog_timer); > +} > + > +int netxen_nic_suspend(struct pci_dev *pdev, pm_message_t state) > +{ > + struct net_device *netdev = pci_get_drvdata(pdev); > + struct netxen_port *port = netdev_priv(netdev); > + > + netif_device_detach(netdev); > + > + if (netif_running(netdev)) { > + netif_carrier_off(netdev); > + netif_stop_queue(netdev); > + port->state = NETXEN_PORT_SUSPEND; > + netxen_nic_down(port); > + } > + > + return 0; > +} > + > +int netxen_nic_resume(struct pci_dev *pdev) > +{ > + u32 ret; > + struct net_device *netdev = pci_get_drvdata(pdev); > + struct netxen_port *port = netdev_priv(netdev); > + > + ret = pci_enable_device(pdev); > + port->state = NETXEN_PORT_UP; > + netif_device_attach(netdev); > + return ret; > +} > + > +/* > + * netxen_nic_get_stats - Get System Network Statistics > + * @netdev: network interface device structure > + */ > +struct net_device_stats *netxen_nic_get_stats(struct net_device *netdev) > +{ > + struct netxen_port *port = netdev_priv(netdev); > + struct net_device_stats *stats = &port->net_stats; > + > + memset(stats, 0, sizeof(*stats)); > + > + /* total packets received */ > + stats->rx_packets = port->stats.no_rcv; > + /* total packets transmitted */ > + stats->tx_packets = port->stats.xmitedframes + port->stats.xmitfinished; > + /* total bytes received */ > + stats->rx_bytes = port->stats.rxbytes; > + /* total bytes transmitted */ > + stats->tx_bytes = port->stats.txbytes; > + /* bad packets received */ > + stats->rx_errors = port->stats.rcvdbadskb; > + /* packet transmit problems */ > + stats->tx_errors = port->stats.nocmddescriptor; > + /* no space in linux buffers */ > + stats->rx_dropped = port->stats.updropped; > + /* no space available in linux */ > + stats->tx_dropped = port->stats.txdropped; > + > + return stats; > +} > + > +long netxen_nic_enable_phy_interrupts(struct netxen_adapter *adapter, > + long portno) > +{ > + long result = 0; > + > + switch (adapter->ahw.board_type) { > + case NETXEN_NIC_GBE: > + result = netxen_niu_gbe_enable_phy_interrupts(adapter, portno); > + break; > + > + case NETXEN_NIC_XGBE: > + netxen_crb_writelit_adapter(adapter, NETXEN_NIU_INT_MASK, 0x3f); > + break; > + > + default: > + printk(KERN_ERR "%s: Unknown board type\n", > + netxen_nic_driver_name); > + result = -1; > + } > + > + return result; > +} > + > +long netxen_nic_disable_phy_interrupts(struct netxen_adapter *adapter, > + long portno) > +{ > + long result = 0; > + > + switch (adapter->ahw.board_type) { > + case NETXEN_NIC_GBE: > + result = netxen_niu_gbe_disable_phy_interrupts(adapter, portno); > + break; > + > + case NETXEN_NIC_XGBE: > + netxen_crb_writelit_adapter(adapter, NETXEN_NIU_INT_MASK, 0x7f); > + break; > + > + default: > + printk(KERN_ERR "%s: Unknown board type\n", > + netxen_nic_driver_name); > + result = -1; > + } > + > + return result; > +} > + > +long netxen_nic_clear_phy_interrupts(struct netxen_adapter *adapter, > + long portno) > +{ > + long result = 0; > + > + switch (adapter->ahw.board_type) { > + case NETXEN_NIC_GBE: > + result = netxen_niu_gbe_clear_phy_interrupts(adapter, portno); > + break; > + > + case NETXEN_NIC_XGBE: > + netxen_crb_writelit_adapter(adapter, NETXEN_NIU_ACTIVE_INT, -1); > + break; > + > + default: > + printk(KERN_ERR "%s: Unknown board type\n", > + netxen_nic_driver_name); > + result = -1; > + } > + > + return result; > +} > + > +void netxen_nic_set_mii_mode(struct netxen_adapter *adapter, long portno, > + long enable) > +{ > + switch (adapter->ahw.board_type) { > + case NETXEN_NIC_GBE: > + netxen_niu_gbe_set_mii_mode(adapter, portno, enable); > + break; > + > + case NETXEN_NIC_XGBE: > + printk(KERN_ERR "%s: Function %s is not implemented for XG\n", > + netxen_nic_driver_name, __FUNCTION__); > + break; > + > + default: > + printk(KERN_ERR "%s: Unknown board type\n", > + netxen_nic_driver_name); > + } > +} > + > +void > +netxen_nic_set_gmii_mode(struct netxen_adapter *adapter, long portno, > + long enable) > +{ > + switch (adapter->ahw.board_type) { > + case NETXEN_NIC_GBE: > + netxen_niu_gbe_set_gmii_mode(adapter, portno, enable); > + break; > + > + case NETXEN_NIC_XGBE: > + printk(KERN_ERR "%s: Function %s is not implemented for XG\n", > + netxen_nic_driver_name, __FUNCTION__); > + break; > + > + default: > + printk(KERN_ERR "%s: Unknown board type\n", > + netxen_nic_driver_name); > + } > +} > + > +void netxen_indicate_link_status(struct netxen_adapter *adapter, u32 portno, > + u32 link) > +{ > + struct netxen_port *pport = adapter->port[portno]; > + struct net_device *netdev = pport->netdev; > + > + if (link) > + netif_carrier_on(netdev); > + else > + netif_carrier_off(netdev); > +} > + > +void netxen_handle_port_int(struct netxen_adapter *adapter, u32 portno, > + u32 enable) > +{ > + u32 intr; > + struct netxen_niu_phy_interrupt *int_src; > + struct netxen_port *port; > + > + /* This should clear the interrupt source */ > + netxen_nic_phy_read(adapter, portno, > + NETXEN_NIU_GB_MII_MGMT_ADDR_INT_STATUS, &intr); > + if (intr == 0) { > + DPRINTK(INFO, "No phy interrupts for port #%d\n", portno); > + return; > + } > + int_src = (struct netxen_niu_phy_interrupt *)&intr; > + netxen_nic_disable_phy_interrupts(adapter, portno); > + > + port = adapter->port[portno]; > + > + if (int_src->jabber) > + DPRINTK(INFO, "NetXen: %s Jabber interrupt \n", > + port->netdev->name); > + > + if (int_src->polarity_changed) > + DPRINTK(INFO, "NetXen: %s POLARITY CHANGED int \n", > + port->netdev->name); > + > + if (int_src->energy_detect) > + DPRINTK(INFO, "NetXen: %s ENERGY DETECT INT \n", > + port->netdev->name); > + > + if (int_src->downshift) > + DPRINTK(INFO, "NetXen: %s DOWNSHIFT INT \n", > + port->netdev->name); > + /* write it down later.. */ > + if ((int_src->speed_changed) || (int_src->link_status_changed)) { > + struct netxen_niu_phy_status status; > + > + DPRINTK(INFO, "NetXen: %s SPEED CHANGED OR" > + " LINK STATUS CHANGED \n", port->netdev->name); > + > + if (netxen_nic_phy_read(adapter, portno, > + NETXEN_NIU_GB_MII_MGMT_ADDR_PHY_STATUS, > + (netxen_crbword_t *) & status) == 0) { > + if (int_src->link_status_changed) { > + if (status.link) { > + netxen_niu_gbe_init_port(adapter, > + portno); > + printk("%s: %s Link UP\n", > + netxen_nic_driver_name, > + port->netdev->name); > + > + } else { > + printk("%s: %s Link DOWN\n", > + netxen_nic_driver_name, > + port->netdev->name); > + } > + netxen_indicate_link_status(adapter, portno, > + status.link); > + } > + } > + } > + netxen_nic_enable_phy_interrupts(adapter, portno); > +} > + > +void netxen_nic_isr_other(struct netxen_adapter *adapter) > +{ > + u32 enable, portno; > + u32 i2qhi; > + > + /* > + * bit 3 is for i2qInt, if high its enabled > + * check for phy interrupts > + * read vector and check for bit 45 for phy > + * clear int by writing the same value into ISR_INT_VECTOR REG > + */ > + > + DPRINTK(INFO, "I2Q is the source of INT \n"); > + > + /* verify the offset */ > + read_lock(&adapter->adapter_lock); > + i2qhi = readl(NETXEN_CRB_NORMALIZE(adapter, NETXEN_I2Q_CLR_PCI_HI)); > + read_unlock(&adapter->adapter_lock); > + > + DPRINTK(INFO, "isr NETXEN_I2Q_CLR_PCI_HI = 0x%x \n", i2qhi); > + > + if (i2qhi & 0x4000) { > + for (portno = 0; portno < NETXEN_NIU_MAX_GBE_PORTS; portno++) { > + DPRINTK(INFO, "External PHY interrupt ON PORT %d\n", > + portno); > + > + enable = 1; > + netxen_handle_port_int(adapter, portno, enable); > + } > + > + /* Clear the interrupt on I2Q */ > + read_lock(&adapter->adapter_lock); > + writel((u32) i2qhi, > + NETXEN_CRB_NORMALIZE(adapter, NETXEN_I2Q_CLR_PCI_HI)); > + read_unlock(&adapter->adapter_lock); > + > + } > +} > + > +void netxen_nic_handle_phy_intr(struct netxen_adapter *adapter) > +{ > + u32 val, val1; > + > + switch (adapter->ahw.board_type) { > + case NETXEN_NIC_GBE: > + val = readl(NETXEN_CRB_NORMALIZE(adapter, ISR_INT_VECTOR)); > + if (val & 0x4) { > + adapter->stats.otherints++; > + netxen_nic_isr_other(adapter); > + } > + break; > + > + case NETXEN_NIC_XGBE: > + { > + struct net_device *netdev = adapter->port[0]->netdev; > + > + /* WINDOW = 1 */ > + read_lock(&adapter->adapter_lock); > + val1 = > + readl(NETXEN_CRB_NORMALIZE(adapter, CRB_XG_STATE)); > + read_unlock(&adapter->adapter_lock); > + > + if (adapter->ahw.xg_linkup == 1 && val1 != XG_LINK_UP) { > + printk(KERN_INFO "%s: %s NIC Link is down\n", > + netxen_nic_driver_name, netdev->name); > + adapter->ahw.xg_linkup = 0; > + /* read twice to clear sticky bits */ > + /* WINDOW = 0 */ > + netxen_nic_read_w0(adapter, > + NETXEN_NIU_XG_STATUS, &val1); > + netxen_nic_read_w0(adapter, > + NETXEN_NIU_XG_STATUS, &val1); > + > + if ((val1 & 0xffb) != 0xffb) { > + printk(KERN_INFO > + "%s ISR: Sync/Align BAD: > 0x%08x\n", > + netxen_nic_driver_name, val1); > + } > + > + } else if (adapter->ahw.xg_linkup == 0 > + && val1 == XG_LINK_UP) { > + printk(KERN_INFO "%s: %s NIC Link is up\n", > + netxen_nic_driver_name, netdev->name); > + adapter->ahw.xg_linkup = 1; > + } > + > + } > + break; > + > + default: > + printk(KERN_ERR "%s ISR: Unknown board type\n", > + netxen_nic_driver_name); > + } > +} > > > -- pradeep - To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html