]> git.ipfire.org Git - thirdparty/bind9.git/commitdiff
missing changes from 23467
authorFrancis Dupont <fdupont@isc.org>
Thu, 17 Mar 2011 09:40:08 +0000 (09:40 +0000)
committerFrancis Dupont <fdupont@isc.org>
Thu, 17 Mar 2011 09:40:08 +0000 (09:40 +0000)
bin/named/win32/dlz_dlopen_driver.c [new file with mode: 0644]
bin/named/win32/named.dsp
bin/named/win32/named.mak

diff --git a/bin/named/win32/dlz_dlopen_driver.c b/bin/named/win32/dlz_dlopen_driver.c
new file mode 100644 (file)
index 0000000..7b17e04
--- /dev/null
@@ -0,0 +1,603 @@
+/*
+ * Copyright (C) 2011  Internet Systems Consortium, Inc. ("ISC")
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
+ * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
+ * AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
+ * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
+ * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
+ * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+ * PERFORMANCE OF THIS SOFTWARE.
+ */
+
+/* $Id: dlz_dlopen_driver.c,v 1.4.2.2 2011/03/17 09:40:08 fdupont Exp $ */
+
+#include <config.h>
+
+#include <windows.h>
+
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+
+#include <dns/log.h>
+#include <dns/sdlz.h>
+#include <dns/result.h>
+
+#include <isc/mem.h>
+#include <isc/print.h>
+#include <isc/result.h>
+#include <isc/util.h>
+
+#include <named/globals.h>
+
+#include <dlz/dlz_dlopen_driver.h>
+
+#ifdef ISC_DLZ_DLOPEN
+static dns_sdlzimplementation_t *dlz_dlopen = NULL;
+
+
+typedef struct dlopen_data {
+       isc_mem_t *mctx;
+       char *dl_path;
+       char *dlzname;
+       HMODULE dl_handle;
+       void *dbdata;
+       unsigned int flags;
+       isc_mutex_t lock;
+       int version;
+       isc_boolean_t in_configure;
+
+       int (*dlz_version)(unsigned int *flags);
+       isc_result_t (*dlz_create)(const char *dlzname,
+                                  unsigned int argc, char *argv[],
+                                  void **dbdata, ...);
+       isc_result_t (*dlz_findzonedb)(void *dbdata, const char *name);
+       isc_result_t (*dlz_lookup)(const char *zone, const char *name,
+                                  void *dbdata, dns_sdlzlookup_t *lookup);
+       isc_result_t (*dlz_authority)(const char *zone, void *dbdata,
+                                     dns_sdlzlookup_t *lookup);
+       isc_result_t (*dlz_allnodes)(const char *zone, void *dbdata,
+                                    dns_sdlzallnodes_t *allnodes);
+       isc_result_t (*dlz_allowzonexfr)(void *dbdata, const char *name,
+                                        const char *client);
+       isc_result_t (*dlz_newversion)(const char *zone, void *dbdata,
+                                      void **versionp);
+       void         (*dlz_closeversion)(const char *zone, isc_boolean_t commit,
+                                        void *dbdata, void **versionp);
+       isc_result_t (*dlz_configure)(dns_view_t *view, void *dbdata);
+       isc_boolean_t (*dlz_ssumatch)(const char *signer, const char *name,
+                                     const char *tcpaddr, const char *type,
+                                     const char *key, isc_uint32_t keydatalen,
+                                     unsigned char *keydata, void *dbdata);
+       isc_result_t (*dlz_addrdataset)(const char *name, const char *rdatastr,
+                                       void *dbdata, void *version);
+       isc_result_t (*dlz_subrdataset)(const char *name, const char *rdatastr,
+                                       void *dbdata, void *version);
+       isc_result_t (*dlz_delrdataset)(const char *name, const char *type,
+                                       void *dbdata, void *version);
+       void         (*dlz_destroy)(void *dbdata);
+} dlopen_data_t;
+
+/* Modules can choose whether they are lock-safe or not. */
+#define MAYBE_LOCK(cd) \
+       do { \
+               if ((cd->flags & DNS_SDLZFLAG_THREADSAFE) == 0 && \
+                   cd->in_configure == ISC_FALSE) \
+                       LOCK(&cd->lock); \
+       } while (0)
+
+#define MAYBE_UNLOCK(cd) \
+       do { \
+               if ((cd->flags & DNS_SDLZFLAG_THREADSAFE) == 0 && \
+                   cd->in_configure == ISC_FALSE) \
+                       UNLOCK(&cd->lock); \
+       } while (0)
+
+/*
+ * Log a message at the given level.
+ */
+static void dlopen_log(int level, const char *fmt, ...)
+{
+       va_list ap;
+       va_start(ap, fmt);
+       isc_log_vwrite(dns_lctx, DNS_LOGCATEGORY_DATABASE,
+                      DNS_LOGMODULE_DLZ, ISC_LOG_DEBUG(level),
+                      fmt, ap);
+       va_end(ap);
+}
+
+/*
+ * SDLZ methods
+ */
+
+static isc_result_t
+dlopen_dlz_allnodes(const char *zone, void *driverarg, void *dbdata,
+                   dns_sdlzallnodes_t *allnodes)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_result_t result;
+
+
+       UNUSED(driverarg);
+
+       if (cd->dlz_allnodes == NULL) {
+               return (ISC_R_NOPERM);
+       }
+
+       MAYBE_LOCK(cd);
+       result = cd->dlz_allnodes(zone, cd->dbdata, allnodes);
+       MAYBE_UNLOCK(cd);
+       return (result);
+}
+
+
+static isc_result_t
+dlopen_dlz_allowzonexfr(void *driverarg, void *dbdata, const char *name,
+                       const char *client)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_result_t result;
+
+       UNUSED(driverarg);
+
+
+       if (cd->dlz_allowzonexfr == NULL) {
+               return (ISC_R_NOPERM);
+       }
+
+       MAYBE_LOCK(cd);
+       result = cd->dlz_allowzonexfr(cd->dbdata, name, client);
+       MAYBE_UNLOCK(cd);
+       return (result);
+}
+
+static isc_result_t
+dlopen_dlz_authority(const char *zone, void *driverarg, void *dbdata,
+                  dns_sdlzlookup_t *lookup)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_result_t result;
+
+       UNUSED(driverarg);
+
+       if (cd->dlz_authority == NULL) {
+               return (ISC_R_NOTIMPLEMENTED);
+       }
+
+       MAYBE_LOCK(cd);
+       result = cd->dlz_authority(zone, cd->dbdata, lookup);
+       MAYBE_UNLOCK(cd);
+       return (result);
+}
+
+static isc_result_t
+dlopen_dlz_findzonedb(void *driverarg, void *dbdata, const char *name)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_result_t result;
+
+       UNUSED(driverarg);
+
+       MAYBE_LOCK(cd);
+       result = cd->dlz_findzonedb(cd->dbdata, name);
+       MAYBE_UNLOCK(cd);
+       return (result);
+}
+
+
+static isc_result_t
+dlopen_dlz_lookup(const char *zone, const char *name, void *driverarg,
+                 void *dbdata, dns_sdlzlookup_t *lookup)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_result_t result;
+
+       UNUSED(driverarg);
+
+       MAYBE_LOCK(cd);
+       result = cd->dlz_lookup(zone, name, cd->dbdata, lookup);
+       MAYBE_UNLOCK(cd);
+       return (result);
+}
+
+/*
+ * Load a symbol from the library
+ */
+static void *
+dl_load_symbol(dlopen_data_t *cd, const char *symbol, isc_boolean_t mandatory) {
+       void *ptr = GetProcAddress(cd->dl_handle, symbol);
+       if (ptr == NULL && mandatory) {
+               dlopen_log(ISC_LOG_ERROR,
+                          "dlz_dlopen: library '%s' is missing "
+                          "required symbol '%s'", cd->dl_path, symbol);
+       }
+       return (ptr);
+}
+
+/*
+ * Called at startup for each dlopen zone in named.conf
+ */
+static isc_result_t
+dlopen_dlz_create(const char *dlzname, unsigned int argc, char *argv[],
+                 void *driverarg, void **dbdata)
+{
+       dlopen_data_t *cd;
+       isc_mem_t *mctx = NULL;
+       isc_result_t result = ISC_R_FAILURE;
+       isc_boolean_t triedload = ISC_FALSE;
+
+       UNUSED(driverarg);
+
+       if (argc < 2) {
+               dlopen_log(ISC_LOG_ERROR,
+                          "dlz_dlopen driver for '%s' needs a path to "
+                          "the shared library", dlzname);
+               return (ISC_R_FAILURE);
+       }
+
+       isc_mem_create(0, 0, &mctx);
+
+       cd = isc_mem_get(mctx, sizeof(*cd));
+       if (cd == NULL) {
+               isc_mem_destroy(&mctx);
+               return (ISC_R_NOMEMORY);
+       }
+       memset(cd, 0, sizeof(*cd));
+
+       cd->mctx = mctx;
+
+       cd->dl_path = isc_mem_strdup(cd->mctx, argv[1]);
+       if (cd->dl_path == NULL) {
+               goto failed;
+       }
+
+       cd->dlzname = isc_mem_strdup(cd->mctx, dlzname);
+       if (cd->dlzname == NULL) {
+               goto failed;
+       }
+
+       triedload = ISC_TRUE;
+
+       /* Initialize the lock */
+       isc_mutex_init(&cd->lock);
+
+       /* Open the library */
+       cd->dl_handle = LoadLibraryA(cd->dl_path);
+       if (cd->dl_handle == NULL) {
+               unsigned int error = GetLastError();
+
+               dlopen_log(ISC_LOG_ERROR,
+                          "dlz_dlopen failed to open library '%s' - %u",
+                          cd->dl_path, error);
+               goto failed;
+       }
+
+       /* Find the symbols */
+       cd->dlz_version = dl_load_symbol(cd, "dlz_version", ISC_TRUE);
+       cd->dlz_create = dl_load_symbol(cd, "dlz_create", ISC_TRUE);
+       cd->dlz_lookup = dl_load_symbol(cd, "dlz_lookup", ISC_TRUE);
+       cd->dlz_findzonedb = dl_load_symbol(cd, "dlz_findzonedb", ISC_TRUE);
+
+       if (cd->dlz_create == NULL ||
+           cd->dlz_lookup == NULL ||
+           cd->dlz_findzonedb == NULL)
+       {
+               /* We're missing a required symbol */
+               goto failed;
+       }
+
+       cd->dlz_allowzonexfr = dl_load_symbol(cd, "dlz_allowzonexfr",
+                                             ISC_FALSE);
+       cd->dlz_allnodes = dl_load_symbol(cd, "dlz_allnodes",
+                                         ISC_TF(cd->dlz_allowzonexfr != NULL));
+       cd->dlz_authority = dl_load_symbol(cd, "dlz_authority", ISC_FALSE);
+       cd->dlz_newversion = dl_load_symbol(cd, "dlz_newversion", ISC_FALSE);
+       cd->dlz_closeversion = dl_load_symbol(cd, "dlz_closeversion",
+                                           ISC_TF(cd->dlz_newversion != NULL));
+       cd->dlz_configure = dl_load_symbol(cd, "dlz_configure", ISC_FALSE);
+       cd->dlz_ssumatch = dl_load_symbol(cd, "dlz_ssumatch", ISC_FALSE);
+       cd->dlz_addrdataset = dl_load_symbol(cd, "dlz_addrdataset", ISC_FALSE);
+       cd->dlz_subrdataset = dl_load_symbol(cd, "dlz_subrdataset", ISC_FALSE);
+       cd->dlz_delrdataset = dl_load_symbol(cd, "dlz_delrdataset", ISC_FALSE);
+
+       /* Check the version of the API is the same */
+       cd->version = cd->dlz_version(&cd->flags);
+       if (cd->version != DLZ_DLOPEN_VERSION) {
+               dlopen_log(ISC_LOG_ERROR,
+                          "dlz_dlopen: incorrect version %d "
+                          "should be %d in '%s'",
+                          cd->version, DLZ_DLOPEN_VERSION, cd->dl_path);
+               goto failed;
+       }
+
+       /*
+        * Call the library's create function. Note that this is an
+        * extended version of dlz create, with the addition of
+        * named function pointers for helper functions that the
+        * driver will need. This avoids the need for the backend to
+        * link the bind9 libraries
+        */
+       MAYBE_LOCK(cd);
+       result = cd->dlz_create(dlzname, argc-1, argv+1,
+                               &cd->dbdata,
+                               "log", dlopen_log,
+                               "putrr", dns_sdlz_putrr,
+                               "putnamedrr", dns_sdlz_putnamedrr,
+                               "writeable_zone", dns_dlz_writeablezone,
+                               NULL);
+       MAYBE_UNLOCK(cd);
+       if (result != ISC_R_SUCCESS)
+               goto failed;
+
+       *dbdata = cd;
+
+       return (ISC_R_SUCCESS);
+
+failed:
+       dlopen_log(ISC_LOG_ERROR, "dlz_dlopen of '%s' failed", dlzname);
+       if (cd->dl_path)
+               isc_mem_free(mctx, cd->dl_path);
+       if (cd->dlzname)
+               isc_mem_free(mctx, cd->dlzname);
+       if (triedload)
+               isc_mutex_destroy(&cd->lock);
+       if (cd->dl_handle)
+               FreeLibrary(cd->dl_handle);
+       isc_mem_put(mctx, cd, sizeof(*cd));
+       isc_mem_destroy(&mctx);
+       return (result);
+}
+
+
+/*
+ * Called when bind is shutting down
+ */
+static void
+dlopen_dlz_destroy(void *driverarg, void *dbdata) {
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_mem_t *mctx;
+
+       UNUSED(driverarg);
+
+       if (cd->dlz_destroy) {
+               MAYBE_LOCK(cd);
+               cd->dlz_destroy(cd->dbdata);
+               MAYBE_UNLOCK(cd);
+       }
+
+       if (cd->dl_path)
+               isc_mem_free(cd->mctx, cd->dl_path);
+       if (cd->dlzname)
+               isc_mem_free(cd->mctx, cd->dlzname);
+
+       if (cd->dl_handle)
+               FreeLibrary(cd->dl_handle);
+
+       isc_mutex_destroy(&cd->lock);
+
+       mctx = cd->mctx;
+       isc_mem_put(mctx, cd, sizeof(*cd));
+       isc_mem_destroy(&mctx);
+}
+
+/*
+ * Called to start a transaction
+ */
+static isc_result_t
+dlopen_dlz_newversion(const char *zone, void *driverarg, void *dbdata,
+                     void **versionp)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_result_t result;
+
+       UNUSED(driverarg);
+
+       if (cd->dlz_newversion == NULL)
+               return (ISC_R_NOTIMPLEMENTED);
+
+       MAYBE_LOCK(cd);
+       result = cd->dlz_newversion(zone, cd->dbdata, versionp);
+       MAYBE_UNLOCK(cd);
+       return (result);
+}
+
+/*
+ * Called to end a transaction
+ */
+static void
+dlopen_dlz_closeversion(const char *zone, isc_boolean_t commit,
+                       void *driverarg, void *dbdata, void **versionp)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+
+       UNUSED(driverarg);
+
+       if (cd->dlz_newversion == NULL) {
+               *versionp = NULL;
+               return;
+       }
+
+       MAYBE_LOCK(cd);
+       cd->dlz_closeversion(zone, commit, cd->dbdata, versionp);
+       MAYBE_UNLOCK(cd);
+}
+
+/*
+ * Called on startup to configure any writeable zones
+ */
+static isc_result_t
+dlopen_dlz_configure(dns_view_t *view, void *driverarg, void *dbdata) {
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_result_t result;
+
+       UNUSED(driverarg);
+
+       if (cd->dlz_configure == NULL)
+               return (ISC_R_SUCCESS);
+
+       MAYBE_LOCK(cd);
+       cd->in_configure = ISC_TRUE;
+       result = cd->dlz_configure(view, cd->dbdata);
+       cd->in_configure = ISC_FALSE;
+       MAYBE_UNLOCK(cd);
+
+       return (result);
+}
+
+
+/*
+ * Check for authority to change a name
+ */
+static isc_boolean_t
+dlopen_dlz_ssumatch(const char *signer, const char *name, const char *tcpaddr,
+                   const char *type, const char *key, isc_uint32_t keydatalen,
+                   unsigned char *keydata, void *driverarg, void *dbdata)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_boolean_t ret;
+
+       UNUSED(driverarg);
+
+       if (cd->dlz_ssumatch == NULL)
+               return (ISC_FALSE);
+
+       MAYBE_LOCK(cd);
+       ret = cd->dlz_ssumatch(signer, name, tcpaddr, type, key, keydatalen,
+                              keydata, cd->dbdata);
+       MAYBE_UNLOCK(cd);
+
+       return (ret);
+}
+
+
+/*
+ * Add an rdataset
+ */
+static isc_result_t
+dlopen_dlz_addrdataset(const char *name, const char *rdatastr,
+                      void *driverarg, void *dbdata, void *version)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_result_t result;
+
+       UNUSED(driverarg);
+
+       if (cd->dlz_addrdataset == NULL)
+               return (ISC_R_NOTIMPLEMENTED);
+
+       MAYBE_LOCK(cd);
+       result = cd->dlz_addrdataset(name, rdatastr, cd->dbdata, version);
+       MAYBE_UNLOCK(cd);
+
+       return (result);
+}
+
+/*
+ * Subtract an rdataset
+ */
+static isc_result_t
+dlopen_dlz_subrdataset(const char *name, const char *rdatastr,
+                      void *driverarg, void *dbdata, void *version)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_result_t result;
+
+       UNUSED(driverarg);
+
+       if (cd->dlz_subrdataset == NULL)
+               return (ISC_R_NOTIMPLEMENTED);
+
+       MAYBE_LOCK(cd);
+       result = cd->dlz_subrdataset(name, rdatastr, cd->dbdata, version);
+       MAYBE_UNLOCK(cd);
+
+       return (result);
+}
+
+/*
+  delete a rdataset
+ */
+static isc_result_t
+dlopen_dlz_delrdataset(const char *name, const char *type,
+                      void *driverarg, void *dbdata, void *version)
+{
+       dlopen_data_t *cd = (dlopen_data_t *) dbdata;
+       isc_result_t result;
+
+       UNUSED(driverarg);
+
+       if (cd->dlz_delrdataset == NULL)
+               return (ISC_R_NOTIMPLEMENTED);
+
+       MAYBE_LOCK(cd);
+       result = cd->dlz_delrdataset(name, type, cd->dbdata, version);
+       MAYBE_UNLOCK(cd);
+
+       return (result);
+}
+
+
+static dns_sdlzmethods_t dlz_dlopen_methods = {
+       dlopen_dlz_create,
+       dlopen_dlz_destroy,
+       dlopen_dlz_findzonedb,
+       dlopen_dlz_lookup,
+       dlopen_dlz_authority,
+       dlopen_dlz_allnodes,
+       dlopen_dlz_allowzonexfr,
+       dlopen_dlz_newversion,
+       dlopen_dlz_closeversion,
+       dlopen_dlz_configure,
+       dlopen_dlz_ssumatch,
+       dlopen_dlz_addrdataset,
+       dlopen_dlz_subrdataset,
+       dlopen_dlz_delrdataset
+};
+#endif
+
+/*
+ * Register driver with BIND
+ */
+isc_result_t
+dlz_dlopen_init(isc_mem_t *mctx) {
+#ifndef ISC_DLZ_DLOPEN
+       UNUSED(mctx);
+       return (ISC_R_NOTIMPLEMENTED);
+#else
+       isc_result_t result;
+
+       dlopen_log(2, "Registering DLZ_dlopen driver");
+
+       result = dns_sdlzregister("dlopen", &dlz_dlopen_methods, NULL,
+                                 DNS_SDLZFLAG_RELATIVEOWNER |
+                                 DNS_SDLZFLAG_THREADSAFE,
+                                 mctx, &dlz_dlopen);
+
+       if (result != ISC_R_SUCCESS) {
+               UNEXPECTED_ERROR(__FILE__, __LINE__,
+                                "dns_sdlzregister() failed: %s",
+                                isc_result_totext(result));
+               result = ISC_R_UNEXPECTED;
+       }
+
+       return (result);
+#endif
+}
+
+
+/*
+ * Unregister the driver
+ */
+void
+dlz_dlopen_clear(void) {
+#ifdef ISC_DLZ_DLOPEN
+       dlopen_log(2, "Unregistering DLZ_dlopen driver");
+       if (dlz_dlopen != NULL)
+               dns_sdlzunregister(&dlz_dlopen);
+#endif
+}
index 401d64f5a1d19cbd9beb48c4c6f5144b16c9c477..2a15064d9d3681df4631a679633ed763f5389eba 100644 (file)
@@ -110,6 +110,10 @@ SOURCE=..\controlconf.c
 # End Source File
 # Begin Source File
 
