Update from Stephan Wilms <Stephan.Wilms@CWA.de> that adds autodetection.

What I implemented in this new driver version is, that the driver will
first probe for a DEC21140 card and use it if found. If not found it
will probe for a DEC21143 card and use that if found. This removes the
need for defining/undefining a macro (as was required with my previous
version). I tested the driver with my 21143 card using netdemo and it
apears to work just fine.

Here are some cases that I did not test, mainly because I do not have
the required testing hardware:
   - I did not enhance or test PPC support
   - I did not test DEC21140 support
   - I did not use other test software than netdemo
This commit is contained in:
Joel Sherrill
2000-05-25 13:42:00 +00:00
parent 64bddf48af
commit c94c2518de

View File

@@ -12,17 +12,18 @@
* ------------------------------------------------------------------------ * ------------------------------------------------------------------------
* [22.05.2000,StWi/CWA] added support for the DEC/Intel 21143 chip * [22.05.2000,StWi/CWA] added support for the DEC/Intel 21143 chip
* *
* This support is (for now) only available for the __i386 target, because * The 21143 support is (for now) only available for the __i386 target,
* that's the only testing platform I have. It should to my best knowledge * because that's the only testing platform I have. It should (to my best
* work in the same way for the "__PPC" target, but someone should test * knowledge) work in the same way for the "__PPC" target, but someone
* this first before it's put into the code. Thanks go to Andrew Klossner * should test this first before it's put into the code. Thanks go to
* who provided the vital information about the Intel 21143 chip. * Andrew Klossner who provided the vital information about the
* Intel 21143 chip.
* (FWIW: I tested this driver using a Kingston KNE100TX with 21143PD chip)
* *
* (FWIW: my network card is a Kingston KNE100TX with 21143PD chip) * The driver will automatically detect whether there is a 21140 or 21143
* * network card in the system and activate support accordingly. It will
* The 21143 support is enabled by defining the macro * look for the 21140 first. If the 21140 is not found the driver will
* "ENABLE_21143_VARIANT" (see the "#if defined(__i386)" section right * look for the 21143.
* below, just add or remove comments as needed)
* ------------------------------------------------------------------------ * ------------------------------------------------------------------------
*/ */
@@ -36,7 +37,6 @@
#if defined(__i386) #if defined(__i386)
#define DEC21140_SUPPORTED #define DEC21140_SUPPORTED
#define ENABLE_21143_VARIANT
#endif #endif
#if defined(__PPC) && (defined(mpc604) || defined(mpc750)) #if defined(__PPC) && (defined(mpc604) || defined(mpc750))
@@ -87,13 +87,11 @@
#define DEC_DEBUG #define DEC_DEBUG
/* note: the 21143 isn't really a DEC, it's an Intel chip */
#define PCI_INVALID_VENDORDEVICEID 0xffffffff #define PCI_INVALID_VENDORDEVICEID 0xffffffff
#define PCI_VENDOR_ID_DEC 0x1011 #define PCI_VENDOR_ID_DEC 0x1011
#if defined(ENABLE_21143_VARIANT) #define PCI_DEVICE_ID_DEC_21140 0x0009
#define PCI_DEVICE_ID_DEC_TULIP_FAST 0x0019 #define PCI_DEVICE_ID_DEC_21143 0x0019
#else
#define PCI_DEVICE_ID_DEC_TULIP_FAST 0x0009
#endif
#define IO_MASK 0x3 #define IO_MASK 0x3
#define MEM_MASK 0xF #define MEM_MASK 0xF
@@ -385,7 +383,7 @@ dec21140Enet_initialize_hardware (struct dec21140_softc *sc)
st_le32( (tbase+memCSR0), CSR0_MODE); st_le32( (tbase+memCSR0), CSR0_MODE);
#ifdef DEC_DEBUG #ifdef DEC_DEBUG
printk("DC21140 %x:%x:%x:%x:%x:%x IRQ %d IO %x M %x .........\n", printk("DC2114x %x:%x:%x:%x:%x:%x IRQ %d IO %x M %x .........\n",
sc->arpcom.ac_enaddr[0], sc->arpcom.ac_enaddr[1], sc->arpcom.ac_enaddr[0], sc->arpcom.ac_enaddr[1],
sc->arpcom.ac_enaddr[2], sc->arpcom.ac_enaddr[3], sc->arpcom.ac_enaddr[2], sc->arpcom.ac_enaddr[3],
sc->arpcom.ac_enaddr[4], sc->arpcom.ac_enaddr[5], sc->arpcom.ac_enaddr[4], sc->arpcom.ac_enaddr[5],
@@ -778,6 +776,7 @@ rtems_dec21140_driver_attach (struct rtems_bsdnet_ifconfig *config)
struct ifnet *ifp; struct ifnet *ifp;
int mtu; int mtu;
int i; int i;
int deviceId = PCI_DEVICE_ID_DEC_21140; /* network card device ID */
/* /*
* First, find a DEC board * First, find a DEC board
@@ -792,16 +791,24 @@ rtems_dec21140_driver_attach (struct rtems_bsdnet_ifconfig *config)
rtems_panic("PCI BIOS not found !!"); rtems_panic("PCI BIOS not found !!");
/* /*
* First, find a DEC board * Try to find the network card on the PCI bus. Probe for a DEC 21140
* card first. If not found probe the bus for a DEC/Intel 21143 card.
*/ */
if ((diag = pcib_find_by_devid(PCI_VENDOR_ID_DEC, deviceId = PCI_DEVICE_ID_DEC_21140;
PCI_DEVICE_ID_DEC_TULIP_FAST, diag = pcib_find_by_devid( PCI_VENDOR_ID_DEC, deviceId,
0, 0, &signature);
&signature)) != PCIB_ERR_SUCCESS) if ( diag == PCIB_ERR_SUCCESS)
rtems_panic("DEC PCI board not found !! (%d)\n", diag); printk( "DEC 21140 PCI network card found\n" );
else { else
printk("DEC PCI Device found\n"); {
} deviceId = PCI_DEVICE_ID_DEC_21143;
diag = pcib_find_by_devid( PCI_VENDOR_ID_DEC, deviceId,
0, &signature);
if ( diag == PCIB_ERR_SUCCESS)
printk( "DEC/Intel 21143 PCI network card found\n" );
else
rtems_panic("DEC PCI network card not found !!\n");
}
#endif #endif
#if defined(__PPC) #if defined(__PPC)
unsigned char ucSlotNumber, ucFnNumber; unsigned char ucSlotNumber, ucFnNumber;
@@ -821,10 +828,10 @@ rtems_dec21140_driver_attach (struct rtems_bsdnet_ifconfig *config)
*/ */
continue; continue;
} }
if (ulDeviceID == ((PCI_DEVICE_ID_DEC_TULIP_FAST<<16) + PCI_VENDOR_ID_DEC)) if (ulDeviceID == ((PCI_DEVICE_ID_DEC_21140<<16) + PCI_VENDOR_ID_DEC))
break; break;
} }
if (ulDeviceID == ((PCI_DEVICE_ID_DEC_TULIP_FAST<<16) + PCI_VENDOR_ID_DEC)){ if (ulDeviceID == ((PCI_DEVICE_ID_DEC_21140<<16) + PCI_VENDOR_ID_DEC)){
printk("DEC Adapter found !!\n"); printk("DEC Adapter found !!\n");
break; break;
} }
@@ -852,10 +859,9 @@ rtems_dec21140_driver_attach (struct rtems_bsdnet_ifconfig *config)
*/ */
#if defined(__i386) #if defined(__i386)
#if defined(ENABLE_21143_VARIANT) /* the 21143 chip must be enabled before it can be accessed */
/* the 21143 chip must be enabled before it can be accessed */ if ( deviceId == PCI_DEVICE_ID_DEC_21143 )
pcib_conf_write32( signature, 0x40, 0 ); pcib_conf_write32( signature, 0x40, 0 );
#endif
pcib_conf_read32(signature, 16, &value); pcib_conf_read32(signature, 16, &value);
sc->port = value & ~IO_MASK; sc->port = value & ~IO_MASK;
@@ -949,7 +955,7 @@ rtems_dec21140_driver_attach (struct rtems_bsdnet_ifconfig *config)
if_attach (ifp); if_attach (ifp);
ether_ifattach (ifp); ether_ifattach (ifp);
printk( "DEC21140 : driver has been attached\n" ); printk( "DC2114x : driver has been attached\n" );
return 1; return 1;
}; };
#endif /* DEC21140_SUPPORTED */ #endif /* DEC21140_SUPPORTED */