2
0
mirror of https://gitlab.isc.org/isc-projects/bind9 synced 2025-08-30 05:57:52 +00:00

Adjust function dns_zt_*() names to remove _zone, lookup -> find.

Add thread support.
This commit is contained in:
Mark Andrews 1999-09-17 10:00:14 +00:00
parent 3ddd92da66
commit a86ce0b97d
2 changed files with 81 additions and 18 deletions

View File

@ -28,14 +28,14 @@
typedef struct dns_zt dns_zt_t; typedef struct dns_zt dns_zt_t;
ISC_LANG_BEGINDECLS ISC_LANG_BEGINDECLS
dns_result_t dns_zt_create(isc_mem_t *mctx, dns_rdataclass_t rdclass, dns_result_t dns_zt_create(isc_mem_t *mctx, dns_rdataclass_t rdclass,
dns_zt_t **zt); dns_zt_t **zt);
dns_result_t dns_zt_mount_zone(dns_zt_t *zt, dns_zone_t *zone); dns_result_t dns_zt_mount(dns_zt_t *zt, dns_zone_t *zone);
dns_result_t dns_zt_unmount_zone(dns_zt_t *zt, dns_zone_t *zone); dns_result_t dns_zt_unmount(dns_zt_t *zt, dns_zone_t *zone);
dns_result_t dns_zt_lookup_zone(dns_zt_t *zt, dns_name_t *name, dns_result_t dns_zt_find(dns_zt_t *zt, dns_name_t *name,
dns_name_t *foundname, dns_zone_t **zone); dns_name_t *foundname, dns_zone_t **zone);
void dns_zt_destroy(dns_zt_t *zt); void dns_zt_detach(dns_zt_t **ztp);
void dns_zt_attach(dns_zt_t *zt, dns_zt_t **ztp);
ISC_LANG_ENDDECLS ISC_LANG_ENDDECLS

View File

