Page MenuHomeFreeBSD

igb(4): Fix out-of-bounds register access on VFs
ClosedPublic

Authored by kgalazka on Oct 8 2025, 8:10 AM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 16, 9:31 PM
Unknown Object (File)
Wed, Jan 14, 1:09 PM
Unknown Object (File)
Mon, Jan 12, 2:36 PM
Unknown Object (File)
Mon, Jan 12, 2:36 PM
Unknown Object (File)
Tue, Dec 30, 4:32 AM
Unknown Object (File)
Sat, Dec 20, 5:34 AM
Unknown Object (File)
Dec 11 2025, 11:15 PM
Unknown Object (File)
Nov 29 2025, 11:09 PM

Details

Summary

Virtual Functions have access to a limited number of registers,
and their bus space size is lower. Use KASSERT to detect out-of-bounds
access and eliminate them to avoid kernel panics in production
environment.

Signed-off-by: Krzysztof Galazka <krzysztof.galazka@intel.com>

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

Wake-on-Lan configuration is not available for VFs.

sys/dev/e1000/if_em.c
1585

I wish these checks against !sc->vf_ifp were replaced with something like a E1000_IS_VF() macro, but is that what that check is for?

4382

Interesting...?

green light from validation point of view

This revision is now accepted and ready to land.Oct 23 2025, 10:46 AM
sys/dev/e1000/if_em.c
1585

Yeah, I was thinking about some refactoring, but I would prefer to do it as separate patch if you don't mind.

erj added inline comments.
sys/dev/e1000/if_em.c
1585

Sure.