mirror of
https://gitlab.isc.org/isc-projects/bind9
synced 2025-08-31 14:35:26 +00:00
The route socket and its storage was detached while still reading
The interfacemgr and the .route was being detached while the network manager had pending read from the socket. Instead of detaching from the socket, we need to cancel the read which in turn will detach the route socket and the associated interfacemgr.
This commit is contained in:
@@ -215,16 +215,9 @@ route_recv(isc_nmhandle_t *handle, isc_result_t eresult, isc_region_t *region,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (eresult == ISC_R_SHUTTINGDOWN) {
|
|
||||||
/*
|
|
||||||
* The mgr->route and mgr is detached in
|
|
||||||
* ns_interfacemgr_shutdown()
|
|
||||||
*/
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (eresult != ISC_R_SUCCESS) {
|
if (eresult != ISC_R_SUCCESS) {
|
||||||
if (eresult != ISC_R_CANCELED) {
|
if (eresult != ISC_R_CANCELED && eresult != ISC_R_SHUTTINGDOWN)
|
||||||
|
{
|
||||||
isc_log_write(IFMGR_COMMON_LOGARGS, ISC_LOG_ERROR,
|
isc_log_write(IFMGR_COMMON_LOGARGS, ISC_LOG_ERROR,
|
||||||
"automatic interface scanning "
|
"automatic interface scanning "
|
||||||
"terminated: %s",
|
"terminated: %s",
|
||||||
@@ -453,8 +446,7 @@ ns_interfacemgr_shutdown(ns_interfacemgr_t *mgr) {
|
|||||||
purge_old_interfaces(mgr);
|
purge_old_interfaces(mgr);
|
||||||
|
|
||||||
if (mgr->route != NULL) {
|
if (mgr->route != NULL) {
|
||||||
isc_nmhandle_detach(&mgr->route);
|
isc_nm_cancelread(mgr->route);
|
||||||
ns_interfacemgr_detach(&mgr);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user