Page MenuHomeFreeBSD

iflib: netmap: fix rsync index overrun
ClosedPublic

Authored by vmaffione on Jun 13 2020, 7:50 AM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Oct 30, 12:36 PM
Unknown Object (File)
Thu, Oct 24, 4:25 AM
Unknown Object (File)
Thu, Oct 24, 4:25 AM
Unknown Object (File)
Thu, Oct 24, 4:25 AM
Unknown Object (File)
Thu, Oct 24, 4:07 AM
Unknown Object (File)
Wed, Oct 23, 8:44 PM
Unknown Object (File)
Oct 5 2024, 5:55 AM
Unknown Object (File)
Sep 21 2024, 4:36 PM

Details

Summary

In the current iflib_netmap_rxsync, there is nothing that prevents kring->nr_hwtail to overrun kring->nr_hwcur during the descriptor import phase. This may cause errors in netmap applications, such as:

em1 RX0: fail 'head < kring->nr_hwcur || head > kring->nr_hwtail' h 795 c 795 t 282 rh 795 rc 795 rt 282 hc 282 ht 282
Test Plan

Tested on an em device in a VM. After the patch, the problem disappears.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

I guess no objections here? This is an easy change, that fixes a bug that is very easy to reproduce, and that prevents netmap applications from working for real on iflib.

This revision is now accepted and ready to land.Jun 23 2020, 3:00 PM
This revision was automatically updated to reflect the committed changes.