--- mqtt/src/dl.c 2012/04/11 15:08:27 1.2.2.3 +++ mqtt/src/dl.c 2012/06/01 11:39:15 1.2.2.7 @@ -2,8 +2,6 @@ #include "rtlm.h" -static void *acc_rtlm, *pub_rtlm, *log_rtlm; - struct tagCallbacks call; @@ -53,7 +51,7 @@ mqttLoadRTLM(cfg_root_t *cfg, int modtype) return NULL; } - rtlm = dlopen(str, RTLD_LAZY); + rtlm = dlopen(str, RTLD_NOW); if (!rtlm) { mqttLog("Error:: RTL module %s not found %s\n", str, dlerror()); return NULL; @@ -61,20 +59,19 @@ mqttLoadRTLM(cfg_root_t *cfg, int modtype) mqttOpenRTLM = dlsym(rtlm, "mqtt_rtlm_open"); if (!mqttOpenRTLM) { - mqttLog("Error:: Can't found mqtt_db_open call\n"); + mqttLog("Error:: Can't found mqtt_rtlm_open call\n"); dlclose(rtlm); return NULL; } mqttCloseRTLM = dlsym(rtlm, "mqtt_rtlm_close"); if (!mqttCloseRTLM) { - mqttLog("Error:: Can't found mqtt_db_close call\n"); + mqttLog("Error:: Can't found mqtt_rtlm_close call\n"); dlclose(rtlm); return NULL; } switch (modtype) { case 0: - acc_rtlm = rtlm; call.OpenACC = mqttOpenRTLM; call.CloseACC = mqttCloseRTLM; call.LoginACC = dlsym(rtlm, "mqtt_rtlm_login"); @@ -85,7 +82,6 @@ mqttLoadRTLM(cfg_root_t *cfg, int modtype) } break; case 1: - pub_rtlm = rtlm; call.OpenPUB = mqttOpenRTLM; call.ClosePUB = mqttCloseRTLM; call.InitSessPUB = dlsym(rtlm, "mqtt_rtlm_init_session"); @@ -94,6 +90,7 @@ mqttLoadRTLM(cfg_root_t *cfg, int modtype) call.WritePUB_topic = dlsym(rtlm, "mqtt_rtlm_write_topic"); call.ReadPUB_topic = dlsym(rtlm, "mqtt_rtlm_read_topic"); call.DeletePUB_topic = dlsym(rtlm, "mqtt_rtlm_delete_topic"); + call.WipePUB_topic = dlsym(rtlm, "mqtt_rtlm_wipe_topic"); call.WritePUB_subscribe = dlsym(rtlm, "mqtt_rtlm_write_subscribe"); call.ReadPUB_subscribe = dlsym(rtlm, "mqtt_rtlm_read_subscribe"); call.DeletePUB_subscribe = dlsym(rtlm, "mqtt_rtlm_delete_subscribe"); @@ -107,7 +104,6 @@ mqttLoadRTLM(cfg_root_t *cfg, int modtype) } break; default: - log_rtlm = rtlm; call.OpenLOG = mqttOpenRTLM; call.CloseLOG = mqttCloseRTLM; call.LOG = dlsym(rtlm, "mqtt_rtlm_logger"); @@ -123,19 +119,10 @@ mqttLoadRTLM(cfg_root_t *cfg, int modtype) } void -mqttUnloadRTLM(int modtype) +mqttUnloadRTLM(void *rtlm) { - switch (modtype) { - case 0: - dlclose(acc_rtlm); - break; - case 1: - dlclose(pub_rtlm); - break; - default: - dlclose(log_rtlm); - break; - } + if (rtlm) + dlclose(rtlm); } inline int