@ -17,13 +17,16 @@
#include <config.h> #include <config.h>
#include <isc/assertions.h> #include <isc/assertions.h>
#include "../isc/util.h"
#include <dns/zt.h> #include <dns/zt.h>
struct dns_zt { struct dns_zt {
unsigned int magic; unsigned int magic;
dns_rdataclass_t rdclass;
dns_rbt_t *table;
isc_mem_t *mctx; isc_mem_t *mctx;
dns_rdataclass_t rdclass;
isc_mutex_t lock;
isc_uint32_t references;
dns_rbt_t *table;
}; };
#define ZTMAGIC 0x5a54626cU /* ZTbl */ #define ZTMAGIC 0x5a54626cU /* ZTbl */
@ -35,6 +38,7 @@ dns_result_t
dns_zt_create(isc_mem_t *mctx, dns_rdataclass_t rdclass, dns_zt_t **zt) { dns_zt_create(isc_mem_t *mctx, dns_rdataclass_t rdclass, dns_zt_t **zt) {
dns_zt_t *new; dns_zt_t *new;
dns_result_t result; dns_result_t result;
isc_result_t iresult;
REQUIRE(zt != NULL && *zt == NULL); REQUIRE(zt != NULL && *zt == NULL);
new = isc_mem_get(mctx, sizeof *new); new = isc_mem_get(mctx, sizeof *new);
@ -42,59 +46,118 @@ dns_zt_create(isc_mem_t *mctx, dns_rdataclass_t rdclass, dns_zt_t **zt) {
return (DNS_R_NOMEMORY); return (DNS_R_NOMEMORY);
result = dns_rbt_create(mctx, auto_detach, NULL, &new->table); result = dns_rbt_create(mctx, auto_detach, NULL, &new->table);
if (result != DNS_R_SUCCESS) { if (result != DNS_R_SUCCESS)
isc_mem_put(mctx, new, sizeof *new); goto cleanup0;
return (result);
iresult = isc_mutex_init(&new->lock);
if (iresult != ISC_R_SUCCESS) {
UNEXPECTED_ERROR(__FILE__, __LINE__,
"isc_lock_init() failed: %s",
isc_result_totext(result));
result = DNS_R_UNEXPECTED;
goto cleanup1;
} }
new->mctx = mctx; new->mctx = mctx;
new->references = 1;
new->rdclass = rdclass; new->rdclass = rdclass;
new->magic = ZTMAGIC; new->magic = ZTMAGIC;
*zt = new; *zt = new;
return (DNS_R_SUCCESS); return (DNS_R_SUCCESS);
cleanup1:
dns_rbt_destroy(&new->table);
cleanup0:
isc_mem_put(mctx, new, sizeof *new);
return (result);
} }
dns_result_t dns_result_t
dns_zt_mount_zone(dns_zt_t *zt, dns_zone_t *zone) { dns_zt_mount(dns_zt_t *zt, dns_zone_t *zone) {
dns_result_t result; dns_result_t result;
dns_zone_t *dummy = NULL; dns_zone_t *dummy = NULL;
REQUIRE(VALID_ZT(zt)); REQUIRE(VALID_ZT(zt));
dns_zone_attach(zone, &dummy); dns_zone_attach(zone, &dummy);
LOCK(&zt->lock);
result = dns_rbt_addname(zt->table, dns_zone_getorigin(zone), zone); result = dns_rbt_addname(zt->table, dns_zone_getorigin(zone), zone);
UNLOCK(&zt->lock);
return (result); return (result);
} }
dns_result_t dns_result_t
dns_zt_unmount_zone(dns_zt_t *zt, dns_zone_t *zone) { dns_zt_unmount(dns_zt_t *zt, dns_zone_t *zone) {
dns_result_t result; dns_result_t result;
REQUIRE(VALID_ZT(zt)); REQUIRE(VALID_ZT(zt));
LOCK(&zt->lock);
result = dns_rbt_deletename(zt->table, dns_zone_getorigin(zone), result = dns_rbt_deletename(zt->table, dns_zone_getorigin(zone),
ISC_FALSE); ISC_FALSE);
UNLOCK(&zt->lock);
return (result); return (result);
} }
dns_result_t dns_result_t
dns_zt_lookup_zone(dns_zt_t *zt, dns_name_t *name, dns_name_t *foundname, dns_zt_find(dns_zt_t *zt, dns_name_t *name, dns_name_t *foundname,
dns_zone_t **zone) dns_zone_t **zone)
{ {
dns_result_t result; dns_result_t result;
REQUIRE(VALID_ZT(zt)); REQUIRE(VALID_ZT(zt));
LOCK(&zt->lock);
result = dns_rbt_findname(zt->table, name, foundname, (void **)zone); result = dns_rbt_findname(zt->table, name, foundname, (void **)zone);
UNLOCK(&zt->lock);
return (result); return (result);
} }
void void
dns_zt_destroy(dns_zt_t *zt) { dns_zt_detach(dns_zt_t **ztp) {
REQUIRE(VALID_ZT(zt)); isc_boolean_t destroy = ISC_FALSE;
dns_zt_t *zt;
zt->magic = 0; REQUIRE(ztp != NULL && VALID_ZT(*ztp));
dns_rbt_destroy(&zt->table);
isc_mem_put(zt->mctx, zt, sizeof *zt); zt = *ztp;
LOCK(&zt->lock);
INSIST(zt->references > 0);
zt->references--;
if (zt->references == 0)
destroy = ISC_TRUE;
UNLOCK(&zt->lock);
if (destroy) {
dns_rbt_destroy(&zt->table);
isc_mutex_destroy(&zt->lock);
isc_mem_put(zt->mctx, zt, sizeof *zt);
zt->magic = 0;
}
*ztp = NULL;
}
void
dns_zt_attach(dns_zt_t *zt, dns_zt_t **ztp) {
REQUIRE(VALID_ZT(zt));
REQUIRE(ztp != NULL && *ztp == NULL);
LOCK(&zt->lock);
INSIST(zt->references > 0);
zt->references++;
INSIST(zt->references != 0xffffffffU);
UNLOCK(&zt->lock);
*ztp = zt;
} }
static void static void