diff options
author | Jason Wright <jason@cvs.openbsd.org> | 2001-09-21 22:27:52 +0000 |
---|---|---|
committer | Jason Wright <jason@cvs.openbsd.org> | 2001-09-21 22:27:52 +0000 |
commit | 9459e619f641024805754d7a4fd97c957dd94d9c (patch) | |
tree | 423c238e4145aa3790456988007f00cc1778b612 /sys/dev/ic/gem.c | |
parent | 93a20176a35412fbb7d9edac93b84eac4b9bf59c (diff) |
configured mtu in BOTH places (grumble)
Also, make it a bit higher than normal (this is an ugly hack and will be
removed when I figure out what this thing wants).
Diffstat (limited to 'sys/dev/ic/gem.c')
-rw-r--r-- | sys/dev/ic/gem.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/sys/dev/ic/gem.c b/sys/dev/ic/gem.c index 6d5cd368204..1291126b92f 100644 --- a/sys/dev/ic/gem.c +++ b/sys/dev/ic/gem.c @@ -748,7 +748,7 @@ if (gem_opdebug) printf("in init\n"); /* step 4. TX MAC registers & counters */ gem_init_regs(sc); - v = ETHERMTU + sizeof(struct ether_header) + + v = ETHERMTU + sizeof(struct ether_header) + 50 + #if NVLAN > 0 EVL_ENCAPLEN + #endif @@ -876,9 +876,9 @@ ether_cmp(a, b) void gem_init_regs(struct gem_softc *sc) { - struct ifnet *ifp = &sc->sc_arpcom.ac_if; bus_space_tag_t t = sc->sc_bustag; bus_space_handle_t h = sc->sc_h; + u_int32_t v; /* These regs are not cleared on reset */ sc->sc_inited = 0; @@ -891,8 +891,12 @@ gem_init_regs(struct gem_softc *sc) bus_space_write_4(t, h, GEM_MAC_MAC_MIN_FRAME, ETHER_MIN_LEN); /* Max frame and max burst size */ - bus_space_write_4(t, h, GEM_MAC_MAC_MAX_FRAME, - (ifp->if_mtu+18) | (0x2000<<16)/* Burst size */); + v = ((ETHERMTU + sizeof(struct ether_header) + 50 + +#if NVLAN > 0 + EVL_ENCAPLEN + +#endif + 0) | (0x2000<<16) /* Burst size */); + bus_space_write_4(t, h, GEM_MAC_MAC_MAX_FRAME, v); bus_space_write_4(t, h, GEM_MAC_PREAMBLE_LEN, 0x7); bus_space_write_4(t, h, GEM_MAC_JAM_SIZE, 0x4); bus_space_write_4(t, h, GEM_MAC_ATTEMPT_LIMIT, 0x10); |