Ok all, here's a patch that attempts to make the 3c523 driver work again in 2.4.1.  It 
includes the following changes:


- fix addresses with bus_to_virt
- reduce xmit buffers from 4 to 1 (puts driver in noop mode like ni52 driver)
- increase recv buffers from 6 to 9 (should help decrease dropped packets)
- add short delay to detect routine (makes cards detectable on fast machines)
- use eth_copy_and_sum for receiving packets

It passed basic stress testing with multiple, simultaneous ftp transfers.

Know bugs:

- Multicast still doesn't work at all (I have patches that seem to fix this but they 
have other problems)
- Still drops packets under heavy traffic (can be reduced further by lowering MTU on 
interface)
- Sometimes requires host to send a packet before it starts receiving (I can't 
reproduce this on my equipment anymore, but needs more testing)

Anyone with this card please test and report back.

Later,
Tom


--- 3c523.c.241 Fri Feb  2 21:09:20 2001
+++ 3c523.c     Sun Feb  4 21:02:18 2001
@@ -148,9 +148,9 @@

  #define RECV_BUFF_SIZE 1524   /* slightly oversized */
  #define XMIT_BUFF_SIZE 1524   /* slightly oversized */
-#define NUM_XMIT_BUFFS 4       /* config for both, 8K and 16K shmem */
-#define NUM_RECV_BUFFS_8  1    /* config for 8K shared mem */
-#define NUM_RECV_BUFFS_16 6    /* config for 16K shared mem */
+#define NUM_XMIT_BUFFS 1       /* config for both, 8K and 16K shmem */
+#define NUM_RECV_BUFFS_8  4    /* config for 8K shared mem */
+#define NUM_RECV_BUFFS_16 9    /* config for 16K shared mem */

  #if (NUM_XMIT_BUFFS == 1)
  #define NO_NOPCOMMANDS                /* only possible with NUM_XMIT_BUFFS=1 */
@@ -303,13 +303,13 @@
        char *iscp_addrs[2];
        int i = 0;

- 
p->base = where + size - 0x01000000;
- 
p->memtop = phys_to_virt(where) + size;
- 
p->scp = (struct scp_struct *)phys_to_virt(p->base + SCP_DEFAULT_ADDRESS);
+ 
p->base = (unsigned long) bus_to_virt((unsigned long)where) + size - 0x01000000;
+ 
p->memtop = bus_to_virt((unsigned long)where) + size;
+ 
p->scp = (struct scp_struct *)(p->base + SCP_DEFAULT_ADDRESS);
        memset((char *) p->scp, 0, sizeof(struct scp_struct));
        p->scp->sysbus = SYSBUSVAL;     /* 1 = 8Bit-Bus, 0 = 16 Bit */

- 
iscp_addrs[0] = phys_to_virt(where);
+ 
iscp_addrs[0] = bus_to_virt((unsigned long)where);
        iscp_addrs[1] = (char *) p->scp - sizeof(struct iscp_struct);

        for (i = 0; i < 2; i++) {
@@ -325,6 +325,7 @@

                /* apparently, you sometimes have to kick the 82586 twice... */
                elmc_id_attn586();
+ 
        DELAY(1);

                if (p->iscp->busy) {    /* i82586 clears 'busy' after successful init 
*/
         
        return 0;
@@ -344,8 +345,8 @@
        elmc_id_reset586();
        DELAY(2);

- 
p->scp = (struct scp_struct *) phys_to_virt(p->base + SCP_DEFAULT_ADDRESS);
- 
p->scb = (struct scb_struct *) phys_to_virt(dev->mem_start);
+ 
p->scp = (struct scp_struct *) (p->base + SCP_DEFAULT_ADDRESS);
+ 
p->scb = (struct scb_struct *) bus_to_virt(dev->mem_start);
        p->iscp = (struct iscp_struct *) ((char *) p->scp - sizeof(struct 
iscp_struct));

        memset((char *) p->iscp, 0, sizeof(struct iscp_struct));
@@ -518,7 +519,8 @@
        }
        dev->mem_end = dev->mem_start + size;   /* set mem_end showed by 'ifconfig' */

- 
((struct priv *) (dev->priv))->base = dev->mem_start + size - 0x01000000;
+ 
((struct priv *) (dev->priv))->memtop = bus_to_virt(dev->mem_start) + size;
+ 
((struct priv *) (dev->priv))->base = (unsigned long) bus_to_virt(dev->mem_start) + 
size - 0x01000000;
        alloc586(dev);

        elmc_id_reset586();     /* make sure it doesn't generate spurious ints */
@@ -944,7 +946,8 @@
         
                if (skb != NULL) {
         
                        skb->dev = dev;
         
                        skb_reserve(skb, 2);    /* 16 byte alignment */
- 
                                memcpy(skb_put(skb, totlen), (u8 
*)phys_to_virt(p->base) + (unsigned long) rbd->buffer, totlen);
+ 
                                skb_put(skb,totlen);
+ 
                                eth_copy_and_sum(skb, (char *) p->base+(unsigned long) 
rbd->buffer,totlen,0);
         
                        skb->protocol = eth_type_trans(skb, dev);
         
                        netif_rx(skb);
         
                        p->stats.rx_packets++;
@@ -1086,6 +1089,7 @@
  static int elmc_send_packet(struct sk_buff *skb, struct net_device *dev)
  {
        int len;
+ 
int i;
  #ifndef NO_NOPCOMMANDS
        int next_nop;
  #endif

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
Please read the FAQ at http://www.tux.org/lkml/

Reply via email to