mirror of
https://gitlab.isc.org/isc-projects/bind9
synced 2025-09-09 19:15:26 +00:00
With taskmgr running on top of netmgr, the ordering of how the tasks and netmgr shutdown interacts was wrong as previously isc_taskmgr_destroy() was waiting until all tasks were properly shutdown and detached. This responsibility was moved to netmgr, so we now need to do the following: 1. shutdown all the tasks - this schedules all shutdown events onto the netmgr queue 2. shutdown the netmgr - this also makes sure all the tasks and events are properly executed 3. Shutdown the taskmgr - this now waits for all the tasks to finish running before returning 4. Shutdown the netmgr - this call waits for all the netmgr netievents to finish before returning This solves the race when the taskmgr object would be destroyed before all the tasks were finished running in the netmgr loops.
37 lines
962 B
C
37 lines
962 B
C
/*
|
|
* Copyright (C) Internet Systems Consortium, Inc. ("ISC")
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, you can obtain one at https://mozilla.org/MPL/2.0/.
|
|
*
|
|
* See the COPYRIGHT file distributed with this work for additional
|
|
* information regarding copyright ownership.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <isc/mem.h>
|
|
#include <isc/result.h>
|
|
|
|
void
|
|
isc__netmgr_create(isc_mem_t *mctx, uint32_t workers, isc_nm_t **netgmrp);
|
|
/*%<
|
|
* Creates a new network manager with 'workers' worker threads,
|
|
* and starts it running.
|
|
*/
|
|
|
|
void
|
|
isc__netmgr_destroy(isc_nm_t **netmgrp);
|
|
/*%<
|
|
* Similar to isc_nm_detach(), but actively waits for all other references
|
|
* to be gone before returning.
|
|
*/
|
|
|
|
void
|
|
isc__netmgr_shutdown(isc_nm_t *mgr);
|
|
/*%<
|
|
* Shut down all active connections, freeing associated resources;
|
|
* prevent new connections from being established.
|
|
*/
|