provider: Do not remove the provider as it would remove it from storage
authorJukka Rissanen <jukka.rissanen@linux.intel.com>
Mon, 12 Nov 2012 12:07:45 +0000 (14:07 +0200)
committerPatrik Flykt <patrik.flykt@linux.intel.com>
Fri, 23 Nov 2012 10:58:52 +0000 (12:58 +0200)
src/provider.c

index 665ef2e..fe7eb88 100644 (file)
@@ -110,8 +110,6 @@ void connman_provider_unref_debug(struct connman_provider *provider,
        if (__sync_fetch_and_sub(&provider->refcount, 1) != 1)
                return;
 
-       provider_remove(provider);
-
        provider_destruct(provider);
 }
 
@@ -197,9 +195,7 @@ int __connman_provider_remove(const char *path)
                if (g_strcmp0(srv_path, path) == 0) {
                        DBG("Removing VPN %s", provider->identifier);
 
-                       if (provider->driver != NULL &&
-                                               provider->driver->remove)
-                               provider->driver->remove(provider);
+                       provider_remove(provider);
 
                        g_hash_table_remove(provider_hash,
                                                provider->identifier);
@@ -565,14 +561,6 @@ static void unregister_provider(gpointer data)
        connman_provider_unref(provider);
 }
 
-static void clean_provider(gpointer key, gpointer value, gpointer user_data)
-{
-       struct connman_provider *provider = value;
-
-       if (provider->driver != NULL && provider->driver->remove)
-               provider->driver->remove(provider);
-}
-
 static gint compare_priority(gconstpointer a, gconstpointer b)
 {
        return 0;
@@ -761,8 +749,6 @@ void __connman_provider_cleanup(void)
 
        connman_notifier_unregister(&provider_notifier);
 
-       g_hash_table_foreach(provider_hash, clean_provider, NULL);
-
        g_hash_table_destroy(provider_hash);
        provider_hash = NULL;