View | Details | Raw Unified | Return to bug 274092 | Differences between
and this patch

Collapse All | Expand All

(-)b/sys/dev/usb/net/if_smsc.c (+73 lines)
Lines 179-184 static const struct usb_device_id smsc_devs[] = { Link Here
179
#define ETHER_IS_VALID(addr) \
179
#define ETHER_IS_VALID(addr) \
180
	(!ETHER_IS_MULTICAST(addr) && !ETHER_IS_ZERO(addr))
180
	(!ETHER_IS_MULTICAST(addr) && !ETHER_IS_ZERO(addr))
181
181
182
#define BOOTARGS_SMSC95XX	"smsc95xx.macaddr"
183
182
static device_probe_t smsc_probe;
184
static device_probe_t smsc_probe;
183
static device_attach_t smsc_attach;
185
static device_attach_t smsc_attach;
184
static device_detach_t smsc_detach;
186
static device_detach_t smsc_detach;
Lines 1538-1543 smsc_ioctl(if_t ifp, u_long cmd, caddr_t data) Link Here
1538
	return (rc);
1540
	return (rc);
1539
}
1541
}
1540
1542
1543
static bool
1544
smsc_get_smsc95xx_macaddr(device_t dev, char* bootargs, size_t bootargs_len, struct usb_ether *ue)
1545
{
1546
	int values[6];
1547
	int i;
1548
	char* p;
1549
1550
	device_printf(dev, "sizeof(*bootargs)=%lu %lu\n", bootargs_len, strnlen(bootargs, bootargs_len));
1551
	p = strnstr(bootargs, BOOTARGS_SMSC95XX, bootargs_len);
1552
	device_printf(dev, "mac1=%s. %lu\n", p, strlen(BOOTARGS_SMSC95XX));
1553
1554
	if (6 != sscanf(p, BOOTARGS_SMSC95XX "=%x:%x:%x:%x:%x:%x%*c",
1555
			&values[0], &values[1], &values[2],
1556
			&values[3], &values[4], &values[5])) {
1557
		device_printf(dev, "invalid mac from bootargs '%s'.\n", p);
1558
		return false;
1559
	}
1560
1561
	for (i = 0; i < ETHER_ADDR_LEN; ++i)
1562
		ue->ue_eaddr[i] = values[i];
1563
1564
	printf("mac=%x:%x:%x:%x:%x:%x.\n",
1565
		ue->ue_eaddr[0], ue->ue_eaddr[1], ue->ue_eaddr[2],
1566
		ue->ue_eaddr[3], ue->ue_eaddr[4], ue->ue_eaddr[5]);
1567
	return true;
1568
}
1569
1570
/**
1571
 * Raspberry Pi is known to pass smsc95xx.macaddr=XX:XX:XX:XX:XX:XX via bootargs.
1572
 */
1573
static int
1574
smsc_bootargs_get_mac_addr(device_t dev, struct usb_ether *ue) {
1575
	char bootargs[2048];         /* early stack supposedly big enough */
1576
	phandle_t node;
1577
1578
	/* only use bootargs for the first device to prevent duplicate mac addresses */
1579
	device_printf(dev, "unit=%d\n", device_get_unit(dev));
1580
	if (device_get_unit(dev) != 0)
1581
		return 1;
1582
	node = OF_finddevice("/chosen");
1583
	if (node == -1)
1584
		return 1;
1585
	device_printf(dev, "/chosen found\n");
1586
	if (OF_getproplen(node, "bootargs") > sizeof(bootargs)) {
1587
		device_printf(dev, "bootargs too large for buffer");
1588
		return 1;
1589
	}
1590
	if (OF_getprop(node, "bootargs", bootargs, sizeof(bootargs)) == -1)
1591
		return 1;
1592
	device_printf(dev, "bootargs: %s.\n", bootargs);
1593
	if (!smsc_get_smsc95xx_macaddr(dev, bootargs, sizeof(bootargs), ue))
1594
		return 1;
1595
	device_printf(dev, "Ethernet address found in bootargs %x:%x:%x:%x:%x:%x.\n",
1596
			ue->ue_eaddr[0], ue->ue_eaddr[1], ue->ue_eaddr[2],
1597
			ue->ue_eaddr[3], ue->ue_eaddr[4], ue->ue_eaddr[5]);
1598
	return 0;
1599
}
1600
1541
/**
1601
/**
1542
 *	smsc_attach_post - Called after the driver attached to the USB interface
1602
 *	smsc_attach_post - Called after the driver attached to the USB interface
1543
 *	@ue: the USB ethernet device
1603
 *	@ue: the USB ethernet device
Lines 1586-1595 smsc_attach_post(struct usb_ether *ue) Link Here
1586
		if ((err != 0) || (!ETHER_IS_VALID(sc->sc_ue.ue_eaddr)))
1646
		if ((err != 0) || (!ETHER_IS_VALID(sc->sc_ue.ue_eaddr)))
1587
			err = usb_fdt_get_mac_addr(sc->sc_ue.ue_dev, &sc->sc_ue);
1647
			err = usb_fdt_get_mac_addr(sc->sc_ue.ue_dev, &sc->sc_ue);
1588
#endif
1648
#endif
1649
#if 1
1589
		if ((err != 0) || (!ETHER_IS_VALID(sc->sc_ue.ue_eaddr))) {
1650
		if ((err != 0) || (!ETHER_IS_VALID(sc->sc_ue.ue_eaddr))) {
1651
			err = smsc_bootargs_get_mac_addr(sc->sc_ue.ue_dev, &sc->sc_ue);
1652
		}
1653
#endif
1654
		if ((err != 0) || (!ETHER_IS_VALID(sc->sc_ue.ue_eaddr))) {
1655
#if 1
1590
			read_random(sc->sc_ue.ue_eaddr, ETHER_ADDR_LEN);
1656
			read_random(sc->sc_ue.ue_eaddr, ETHER_ADDR_LEN);
1591
			sc->sc_ue.ue_eaddr[0] &= ~0x01;     /* unicast */
