diff options
author | gonzo <gonzo@FreeBSD.org> | 2009-05-16 02:45:38 +0000 |
---|---|---|
committer | gonzo <gonzo@FreeBSD.org> | 2009-05-16 02:45:38 +0000 |
commit | 3a3558a8c154dc7f3e8fb4b68af73cdb536367b2 (patch) | |
tree | 0d894b87ba778a29519bcfb047771d590952ac38 /sys | |
parent | 5e17e7a6de32c83239be92ae39b6000eb8a46f07 (diff) | |
download | FreeBSD-src-3a3558a8c154dc7f3e8fb4b68af73cdb536367b2.zip FreeBSD-src-3a3558a8c154dc7f3e8fb4b68af73cdb536367b2.tar.gz |
- Set MAC Address obtained from RedBoot or generate random one
Diffstat (limited to 'sys')
-rw-r--r-- | sys/mips/atheros/if_arge.c | 39 |
1 files changed, 32 insertions, 7 deletions
diff --git a/sys/mips/atheros/if_arge.c b/sys/mips/atheros/if_arge.c index a3f38e0..b3237c2 100644 --- a/sys/mips/atheros/if_arge.c +++ b/sys/mips/atheros/if_arge.c @@ -153,6 +153,13 @@ DRIVER_MODULE(arge, nexus, arge_driver, arge_devclass, 0, 0); DRIVER_MODULE(miibus, arge, miibus_driver, miibus_devclass, 0, 0); /* + * RedBoot passes MAC address to entry point as environment + * variable. platfrom_start parses it and stores in this variable + */ +extern uint32_t ar711_base_mac[ETHER_ADDR_LEN]; + + +/* * Flushes all */ static void @@ -183,7 +190,8 @@ arge_attach(device_t dev) struct ifnet *ifp; struct arge_softc *sc; int error = 0, rid, phynum; - uint32_t reg; + uint32_t reg, rnd; + int is_base_mac_empty, i; sc = device_get_softc(dev); sc->arge_dev = dev; @@ -269,12 +277,29 @@ arge_attach(device_t dev) ifp->if_capenable = ifp->if_capabilities; - eaddr[0] = 0x00; - eaddr[1] = 0x15; - eaddr[2] = 0x6d; - eaddr[3] = 0xc1; - eaddr[4] = 0x28; - eaddr[5] = 0x2e; + is_base_mac_empty = 1; + for (i = 0; i < ETHER_ADDR_LEN; i++) { + eaddr[i] = ar711_base_mac[i] & 0xff; + if (eaddr[i] != 0) + is_base_mac_empty = 0; + } + + if (is_base_mac_empty) { + /* + * No MAC address configured. Generate the random one. + */ + if (bootverbose) + device_printf(dev, + "Generating random ethernet address.\n"); + + rnd = arc4random(); + eaddr[0] = 'b'; + eaddr[1] = 's'; + eaddr[2] = 'd'; + eaddr[3] = (rnd >> 24) & 0xff; + eaddr[4] = (rnd >> 16) & 0xff; + eaddr[5] = (rnd >> 8) & 0xff; + } if (arge_dma_alloc(sc) != 0) { error = ENXIO; |