+SOURCE=.\dlz_dlopen_driver.c
+# End Source File
+# Begin Source File
+
 SOURCE=..\interfacemgr.c
 # End Source File
 # Begin Source File
index f01195ed58845a6024daeb54ab37c22e44c06ecd..a51468bce117143192710c115aebf0acf90dc389 100644 (file)
@@ -129,6 +129,7 @@ CLEAN :
        -@erase "$(INTDIR)\config.obj"
        -@erase "$(INTDIR)\control.obj"
        -@erase "$(INTDIR)\controlconf.obj"
+       -@erase "$(INTDIR)\dlz_dlopen_driver.obj"
        -@erase "$(INTDIR)\interfacemgr.obj"
        -@erase "$(INTDIR)\listenlist.obj"
        -@erase "$(INTDIR)\log.obj"
@@ -174,6 +175,7 @@ LINK32_OBJS= \
        "$(INTDIR)\config.obj" \
        "$(INTDIR)\control.obj" \
        "$(INTDIR)\controlconf.obj" \
+       "$(INTDIR)\dlz_dlopen_driver.obj" \
        "$(INTDIR)\interfacemgr.obj" \
        "$(INTDIR)\listenlist.obj" \
        "$(INTDIR)\log.obj" \
@@ -247,6 +249,8 @@ CLEAN :
        -@erase "$(INTDIR)\control.sbr"
        -@erase "$(INTDIR)\controlconf.obj"
        -@erase "$(INTDIR)\controlconf.sbr"
