Page MenuHomeFreeBSD

Resolve deadlock between epoch(9) and various network interface SX-locks
ClosedPublic

Authored by hselasky on Oct 22 2018, 11:36 AM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 15, 2:15 AM
Unknown Object (File)
Fri, Dec 27, 6:31 AM
Unknown Object (File)
Dec 6 2024, 1:20 PM
Unknown Object (File)
Oct 27 2024, 6:11 PM
Unknown Object (File)
Oct 18 2024, 8:11 PM
Unknown Object (File)
Oct 18 2024, 8:11 PM
Unknown Object (File)
Oct 18 2024, 8:11 PM
Unknown Object (File)
Oct 18 2024, 7:51 PM
Subscribers

Details

Summary

Resolve deadlock between epoch(9) and various network interface SX-locks, by not allowing to hold the epoch read lock over typical network interface driver IOCTL code paths. The remaining race for double free will be solved separately.

Not allowed behaviour for the network subsystem global epoch:
epoch_enter()
sx_xlock();
sx_xunlock();
epoch_exit();

Allowed behaviour for the network subsystems global epoch:
sx_xlock();
epoch_wait();
sx_xunlock();

MFC after: 1 week
Sponsored by: Mellanox Technologies

Test Plan
#!/usr/local/bin/bash
# Script to reproduce hang

for i in {1..255}
do
(ifconfig mce0.$i create; 
ifconfig mce0.$i inet 224.0.0.$i;
ifconfig mce0.$i destroy) &
done

Diff Detail

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