Page MenuHomeFreeBSD

linsysfs(4): Refactor to avoid referencing an unstable interfaces
ClosedPublic

Authored by dchagin on Feb 26 2023, 9:44 AM.
Referenced Files
F133532883: D38790.id118168.diff
Sun, Oct 26, 11:30 AM
Unknown Object (File)
Sat, Oct 25, 5:26 AM
Unknown Object (File)
Fri, Oct 17, 7:58 PM
Unknown Object (File)
Thu, Oct 16, 4:34 AM
Unknown Object (File)
Sat, Oct 11, 1:50 AM
Unknown Object (File)
Sat, Oct 11, 1:50 AM
Unknown Object (File)
Sat, Oct 11, 1:50 AM
Unknown Object (File)
Sat, Oct 11, 1:50 AM
Subscribers

Details

Summary

Enter the net epoch when traversing a list of interfaces. For that
split the ifname_linux_to_bsd() function on two counterparts, where
the ifname_linux_to_ifp() intended to use in epoch, while the
ifname_linux_to_bsd() intended to be a self-contained.
Until the linux_ioctl_coket() function is refactored, the
ifname_linux_to_bsd() temporarily returns interface outside
of the epoch.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 50098
Build 46990: arc lint + arc unit

Event Timeline

melifaro added inline comments.
sys/compat/linsysfs/linsysfs.c
214

Maybe the other way round? In that case, you don't need to have an additional epoch exit.

215

Nit: IIRC sbuf_printf() cannot sleep, so it's worth writing ifindex inside the epoch and avoid using a temporary variable.

233

Nit: same as previous one: do everything inside ifp != NULL condition

This revision is now accepted and ready to land.Feb 27 2023, 11:24 AM

done, btw, you are right, sbuf here don't sleep,
also vnet context stored as V_ifnet is not iniitalized without it

This revision now requires review to proceed.Mar 2 2023, 9:20 AM
This revision was not accepted when it landed; it landed in state Needs Review.Mar 4 2023, 9:13 AM
This revision was automatically updated to reflect the committed changes.