lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [day] [month] [year] [list]
Message-ID: <4818BCF1.9030100@hotmail.com>
Date:	Wed, 30 Apr 2008 19:39:45 +0100
From:	Bruce Robson <bns_robson@...mail.com>
To:	Philip Blundell <philb@....org>, netdev@...r.kernel.org
Subject: [PATCH] drivers/net  EtherExpress 16 : IPv6 not working with this
 driver

From: Bruce Robson <bns_robson@...mail.com>

Corrects loading of multi-cast addresses.
Thereby allowing IPv6 neighbour discovery to work.

Signed-off-by: Bruce Robson <bns_robson@...mail.com>

---

The driver sources file eexpress.c contains an approximately 30 line
function eexp_setup_filter used when loading multicast addresses.
There were 3 problems in this function
1)  It wrote the number of multicast addresses to the card instead
    of the number of bytes in the multicast addresses.
2)  When loading multiple multicast addresses it loaded the first
    one provided multiple times instead of loading each one once.
3)  The setting of pointer 'data' from 'dmi->dmi_addr' occured before
    the test for the error situation of 'dmi' being NULL.

There is some information on the Intel EtherExpress 16 at
http://www.intel.com/support/etherexpress/vintage/sb/cs-013500.htm
Datasheet for the Intel 82586 ethernet controller used by the card
http://www.datasheetcatalog.com/datasheets_pdf/8/2/5/8/82586.shtml


--- drivers/net/eexpress.c.000	2008-01-24 22:58:37.000000000 +0000
+++ drivers/net/eexpress.c	2008-04-30 00:17:51.000000000 +0100
@@ -201,9 +201,9 @@ static unsigned short start_code[] = {
 
 	0x0000,Cmd_MCast,
 	0x0076,                 /* link to next command */
 #define CONF_NR_MULTICAST 0x44
-	0x0000,                 /* number of multicast addresses */
+	0x0000,                 /* number of bytes in multicast address(es) */
 #define CONF_MULTICAST 0x46
 	0x0000, 0x0000, 0x0000, /* some addresses */
 	0x0000, 0x0000, 0x0000,
 	0x0000, 0x0000, 0x0000,
@@ -1568,9 +1568,9 @@ static void eexp_hw_init586(struct net_d
 }
 
 static void eexp_setup_filter(struct net_device *dev)
 {
-	struct dev_mc_list *dmi = dev->mc_list;
+	struct dev_mc_list *dmi;
 	unsigned short ioaddr = dev->base_addr;
 	int count = dev->mc_count;
 	int i;
 	if (count > 8) {
@@ -1579,19 +1579,20 @@ static void eexp_setup_filter(struct net
 		count = 8;
 	}
 
 	outw(CONF_NR_MULTICAST & ~31, ioaddr+SM_PTR);
-	outw(count, ioaddr+SHADOW(CONF_NR_MULTICAST));
-	for (i = 0; i < count; i++) {
-		unsigned short *data = (unsigned short *)dmi->dmi_addr;
+	outw(6*count, ioaddr+SHADOW(CONF_NR_MULTICAST));
+	for (i = 0, dmi = dev->mc_list; i < count; i++, dmi = dmi->next) {
+		unsigned short *data;
 		if (!dmi) {
 			printk(KERN_INFO "%s: too few multicast addresses\n", dev->name);
 			break;
 		}
 		if (dmi->dmi_addrlen != ETH_ALEN) {
 			printk(KERN_INFO "%s: invalid multicast address length given.\n", dev->name);
 			continue;
 		}
+		data = (unsigned short *)dmi->dmi_addr;
 		outw((CONF_MULTICAST+(6*i)) & ~31, ioaddr+SM_PTR);
 		outw(data[0], ioaddr+SHADOW(CONF_MULTICAST+(6*i)));
 		outw((CONF_MULTICAST+(6*i)+2) & ~31, ioaddr+SM_PTR);
 		outw(data[1], ioaddr+SHADOW(CONF_MULTICAST+(6*i)+2));
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