1657
			sc->sc_ue.ue_eaddr[0] &= ~0x01;     /* unicast */
1592
			sc->sc_ue.ue_eaddr[0] |=  0x02;     /* locally administered */
1658
			sc->sc_ue.ue_eaddr[0] |=  0x02;     /* locally administered */
1659
#else
1660
			struct ether_addr eaddr;
1661
			device_printf(ue->ue_dev, "No MAC address found. Using ether_gen_addr(). %p\n", ue->ue_ifp);
1662
			ether_gen_addr(ue->ue_ifp, &eaddr);
1663
			for (int i = 0; i < ETHER_ADDR_LEN; i++)
1664
				sc->sc_ue.ue_eaddr[i] = eaddr.octet[i];
1665
#endif
1593
		}
1666
		}
1594
	}
1667
	}
1595
1668
(-)b/sys/net/if_ethersubr.c (+4 lines)
Lines 1499-1504 ether_gen_addr(struct ifnet *ifp, struct ether_addr *hwaddr) Link Here
1499
	char digest[SHA1_RESULTLEN];
1499
	char digest[SHA1_RESULTLEN];
1500
	char jailname[MAXHOSTNAMELEN];
1500
	char jailname[MAXHOSTNAMELEN];
1501
1501
1502
if_printf(ifp, "getcredhostuuid %s\n", __FILE__);
1502
	getcredhostuuid(curthread->td_ucred, uuid, sizeof(uuid));
1503
	getcredhostuuid(curthread->td_ucred, uuid, sizeof(uuid));
1503
	if (strncmp(uuid, DEFAULT_HOSTUUID, sizeof(uuid)) == 0) {
1504
	if (strncmp(uuid, DEFAULT_HOSTUUID, sizeof(uuid)) == 0) {
1504
		/* Fall back to a random mac address. */
1505
		/* Fall back to a random mac address. */
Lines 1507-1512 ether_gen_addr(struct ifnet *ifp, struct ether_addr *hwaddr) Link Here
1507
1508
1508
	/* If each (vnet) jail would also have a unique hostuuid this would not
1509
	/* If each (vnet) jail would also have a unique hostuuid this would not
1509
	 * be necessary. */
1510
	 * be necessary. */
1511
if_printf(ifp, "getjailname %s\n", __FILE__);
1510
	getjailname(curthread->td_ucred, jailname, sizeof(jailname));
1512
	getjailname(curthread->td_ucred, jailname, sizeof(jailname));
1511
	sz = asprintf(&buf, M_TEMP, "%s-%s-%s", uuid, if_name(ifp),
1513
	sz = asprintf(&buf, M_TEMP, "%s-%s-%s", uuid, if_name(ifp),
1512
	    jailname);
1514
	    jailname);
Lines 1515-1520 ether_gen_addr(struct ifnet *ifp, struct ether_addr *hwaddr) Link Here
1515
		goto rando;
1517
		goto rando;
1516
	}
1518
	}
1517
1519
1520
if_printf(ifp, "SHA1 %s\n", __FILE__);
1518
	SHA1Init(&ctx);
1521
	SHA1Init(&ctx);
1519
	SHA1Update(&ctx, buf, sz);
1522
	SHA1Update(&ctx, buf, sz);
1520
	SHA1Final(digest, &ctx);
1523
	SHA1Final(digest, &ctx);
Lines 1530-1535 ether_gen_addr(struct ifnet *ifp, struct ether_addr *hwaddr) Link Here
1530
1533
1531
	return;
1534
	return;
1532
rando:
1535
rando:
1536
if_printf(ifp, "arc4rand %s\n", __FILE__);
1533
	arc4rand(hwaddr, sizeof(*hwaddr), 0);
1537
	arc4rand(hwaddr, sizeof(*hwaddr), 0);
1534
	/* Unicast */
1538
	/* Unicast */
1535
	hwaddr->octet[0] &= 0xFE;
1539
	hwaddr->octet[0] &= 0xFE;

Return to bug 274092