Apply big endian fixes submitted by Garrett D'Amore in PR kern/32032.

This commit is contained in:
tron 2005-11-10 10:00:19 +00:00
parent af56e26cc6
commit f55fe966f7

View File

@ -1,4 +1,4 @@
/* $NetBSD: if_axe.c,v 1.9 2005/05/30 04:21:39 christos Exp $ */
/* $NetBSD: if_axe.c,v 1.10 2005/11/10 10:00:19 tron Exp $ */
/*
* Copyright (c) 1997, 1998, 1999, 2000-2003
@ -73,7 +73,7 @@
*/
#include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: if_axe.c,v 1.9 2005/05/30 04:21:39 christos Exp $");
__KERNEL_RCSID(0, "$NetBSD: if_axe.c,v 1.10 2005/11/10 10:00:19 tron Exp $");
#if defined(__NetBSD__)
#include "opt_inet.h"
@ -286,7 +286,7 @@ axe_miibus_readreg(device_ptr_t dev, int phy, int reg)
if (val)
sc->axe_phyaddrs[0] = phy;
return (val);
return (le16toh(val));
}
Static void
@ -298,6 +298,7 @@ axe_miibus_writereg(device_ptr_t dev, int phy, int reg, int val)
if (sc->axe_dying)
return;
val = htole32(val);
axe_lock_mii(sc);
axe_cmd(sc, AXE_CMD_MII_OPMODE_SW, 0, 0, NULL);
err = axe_cmd(sc, AXE_CMD_MII_WRITE_REG, reg, phy, (void *)&val);
@ -379,6 +380,7 @@ axe_setmulti(struct axe_softc *sc)
ifp = GET_IFP(sc);
axe_cmd(sc, AXE_CMD_RXCTL_READ, 0, 0, (void *)&rxmode);
rxmode = le16toh(rxmode);
if (ifp->if_flags & IFF_ALLMULTI || ifp->if_flags & IFF_PROMISC) {
allmulti:
@ -1231,7 +1233,7 @@ axe_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data)
axe_cmd(sc, AXE_CMD_RXCTL_READ,
0, 0, (void *)&rxmode);
rxmode |= AXE_RXCMD_PROMISC;
rxmode = le16toh(rxmode) | AXE_RXCMD_PROMISC;
axe_cmd(sc, AXE_CMD_RXCTL_WRITE,
0, rxmode, NULL);
@ -1241,7 +1243,7 @@ axe_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data)
sc->axe_if_flags & IFF_PROMISC) {
axe_cmd(sc, AXE_CMD_RXCTL_READ,
0, 0, (void *)&rxmode);
rxmode &= ~AXE_RXCMD_PROMISC;
rxmode = le16toh(rxmode) & ~AXE_RXCMD_PROMISC;
axe_cmd(sc, AXE_CMD_RXCTL_WRITE,
0, rxmode, NULL);
axe_setmulti(sc);