Merge branch 'upstream'
This commit is contained in:
commit
54da9a3968
2
Makefile
2
Makefile
|
@ -1,7 +1,7 @@
|
|||
VERSION = 2
|
||||
PATCHLEVEL = 6
|
||||
SUBLEVEL = 16
|
||||
EXTRAVERSION =-rc5
|
||||
EXTRAVERSION =-rc6
|
||||
NAME=Sliding Snow Leopard
|
||||
|
||||
# *DOCUMENTATION*
|
||||
|
|
|
@ -1574,6 +1574,7 @@ MODULE_LICENSE("GPL");
|
|||
|
||||
static int __init el3_init_module(void)
|
||||
{
|
||||
int ret = 0;
|
||||
el3_cards = 0;
|
||||
|
||||
if (debug >= 0)
|
||||
|
@ -1589,14 +1590,16 @@ static int __init el3_init_module(void)
|
|||
}
|
||||
|
||||
#ifdef CONFIG_EISA
|
||||
if (eisa_driver_register (&el3_eisa_driver) < 0) {
|
||||
eisa_driver_unregister (&el3_eisa_driver);
|
||||
}
|
||||
ret = eisa_driver_register(&el3_eisa_driver);
|
||||
#endif
|
||||
#ifdef CONFIG_MCA
|
||||
mca_register_driver(&el3_mca_driver);
|
||||
{
|
||||
int err = mca_register_driver(&el3_mca_driver);
|
||||
if (ret == 0)
|
||||
ret = err;
|
||||
}
|
||||
#endif
|
||||
return 0;
|
||||
return ret;
|
||||
}
|
||||
|
||||
static void __exit el3_cleanup_module(void)
|
||||
|
|
|
@ -1087,7 +1087,8 @@ config NE2000
|
|||
without a specific driver are compatible with NE2000.
|
||||
|
||||
If you have a PCI NE2000 card however, say N here and Y to "PCI
|
||||
NE2000 support", above. If you have a NE2000 card and are running on
|
||||
NE2000 and clone support" under "EISA, VLB, PCI and on board
|
||||
controllers" below. If you have a NE2000 card and are running on
|
||||
an MCA system (a bus system used on some IBM PS/2 computers and
|
||||
laptops), say N here and Y to "NE/2 (ne2000 MCA version) support",
|
||||
below.
|
||||
|
|
|
@ -1012,7 +1012,7 @@ static int __init read_eeprom(struct net_device *dev)
|
|||
#ifdef MODULE
|
||||
static struct net_device *de620_dev;
|
||||
|
||||
int init_module(void)
|
||||
int __init init_module(void)
|
||||
{
|
||||
de620_dev = de620_probe(-1);
|
||||
if (IS_ERR(de620_dev))
|
||||
|
|
|
@ -50,8 +50,8 @@
|
|||
|
||||
*/
|
||||
#define DRV_NAME "D-Link DL2000-based linux driver"
|
||||
#define DRV_VERSION "v1.17a"
|
||||
#define DRV_RELDATE "2002/10/04"
|
||||
#define DRV_VERSION "v1.17b"
|
||||
#define DRV_RELDATE "2006/03/10"
|
||||
#include "dl2k.h"
|
||||
|
||||
static char version[] __devinitdata =
|
||||
|
@ -765,7 +765,7 @@ rio_free_tx (struct net_device *dev, int irq)
|
|||
break;
|
||||
skb = np->tx_skbuff[entry];
|
||||
pci_unmap_single (np->pdev,
|
||||
np->tx_ring[entry].fraginfo,
|
||||
np->tx_ring[entry].fraginfo & 0xffffffffffff,
|
||||
skb->len, PCI_DMA_TODEVICE);
|
||||
if (irq)
|
||||
dev_kfree_skb_irq (skb);
|
||||
|
@ -892,14 +892,16 @@ receive_packet (struct net_device *dev)
|
|||
|
||||
/* Small skbuffs for short packets */
|
||||
if (pkt_len > copy_thresh) {
|
||||
pci_unmap_single (np->pdev, desc->fraginfo,
|
||||
pci_unmap_single (np->pdev,
|
||||
desc->fraginfo & 0xffffffffffff,
|
||||
np->rx_buf_sz,
|
||||
PCI_DMA_FROMDEVICE);
|
||||
skb_put (skb = np->rx_skbuff[entry], pkt_len);
|
||||
np->rx_skbuff[entry] = NULL;
|
||||
} else if ((skb = dev_alloc_skb (pkt_len + 2)) != NULL) {
|
||||
pci_dma_sync_single_for_cpu(np->pdev,
|
||||
desc->fraginfo,
|
||||
desc->fraginfo &
|
||||
0xffffffffffff,
|
||||
np->rx_buf_sz,
|
||||
PCI_DMA_FROMDEVICE);
|
||||
skb->dev = dev;
|
||||
|
@ -910,7 +912,8 @@ receive_packet (struct net_device *dev)
|
|||
pkt_len, 0);
|
||||
skb_put (skb, pkt_len);
|
||||
pci_dma_sync_single_for_device(np->pdev,
|
||||
desc->fraginfo,
|
||||
desc->fraginfo &
|
||||
0xffffffffffff,
|
||||
np->rx_buf_sz,
|
||||
PCI_DMA_FROMDEVICE);
|
||||
}
|
||||
|
@ -1796,8 +1799,9 @@ rio_close (struct net_device *dev)
|
|||
np->rx_ring[i].fraginfo = 0;
|
||||
skb = np->rx_skbuff[i];
|
||||
if (skb) {
|
||||
pci_unmap_single (np->pdev, np->rx_ring[i].fraginfo,
|
||||
skb->len, PCI_DMA_FROMDEVICE);
|
||||
pci_unmap_single(np->pdev,
|
||||
np->rx_ring[i].fraginfo & 0xffffffffffff,
|
||||
skb->len, PCI_DMA_FROMDEVICE);
|
||||
dev_kfree_skb (skb);
|
||||
np->rx_skbuff[i] = NULL;
|
||||
}
|
||||
|
@ -1805,8 +1809,9 @@ rio_close (struct net_device *dev)
|
|||
for (i = 0; i < TX_RING_SIZE; i++) {
|
||||
skb = np->tx_skbuff[i];
|
||||
if (skb) {
|
||||
pci_unmap_single (np->pdev, np->tx_ring[i].fraginfo,
|
||||
skb->len, PCI_DMA_TODEVICE);
|
||||
pci_unmap_single(np->pdev,
|
||||
np->tx_ring[i].fraginfo & 0xffffffffffff,
|
||||
skb->len, PCI_DMA_TODEVICE);
|
||||
dev_kfree_skb (skb);
|
||||
np->tx_skbuff[i] = NULL;
|
||||
}
|
||||
|
|
|
@ -2917,7 +2917,7 @@ e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
|
|||
if (!__pskb_pull_tail(skb, pull_size)) {
|
||||
printk(KERN_ERR "__pskb_pull_tail failed.\n");
|
||||
dev_kfree_skb_any(skb);
|
||||
return -EFAULT;
|
||||
return NETDEV_TX_OK;
|
||||
}
|
||||
len = skb->len - skb->data_len;
|
||||
}
|
||||
|
|
|
@ -74,7 +74,7 @@
|
|||
#define TX_RING_SIZE 512
|
||||
#define TX_DEF_PENDING (TX_RING_SIZE - 1)
|
||||
#define TX_MIN_PENDING 64
|
||||
#define MAX_SKB_TX_LE (4 + 2*MAX_SKB_FRAGS)
|
||||
#define MAX_SKB_TX_LE (4 + (sizeof(dma_addr_t)/sizeof(u32))*MAX_SKB_FRAGS)
|
||||
|
||||
#define STATUS_RING_SIZE 2048 /* 2 ports * (TX + 2*RX) */
|
||||
#define STATUS_LE_BYTES (STATUS_RING_SIZE*sizeof(struct sky2_status_le))
|
||||
|
@ -622,8 +622,8 @@ static void sky2_mac_init(struct sky2_hw *hw, unsigned port)
|
|||
|
||||
/* Configure Rx MAC FIFO */
|
||||
sky2_write8(hw, SK_REG(port, RX_GMF_CTRL_T), GMF_RST_CLR);
|
||||
sky2_write16(hw, SK_REG(port, RX_GMF_CTRL_T),
|
||||
GMF_RX_CTRL_DEF);
|
||||
sky2_write32(hw, SK_REG(port, RX_GMF_CTRL_T),
|
||||
GMF_OPER_ON | GMF_RX_F_FL_ON);
|
||||
|
||||
/* Flush Rx MAC FIFO on any flow control or error */
|
||||
sky2_write16(hw, SK_REG(port, RX_GMF_FL_MSK), GMR_FS_ANY_ERR);
|
||||
|
@ -995,6 +995,10 @@ static int sky2_rx_start(struct sky2_port *sky2)
|
|||
sky2_rx_add(sky2, re->mapaddr);
|
||||
}
|
||||
|
||||
/* Truncate oversize frames */
|
||||
sky2_write16(hw, SK_REG(sky2->port, RX_GMF_TR_THR), sky2->rx_bufsize - 8);
|
||||
sky2_write32(hw, SK_REG(sky2->port, RX_GMF_CTRL_T), RX_TRUNC_ON);
|
||||
|
||||
/* Tell chip about available buffers */
|
||||
sky2_write16(hw, Y2_QADDR(rxq, PREF_UNIT_PUT_IDX), sky2->rx_put);
|
||||
sky2->rx_last_put = sky2_read16(hw, Y2_QADDR(rxq, PREF_UNIT_PUT_IDX));
|
||||
|
@ -1145,6 +1149,7 @@ static int sky2_xmit_frame(struct sk_buff *skb, struct net_device *dev)
|
|||
struct sky2_tx_le *le = NULL;
|
||||
struct tx_ring_info *re;
|
||||
unsigned i, len;
|
||||
int avail;
|
||||
dma_addr_t mapping;
|
||||
u32 addr64;
|
||||
u16 mss;
|
||||
|
@ -1287,12 +1292,16 @@ static int sky2_xmit_frame(struct sk_buff *skb, struct net_device *dev)
|
|||
re->idx = sky2->tx_prod;
|
||||
le->ctrl |= EOP;
|
||||
|
||||
avail = tx_avail(sky2);
|
||||
if (mss != 0 || avail < TX_MIN_PENDING) {
|
||||
le->ctrl |= FRC_STAT;
|
||||
if (avail <= MAX_SKB_TX_LE)
|
||||
netif_stop_queue(dev);
|
||||
}
|
||||
|
||||
sky2_put_idx(hw, txqaddr[sky2->port], sky2->tx_prod,
|
||||
&sky2->tx_last_put, TX_RING_SIZE);
|
||||
|
||||
if (tx_avail(sky2) <= MAX_SKB_TX_LE)
|
||||
netif_stop_queue(dev);
|
||||
|
||||
out_unlock:
|
||||
spin_unlock(&sky2->tx_lock);
|
||||
|
||||
|
@ -1707,10 +1716,12 @@ static void sky2_tx_timeout(struct net_device *dev)
|
|||
|
||||
|
||||
#define roundup(x, y) ((((x)+((y)-1))/(y))*(y))
|
||||
/* Want receive buffer size to be multiple of 64 bits, and incl room for vlan */
|
||||
/* Want receive buffer size to be multiple of 64 bits
|
||||
* and incl room for vlan and truncation
|
||||
*/
|
||||
static inline unsigned sky2_buf_size(int mtu)
|
||||
{
|
||||
return roundup(mtu + ETH_HLEN + 4, 8);
|
||||
return roundup(mtu + ETH_HLEN + VLAN_HLEN, 8) + 8;
|
||||
}
|
||||
|
||||
static int sky2_change_mtu(struct net_device *dev, int new_mtu)
|
||||
|
@ -1793,7 +1804,7 @@ static struct sk_buff *sky2_receive(struct sky2_port *sky2,
|
|||
if (!(status & GMR_FS_RX_OK))
|
||||
goto resubmit;
|
||||
|
||||
if ((status >> 16) != length || length > sky2->rx_bufsize)
|
||||
if (length > sky2->netdev->mtu + ETH_HLEN)
|
||||
goto oversize;
|
||||
|
||||
if (length < copybreak) {
|
||||
|
@ -3243,8 +3254,7 @@ static int __devinit sky2_probe(struct pci_dev *pdev,
|
|||
}
|
||||
}
|
||||
|
||||
err = request_irq(pdev->irq, sky2_intr, SA_SHIRQ | SA_SAMPLE_RANDOM,
|
||||
DRV_NAME, hw);
|
||||
err = request_irq(pdev->irq, sky2_intr, SA_SHIRQ, DRV_NAME, hw);
|
||||
if (err) {
|
||||
printk(KERN_ERR PFX "%s: cannot assign irq %d\n",
|
||||
pci_name(pdev), pdev->irq);
|
||||
|
|
|
@ -1362,7 +1362,6 @@ static int de_open (struct net_device *dev)
|
|||
{
|
||||
struct de_private *de = dev->priv;
|
||||
int rc;
|
||||
unsigned long flags;
|
||||
|
||||
if (netif_msg_ifup(de))
|
||||
printk(KERN_DEBUG "%s: enabling interface\n", dev->name);
|
||||
|
@ -1376,18 +1375,20 @@ static int de_open (struct net_device *dev)
|
|||
return rc;
|
||||
}
|
||||
|
||||
rc = de_init_hw(de);
|
||||
if (rc) {
|
||||
printk(KERN_ERR "%s: h/w init failure, err=%d\n",
|
||||
dev->name, rc);
|
||||
goto err_out_free;
|
||||
}
|
||||
dw32(IntrMask, 0);
|
||||
|
||||
rc = request_irq(dev->irq, de_interrupt, SA_SHIRQ, dev->name, dev);
|
||||
if (rc) {
|
||||
printk(KERN_ERR "%s: IRQ %d request failure, err=%d\n",
|
||||
dev->name, dev->irq, rc);
|
||||
goto err_out_hw;
|
||||
goto err_out_free;
|
||||
}
|
||||
|
||||
rc = de_init_hw(de);
|
||||
if (rc) {
|
||||
printk(KERN_ERR "%s: h/w init failure, err=%d\n",
|
||||
dev->name, rc);
|
||||
goto err_out_free_irq;
|
||||
}
|
||||
|
||||
netif_start_queue(dev);
|
||||
|
@ -1395,11 +1396,8 @@ static int de_open (struct net_device *dev)
|
|||
|
||||
return 0;
|
||||
|
||||
err_out_hw:
|
||||
spin_lock_irqsave(&de->lock, flags);
|
||||
de_stop_hw(de);
|
||||
spin_unlock_irqrestore(&de->lock, flags);
|
||||
|
||||
err_out_free_irq:
|
||||
free_irq(dev->irq, dev);
|
||||
err_out_free:
|
||||
de_free_rings(de);
|
||||
return rc;
|
||||
|
@ -1455,6 +1453,8 @@ static void de_tx_timeout (struct net_device *dev)
|
|||
synchronize_irq(dev->irq);
|
||||
de_clean_rings(de);
|
||||
|
||||
de_init_rings(de);
|
||||
|
||||
de_init_hw(de);
|
||||
|
||||
netif_wake_queue(dev);
|
||||
|
|
|
@ -435,11 +435,17 @@ static int sil24_softreset(struct ata_port *ap, int verbose,
|
|||
struct sil24_port_priv *pp = ap->private_data;
|
||||
struct sil24_prb *prb = &pp->cmd_block[0].ata.prb;
|
||||
dma_addr_t paddr = pp->cmd_block_dma;
|
||||
unsigned long timeout = jiffies + ATA_TMOUT_BOOT * HZ;
|
||||
u32 irq_enable, irq_stat;
|
||||
int cnt;
|
||||
|
||||
DPRINTK("ENTER\n");
|
||||
|
||||
if (!sata_dev_present(ap)) {
|
||||
DPRINTK("PHY reports no device\n");
|
||||
*class = ATA_DEV_NONE;
|
||||
goto out;
|
||||
}
|
||||
|
||||
/* temporarily turn off IRQs during SRST */
|
||||
irq_enable = readl(port + PORT_IRQ_ENABLE_SET);
|
||||
writel(irq_enable, port + PORT_IRQ_ENABLE_CLR);
|
||||
|
@ -455,7 +461,7 @@ static int sil24_softreset(struct ata_port *ap, int verbose,
|
|||
|
||||
writel((u32)paddr, port + PORT_CMD_ACTIVATE);
|
||||
|
||||
for (cnt = 0; cnt < 100; cnt++) {
|
||||
do {
|
||||
irq_stat = readl(port + PORT_IRQ_STAT);
|
||||
writel(irq_stat, port + PORT_IRQ_STAT); /* clear irq */
|
||||
|
||||
|
@ -463,24 +469,24 @@ static int sil24_softreset(struct ata_port *ap, int verbose,
|
|||
if (irq_stat & (PORT_IRQ_COMPLETE | PORT_IRQ_ERROR))
|
||||
break;
|
||||
|
||||
msleep(1);
|
||||
}
|
||||
msleep(100);
|
||||
} while (time_before(jiffies, timeout));
|
||||
|
||||
/* restore IRQs */
|
||||
writel(irq_enable, port + PORT_IRQ_ENABLE_SET);
|
||||
|
||||
if (sata_dev_present(ap)) {
|
||||
if (!(irq_stat & PORT_IRQ_COMPLETE)) {
|
||||
DPRINTK("EXIT, srst failed\n");
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
sil24_update_tf(ap);
|
||||
*class = ata_dev_classify(&pp->tf);
|
||||
if (!(irq_stat & PORT_IRQ_COMPLETE)) {
|
||||
DPRINTK("EXIT, srst failed\n");
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
sil24_update_tf(ap);
|
||||
*class = ata_dev_classify(&pp->tf);
|
||||
|
||||
if (*class == ATA_DEV_UNKNOWN)
|
||||
*class = ATA_DEV_NONE;
|
||||
|
||||
out:
|
||||
DPRINTK("EXIT, class=%u\n", *class);
|
||||
return 0;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue