aboutsummaryrefslogtreecommitdiff
path: root/sys/net/iflib.c
diff options
context:
space:
mode:
authorPatrick Kelsey <pkelsey@FreeBSD.org>2020-03-14 19:43:44 +0000
committerPatrick Kelsey <pkelsey@FreeBSD.org>2020-03-14 19:43:44 +0000
commit9e9b738ac5dc5b5bca1a4de3b03fd4d072261adc (patch)
treea70d27bd3529cf0616deb84d6ee525b24f409466 /sys/net/iflib.c
parent30b5d9be24ec13157d18ae9bf01ef964f8187998 (diff)
downloadsrc-9e9b738ac5dc5b5bca1a4de3b03fd4d072261adc.tar.gz
src-9e9b738ac5dc5b5bca1a4de3b03fd4d072261adc.zip
Fix iflib freelist state corruption
This fixes a bug in iflib freelist management that breaks the required correspondence between freelist indexes and driver ring slots. PR: 243126, 243392, 240628 Reported by: avg, alexandr.oleynikov@gmail.com, Harald Schmalzbauer Reviewed by: avg, gallatin MFC after: 1 week Differential Revision: https://reviews.freebsd.org/D23943
Notes
Notes: svn path=/head/; revision=358995
Diffstat (limited to 'sys/net/iflib.c')
-rw-r--r--sys/net/iflib.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/sys/net/iflib.c b/sys/net/iflib.c
index 30c09a7d43ad..86149ee18089 100644
--- a/sys/net/iflib.c
+++ b/sys/net/iflib.c
@@ -2072,7 +2072,9 @@ _iflib_fl_refill(if_ctx_t ctx, iflib_fl_t fl, int count)
bus_dmamap_sync(fl->ifl_ifdi->idi_tag, fl->ifl_ifdi->idi_map,
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
ctx->isc_rxd_flush(ctx->ifc_softc, fl->ifl_rxq->ifr_id, fl->ifl_id, pidx);
- fl->ifl_fragidx = frag_idx;
+ fl->ifl_fragidx = frag_idx + 1;
+ if (fl->ifl_fragidx == fl->ifl_size)
+ fl->ifl_fragidx = 0;
return (n == -1 ? 0 : IFLIB_RXEOF_EMPTY);
}