summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2014-11-25 12:54:56 +0100
committerSebastian Huber <sebastian.huber@embedded-brains.de>2015-01-21 15:00:20 +0100
commit6a73f64fe2eed3aedee150e5422b2b8fc41af36b (patch)
tree82bd55b332c9d900f4fe0a9ce0fed53f5f549a67
parentif_cgem: Enable hardware checksum assist (diff)
downloadrtems-libbsd-6a73f64fe2eed3aedee150e5422b2b8fc41af36b.tar.bz2
if_cgem: Use rtems_bsd_get_mac_address()
-rw-r--r--freebsd/sys/dev/cadence/if_cgem.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/freebsd/sys/dev/cadence/if_cgem.c b/freebsd/sys/dev/cadence/if_cgem.c
index fb498502..27ce43d3 100644
--- a/freebsd/sys/dev/cadence/if_cgem.c
+++ b/freebsd/sys/dev/cadence/if_cgem.c
@@ -85,6 +85,7 @@ __FBSDID("$FreeBSD$");
#include <rtems/bsd/local/miibus_if.h>
#ifdef __rtems__
#pragma GCC diagnostic ignored "-Wpointer-sign"
+#include <rtems/bsd/bsd.h>
#endif /* __rtems__ */
#define IF_CGEM_NAME "cgem"
@@ -233,7 +234,9 @@ static void
cgem_get_mac(struct cgem_softc *sc, u_char eaddr[])
{
int i;
+#ifndef __rtems__
uint32_t rnd;
+#endif /* __rtems__ */
/* See if boot loader gave us a MAC address already. */
for (i = 0; i < 4; i++) {
@@ -252,6 +255,7 @@ cgem_get_mac(struct cgem_softc *sc, u_char eaddr[])
/* No MAC from boot loader? Assign a random one. */
if (i == 4) {
+#ifndef __rtems__
rnd = arc4random();
eaddr[0] = 'b';
@@ -260,6 +264,10 @@ cgem_get_mac(struct cgem_softc *sc, u_char eaddr[])
eaddr[3] = (rnd >> 16) & 0xff;
eaddr[4] = (rnd >> 8) & 0xff;
eaddr[5] = rnd & 0xff;
+#else /* __rtems__ */
+ rtems_bsd_get_mac_address(device_get_name(sc->dev),
+ device_get_unit(sc->dev), eaddr);
+#endif /* __rtems__ */
device_printf(sc->dev, "no mac address found, assigning "
"random: %02x:%02x:%02x:%02x:%02x:%02x\n",