+       -@erase "$(INTDIR)\dlz_dlopen_driver.obj"
+       -@erase "$(INTDIR)\dlz_dlopen_driver.sbr"
        -@erase "$(INTDIR)\interfacemgr.obj"
        -@erase "$(INTDIR)\interfacemgr.sbr"
        -@erase "$(INTDIR)\listenlist.obj"
@@ -319,6 +323,7 @@ BSC32_SBRS= \
        "$(INTDIR)\config.sbr" \
        "$(INTDIR)\control.sbr" \
        "$(INTDIR)\controlconf.sbr" \
+       "$(INTDIR)\dlz_dlopen_driver.sbr" \
        "$(INTDIR)\interfacemgr.sbr" \
        "$(INTDIR)\listenlist.sbr" \
        "$(INTDIR)\log.sbr" \
@@ -359,6 +364,7 @@ LINK32_OBJS= \
        "$(INTDIR)\config.obj" \
        "$(INTDIR)\control.obj" \
        "$(INTDIR)\controlconf.obj" \
+       "$(INTDIR)\dlz_dlopen_driver.obj" \
        "$(INTDIR)\interfacemgr.obj" \
        "$(INTDIR)\listenlist.obj" \
        "$(INTDIR)\log.obj" \
@@ -530,6 +536,22 @@ SOURCE=..\controlconf.c
        $(CPP) $(CPP_PROJ) $(SOURCE)
 
 
+!ENDIF 
+
+SOURCE=.\dlz_dlopen_driver.c
+
+!IF  "$(CFG)" == "named - Win32 Release"
+
+
+"$(INTDIR)\dlz_dlopen_driver.obj" : $(SOURCE) "$(INTDIR)"
+
+
+!ELSEIF  "$(CFG)" == "named - Win32 Debug"
+
+
+"$(INTDIR)\dlz_dlopen_driver.obj"      "$(INTDIR)\dlz_dlopen_driver.sbr" : $(SOURCE) "$(INTDIR)"
+
+
 !ENDIF 
 
 SOURCE=..\interfacemgr.c