From: Daniel Wagner <[email protected]>

---
 Makefile.am      |    2 +-
 Makefile.plugins |    3 -
 include/dhcp.h   |   81 --------------
 plugins/dhcp.c   |  227 -------------------------------------
 src/connman.h    |    2 -
 src/dhcp.c       |  325 +++++++++++++++++++++++++++---------------------------
 6 files changed, 162 insertions(+), 478 deletions(-)
 delete mode 100644 include/dhcp.h
 delete mode 100644 plugins/dhcp.c

diff --git a/Makefile.am b/Makefile.am
index 7582e2a..67b2c29 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -14,7 +14,7 @@ nodist_include_HEADERS = include/version.h
 noinst_HEADERS = include/driver.h include/element.h include/property.h \
                        include/rtnl.h include/wifi.h include/task.h \
                        include/dbus.h include/rfkill.h include/option.h \
-                       include/profile.h include/provider.h include/dhcp.h \
+                       include/profile.h include/provider.h \
                        include/utsname.h include/timeserver.h include/proxy.h \
                        include/location.h include/technology.h
 
diff --git a/Makefile.plugins b/Makefile.plugins
index d8ca1b1..94a4fa6 100644
--- a/Makefile.plugins
+++ b/Makefile.plugins
@@ -4,9 +4,6 @@ plugin_cflags = -fvisibility=hidden -I$(srcdir)/gdbus \
 plugin_ldflags = -no-undefined -module -avoid-version
 
 
-builtin_modules += dhcp
-builtin_sources += plugins/dhcp.c
-
 if LOOPBACK
 if LOOPBACK_BUILTIN
 builtin_modules += loopback
diff --git a/include/dhcp.h b/include/dhcp.h
deleted file mode 100644
index ce3e6f4..0000000
--- a/include/dhcp.h
+++ /dev/null
@@ -1,81 +0,0 @@
-/*
- *
- *  Connection Manager
- *
- *  Copyright (C) 2007-2010  Intel Corporation. All rights reserved.
- *
- *  This program is free software; you can redistribute it and/or modify
- *  it under the terms of the GNU General Public License version 2 as
- *  published by the Free Software Foundation.
- *
- *  This program is distributed in the hope that it will be useful,
- *  but WITHOUT ANY WARRANTY; without even the implied warranty of
- *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- *  GNU General Public License for more details.
- *
- *  You should have received a copy of the GNU General Public License
- *  along with this program; if not, write to the Free Software
- *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
- *
- */
-
-#ifndef __CONNMAN_DHCP_H
-#define __CONNMAN_DHCP_H
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/**
- * SECTION:dhcp
- * @title: DHCP premitives
- * @short_description: Functions for handling DHCP
- */
-
-enum connman_dhcp_state {
-       CONNMAN_DHCP_STATE_UNKNOWN  = 0,
-       CONNMAN_DHCP_STATE_IDLE     = 1,
-       CONNMAN_DHCP_STATE_BOUND    = 2,
-       CONNMAN_DHCP_STATE_RENEW    = 3,
-       CONNMAN_DHCP_STATE_FAIL     = 4,
-};
-
-#define CONNMAN_DHCP_PRIORITY_LOW      -100
-#define CONNMAN_DHCP_PRIORITY_DEFAULT     0
-#define CONNMAN_DHCP_PRIORITY_HIGH      100
-
-struct connman_dhcp;
-
-struct connman_dhcp *connman_dhcp_ref(struct connman_dhcp *dhcp);
-void connman_dhcp_unref(struct connman_dhcp *dhcp);
-
-int connman_dhcp_get_index(struct connman_dhcp *dhcp);
-char *connman_dhcp_get_interface(struct connman_dhcp *dhcp);
-
-void connman_dhcp_set_value(struct connman_dhcp *dhcp,
-                                       const char *key, const char *value);
-
-void connman_dhcp_bound(struct connman_dhcp *dhcp);
-void connman_dhcp_renew(struct connman_dhcp *dhcp);
-void connman_dhcp_release(struct connman_dhcp *dhcp);
-void connman_dhcp_fail(struct connman_dhcp *dhcp);
-
-void *connman_dhcp_get_data(struct connman_dhcp *dhcp);
-void connman_dhcp_set_data(struct connman_dhcp *dhcp, void *data);
-
-struct connman_dhcp_driver {
-       const char *name;
-       int priority;
-       int (*request) (struct connman_dhcp *dhcp);
-       int (*release) (struct connman_dhcp *dhcp);
-       int (*renew) (struct connman_dhcp *dhcp);
-};
-
-int connman_dhcp_driver_register(struct connman_dhcp_driver *driver);
-void connman_dhcp_driver_unregister(struct connman_dhcp_driver *driver);
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* __CONNMAN_DHCP_H */
diff --git a/plugins/dhcp.c b/plugins/dhcp.c
deleted file mode 100644
index 54306ed..0000000
--- a/plugins/dhcp.c
+++ /dev/null
@@ -1,227 +0,0 @@
-/*
- *
- *  Connection Manager
- *
- *  Copyright (C) 2007-2010  Intel Corporation. All rights reserved.
- *
- *  This program is free software; you can redistribute it and/or modify
- *  it under the terms of the GNU General Public License version 2 as
- *  published by the Free Software Foundation.
- *
- *  This program is distributed in the hope that it will be useful,
- *  but WITHOUT ANY WARRANTY; without even the implied warranty of
- *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- *  GNU General Public License for more details.
- *
- *  You should have received a copy of the GNU General Public License
- *  along with this program; if not, write to the Free Software
- *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
- *
- */
-
-#ifdef HAVE_CONFIG_H
-#include <config.h>
-#endif
-
-#include <stdio.h>
-#include <errno.h>
-#include <string.h>
-#include <stdlib.h>
-
-#define CONNMAN_API_SUBJECT_TO_CHANGE
-#include <connman/plugin.h>
-#include <connman/dhcp.h>
-#include <connman/utsname.h>
-#include <connman/log.h>
-
-#include <gdhcp/gdhcp.h>
-
-static void dhcp_debug(const char *str, void *data)
-{
-       connman_info("%s: %s\n", (const char *) data, str);
-}
-
-static void no_lease_cb(GDHCPClient *dhcp_client, gpointer user_data)
-{
-       struct connman_dhcp *dhcp = user_data;
-
-       DBG("No lease available");
-
-       connman_dhcp_fail(dhcp);
-}
-
-static void lease_lost_cb(GDHCPClient *dhcp_client, gpointer user_data)
-{
-       DBG("Lease lost");
-}
-
-static void ipv4ll_lost_cb(GDHCPClient *dhcp_client, gpointer user_data)
-{
-       struct connman_dhcp *dhcp = user_data;
-
-       DBG("Lease lost");
-
-       connman_dhcp_release(dhcp);
-}
-
-static void lease_available_cb(GDHCPClient *dhcp_client, gpointer user_data)
-{
-       struct connman_dhcp *dhcp = user_data;
-       GList *list, *option = NULL;
-       char *address, *nameservers;
-       size_t ns_strlen = 0;
-
-       DBG("Lease available");
-
-       address = g_dhcp_client_get_address(dhcp_client);
-       if (address != NULL)
-               connman_dhcp_set_value(dhcp, "Address", address);
-       g_free(address);
-
-       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_SUBNET);
-       if (option != NULL)
-               connman_dhcp_set_value(dhcp, "Netmask", option->data);
-
-       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_DNS_SERVER);
-       for (list = option; list; list = list->next)
-               ns_strlen += strlen((char *) list->data) + 2;
-       nameservers = g_try_malloc0(ns_strlen);
-       if (nameservers) {
-               char *ns_index = nameservers;
-
-               for (list = option; list; list = list->next) {
-                       sprintf(ns_index, "%s ", (char *) list->data);
-                       ns_index += strlen((char *) list->data) + 1;
-               }
-
-               connman_dhcp_set_value(dhcp, "Nameserver", nameservers);
-       }
-       g_free(nameservers);
-
-       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_DOMAIN_NAME);
-       if (option != NULL)
-               connman_dhcp_set_value(dhcp, "Domainname", option->data);
-
-       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_ROUTER);
-       if (option != NULL)
-               connman_dhcp_set_value(dhcp, "Gateway", option->data);
-
-       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_HOST_NAME);
-       if (option != NULL)
-               connman_dhcp_set_value(dhcp, "Hostname", option->data);
-
-       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_NTP_SERVER);
-       if (option != NULL)
-               connman_dhcp_set_value(dhcp, "Timeserver", option->data);
-
-       option = g_dhcp_client_get_option(dhcp_client, 252);
-       if (option != NULL)
-               connman_dhcp_set_value(dhcp, "PAC", option->data);
-
-       connman_dhcp_bound(dhcp);
-}
-
-static void ipv4ll_available_cb(GDHCPClient *dhcp_client, gpointer user_data)
-{
-       struct connman_dhcp *dhcp = user_data;
-       char *address, *netmask;
-
-       DBG("IPV4LL available");
-
-       address = g_dhcp_client_get_address(dhcp_client);
-       if (address != NULL)
-               connman_dhcp_set_value(dhcp, "Address", address);
-
-       netmask = g_dhcp_client_get_netmask(dhcp_client);
-       if (netmask != NULL)
-               connman_dhcp_set_value(dhcp, "Netmask", netmask);
-
-       g_free(address);
-       g_free(netmask);
-
-       connman_dhcp_bound(dhcp);
-}
-
-static int dhcp_request(struct connman_dhcp *dhcp)
-{
-       GDHCPClient *dhcp_client;
-       GDHCPClientError error;
-       const char *hostname;
-       int index;
-
-       DBG("dhcp %p", dhcp);
-
-       index = connman_dhcp_get_index(dhcp);
-
-       dhcp_client = g_dhcp_client_new(G_DHCP_IPV4, index, &error);
-       if (error != G_DHCP_CLIENT_ERROR_NONE)
-               return -EINVAL;
-
-       if (getenv("CONNMAN_DHCP_DEBUG"))
-               g_dhcp_client_set_debug(dhcp_client, dhcp_debug, "DHCP");
-
-       hostname = connman_utsname_get_hostname();
-       if (hostname != NULL)
-               g_dhcp_client_set_send(dhcp_client, G_DHCP_HOST_NAME, hostname);
-
-       g_dhcp_client_set_request(dhcp_client, G_DHCP_HOST_NAME);
-       g_dhcp_client_set_request(dhcp_client, G_DHCP_SUBNET);
-       g_dhcp_client_set_request(dhcp_client, G_DHCP_DNS_SERVER);
-       g_dhcp_client_set_request(dhcp_client, G_DHCP_DOMAIN_NAME);
-       g_dhcp_client_set_request(dhcp_client, G_DHCP_NTP_SERVER);
-       g_dhcp_client_set_request(dhcp_client, G_DHCP_ROUTER);
-       g_dhcp_client_set_request(dhcp_client, 252);
-
-       g_dhcp_client_register_event(dhcp_client,
-                       G_DHCP_CLIENT_EVENT_LEASE_AVAILABLE,
-                                               lease_available_cb, dhcp);
-
-       g_dhcp_client_register_event(dhcp_client,
-                       G_DHCP_CLIENT_EVENT_IPV4LL_AVAILABLE,
-                                               ipv4ll_available_cb, dhcp);
-
-       g_dhcp_client_register_event(dhcp_client,
-                       G_DHCP_CLIENT_EVENT_LEASE_LOST, lease_lost_cb, dhcp);
-
-       g_dhcp_client_register_event(dhcp_client,
-                       G_DHCP_CLIENT_EVENT_IPV4LL_LOST, ipv4ll_lost_cb, dhcp);
-
-       g_dhcp_client_register_event(dhcp_client,
-                       G_DHCP_CLIENT_EVENT_NO_LEASE, no_lease_cb, dhcp);
-
-       connman_dhcp_set_data(dhcp, dhcp_client);
-
-       return g_dhcp_client_start(dhcp_client);
-}
-
-static int dhcp_release(struct connman_dhcp *dhcp)
-{
-       GDHCPClient *dhcp_client = connman_dhcp_get_data(dhcp);
-
-       DBG("dhcp %p", dhcp);
-
-       g_dhcp_client_stop(dhcp_client);
-       g_dhcp_client_unref(dhcp_client);
-
-       return 0;
-}
-
-static struct connman_dhcp_driver dhcp_driver = {
-       .name           = "dhcp",
-       .priority       = CONNMAN_DHCP_PRIORITY_DEFAULT,
-       .request        = dhcp_request,
-       .release        = dhcp_release,
-};
-
-static int dhcp_init(void)
-{
-       return connman_dhcp_driver_register(&dhcp_driver);
-}
-
-static void dhcp_exit(void)
-{
-       connman_dhcp_driver_unregister(&dhcp_driver);
-}
-
-CONNMAN_PLUGIN_DEFINE(dhcp, "Generic DHCP plugin", VERSION,
-                       CONNMAN_PLUGIN_PRIORITY_DEFAULT, dhcp_init, dhcp_exit)
diff --git a/src/connman.h b/src/connman.h
index 24d5d2c..5ad4bcd 100644
--- a/src/connman.h
+++ b/src/connman.h
@@ -277,8 +277,6 @@ int __connman_utsname_set_domainname(const char 
*domainname);
 int __connman_timeserver_init(void);
 void __connman_timeserver_cleanup(void);
 
-#include <connman/dhcp.h>
-
 int __connman_dhcp_init(void);
 void __connman_dhcp_cleanup(void);
 
diff --git a/src/dhcp.c b/src/dhcp.c
index 76c0b75..163b0b7 100644
--- a/src/dhcp.c
+++ b/src/dhcp.c
@@ -22,79 +22,36 @@
 #ifdef HAVE_CONFIG_H
 #include <config.h>
 #endif
+#include <stdio.h>
+#include <errno.h>
+#include <string.h>
+#include <stdlib.h>
+
+#include <gdhcp/gdhcp.h>
 
 #include <glib.h>
 
 #include "connman.h"
 
+enum connman_dhcp_state {
+       CONNMAN_DHCP_STATE_UNKNOWN  = 0,
+       CONNMAN_DHCP_STATE_IDLE     = 1,
+       CONNMAN_DHCP_STATE_BOUND    = 2,
+       CONNMAN_DHCP_STATE_RENEW    = 3,
+       CONNMAN_DHCP_STATE_FAIL     = 4,
+};
+
 struct connman_dhcp {
-       gint refcount;
+       GDHCPClient *dhcp_client;
+
        int index;
        enum connman_dhcp_state state;
 
        struct connman_element *element;
-
-       struct connman_dhcp_driver *driver;
-       void *driver_data;
 };
 
-/**
- * connman_dhcp_ref:
- * @dhcp: DHCP structure
- *
- * Increase reference counter of DHCP
- */
-struct connman_dhcp *connman_dhcp_ref(struct connman_dhcp *dhcp)
-{
-       g_atomic_int_inc(&dhcp->refcount);
-
-       return dhcp;
-}
-
-/**
- * connman_dhcp_unref:
- * @dhcp: DHCP structure
- *
- * Decrease reference counter of DHCP
- */
-void connman_dhcp_unref(struct connman_dhcp *dhcp)
-{
-       if (g_atomic_int_dec_and_test(&dhcp->refcount) == TRUE)
-               g_free(dhcp);
-}
-
-/**
- * connman_dhcp_get_index:
- * @dhcp: DHCP structure
- *
- * Get network index of DHCP
- */
-int connman_dhcp_get_index(struct connman_dhcp *dhcp)
-{
-       return dhcp->index;
-}
-
-/**
- * connman_dhcp_get_interface:
- * @dhcp: DHCP structure
- *
- * Get network interface of DHCP
- */
-char *connman_dhcp_get_interface(struct connman_dhcp *dhcp)
-{
-       return connman_inet_ifname(dhcp->index);
-}
-
-/**
- * connman_dhcp_set_value:
- * @dhcp: DHCP structure
- * @key: unique identifier
- * @value: string value
- *
- * Set string value for specific key
- */
-void connman_dhcp_set_value(struct connman_dhcp *dhcp,
-                                       const char *key, const char *value)
+static void dhcp_set_value(struct connman_dhcp *dhcp,
+                               const char *key, const char *value)
 {
        char **nameservers;
 
@@ -147,13 +104,7 @@ void connman_dhcp_set_value(struct connman_dhcp *dhcp,
        }
 }
 
-/**
- * connman_dhcp_bound:
- * @dhcp: DHCP structure
- *
- * Report successful bound of the interface
- */
-void connman_dhcp_bound(struct connman_dhcp *dhcp)
+static void dhcp_bound(struct connman_dhcp *dhcp)
 {
        struct connman_element *element;
 
@@ -172,114 +123,178 @@ void connman_dhcp_bound(struct connman_dhcp *dhcp)
                connman_element_unref(element);
 }
 
-/**
- * connman_dhcp_renew:
- * @dhcp: DHCP structure
- *
- * Report successful renew of the interface
- */
-void connman_dhcp_renew(struct connman_dhcp *dhcp)
+static void no_lease_cb(GDHCPClient *dhcp_client, gpointer user_data)
 {
-       DBG("dhcp %p", dhcp);
+       struct connman_dhcp *dhcp = user_data;
 
-       connman_element_update(dhcp->element);
+       DBG("No lease available");
+
+       connman_element_set_error(dhcp->element,
+                                       CONNMAN_ELEMENT_ERROR_FAILED);
 }
 
-/**
- * connman_dhcp_release:
- * @dhcp: DHCP structure
- *
- * Report DHCP release of the interface
- */
-void connman_dhcp_release(struct connman_dhcp *dhcp)
+static void lease_lost_cb(GDHCPClient *dhcp_client, gpointer user_data)
 {
-       DBG("dhcp %p", dhcp);
+       DBG("Lease lost");
+}
+
+static void ipv4ll_lost_cb(GDHCPClient *dhcp_client, gpointer user_data)
+{
+       struct connman_dhcp *dhcp = user_data;
+
+       DBG("Lease lost");
 
        connman_element_unregister_children(dhcp->element);
 }
 
-/**
- * connman_dhcp_fail:
- * @dhcp: DHCP structure
- *
- * Report DHCP failure of the interface
- */
-void connman_dhcp_fail(struct connman_dhcp *dhcp)
+static void lease_available_cb(GDHCPClient *dhcp_client, gpointer user_data)
 {
-       DBG("dhcp %p", dhcp);
+       struct connman_dhcp *dhcp = user_data;
+       GList *list, *option = NULL;
+       char *address, *nameservers;
+       size_t ns_strlen = 0;
+
+       DBG("Lease available");
+
+       address = g_dhcp_client_get_address(dhcp_client);
+       if (address != NULL)
+               dhcp_set_value(dhcp, "Address", address);
+       g_free(address);
+
+       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_SUBNET);
+       if (option != NULL)
+               dhcp_set_value(dhcp, "Netmask", option->data);
+
+       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_DNS_SERVER);
+       for (list = option; list; list = list->next)
+               ns_strlen += strlen((char *) list->data) + 2;
+       nameservers = g_try_malloc0(ns_strlen);
+       if (nameservers) {
+               char *ns_index = nameservers;
+
+               for (list = option; list; list = list->next) {
+                       sprintf(ns_index, "%s ", (char *) list->data);
+                       ns_index += strlen((char *) list->data) + 1;
+               }
 
-       connman_element_set_error(dhcp->element,
-                                       CONNMAN_ELEMENT_ERROR_FAILED);
+               dhcp_set_value(dhcp, "Nameserver", nameservers);
+       }
+       g_free(nameservers);
+
+       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_DOMAIN_NAME);
+       if (option != NULL)
+               dhcp_set_value(dhcp, "Domainname", option->data);
+
+       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_ROUTER);
+       if (option != NULL)
+               dhcp_set_value(dhcp, "Gateway", option->data);
+
+       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_HOST_NAME);
+       if (option != NULL)
+               dhcp_set_value(dhcp, "Hostname", option->data);
+
+       option = g_dhcp_client_get_option(dhcp_client, G_DHCP_NTP_SERVER);
+       if (option != NULL)
+               dhcp_set_value(dhcp, "Timeserver", option->data);
+
+       option = g_dhcp_client_get_option(dhcp_client, 252);
+       if (option != NULL)
+               dhcp_set_value(dhcp, "PAC", option->data);
+
+       dhcp_bound(dhcp);
 }
 
-/**
- * connman_dhcp_get_data:
- * @dhcp: DHCP structure
- *
- * Get private DHCP data pointer
- */
-void *connman_dhcp_get_data(struct connman_dhcp *dhcp)
+static void ipv4ll_available_cb(GDHCPClient *dhcp_client, gpointer user_data)
 {
-       return dhcp->driver_data;
+       struct connman_dhcp *dhcp = user_data;
+       char *address, *netmask;
+
+       DBG("IPV4LL available");
+
+       address = g_dhcp_client_get_address(dhcp_client);
+       if (address != NULL)
+               dhcp_set_value(dhcp, "Address", address);
+
+       netmask = g_dhcp_client_get_netmask(dhcp_client);
+       if (netmask != NULL)
+               dhcp_set_value(dhcp, "Netmask", netmask);
+
+       g_free(address);
+       g_free(netmask);
+
+       dhcp_bound(dhcp);
 }
 
-/**
- * connman_dhcp_set_data:
- * @dhcp: DHCP structure
- * @data: data pointer
- *
- * Set private DHCP data pointer
- */
-void connman_dhcp_set_data(struct connman_dhcp *dhcp, void *data)
+static void dhcp_debug(const char *str, void *data)
 {
-       dhcp->driver_data = data;
+       connman_info("%s: %s\n", (const char *) data, str);
 }
 
-static GSList *driver_list = NULL;
-
-static gint compare_priority(gconstpointer a, gconstpointer b)
+static int dhcp_request(struct connman_dhcp *dhcp)
 {
-       const struct connman_dhcp_driver *driver1 = a;
-       const struct connman_dhcp_driver *driver2 = b;
+       GDHCPClient *dhcp_client;
+       GDHCPClientError error;
+       const char *hostname;
+       int index;
 
-       return driver2->priority - driver1->priority;
-}
+       DBG("dhcp %p", dhcp);
 
-/**
- * connman_dhcp_driver_register:
- * @driver: DHCP driver definition
- *
- * Register a new DHCP driver
- *
- * Returns: %0 on success
- */
-int connman_dhcp_driver_register(struct connman_dhcp_driver *driver)
-{
-       DBG("driver %p name %s", driver, driver->name);
+       index = dhcp->index;
 
-       driver_list = g_slist_insert_sorted(driver_list, driver,
-                                                       compare_priority);
+       dhcp_client = g_dhcp_client_new(G_DHCP_IPV4, index, &error);
+       if (error != G_DHCP_CLIENT_ERROR_NONE)
+               return -EINVAL;
 
-       return 0;
+       if (getenv("CONNMAN_DHCP_DEBUG"))
+               g_dhcp_client_set_debug(dhcp_client, dhcp_debug, "DHCP");
+
+       hostname = connman_utsname_get_hostname();
+       if (hostname != NULL)
+               g_dhcp_client_set_send(dhcp_client, G_DHCP_HOST_NAME, hostname);
+
+       g_dhcp_client_set_request(dhcp_client, G_DHCP_HOST_NAME);
+       g_dhcp_client_set_request(dhcp_client, G_DHCP_SUBNET);
+       g_dhcp_client_set_request(dhcp_client, G_DHCP_DNS_SERVER);
+       g_dhcp_client_set_request(dhcp_client, G_DHCP_DOMAIN_NAME);
+       g_dhcp_client_set_request(dhcp_client, G_DHCP_NTP_SERVER);
+       g_dhcp_client_set_request(dhcp_client, G_DHCP_ROUTER);
+       g_dhcp_client_set_request(dhcp_client, 252);
+
+       g_dhcp_client_register_event(dhcp_client,
+                       G_DHCP_CLIENT_EVENT_LEASE_AVAILABLE,
+                                               lease_available_cb, dhcp);
+
+       g_dhcp_client_register_event(dhcp_client,
+                       G_DHCP_CLIENT_EVENT_IPV4LL_AVAILABLE,
+                                               ipv4ll_available_cb, dhcp);
+
+       g_dhcp_client_register_event(dhcp_client,
+                       G_DHCP_CLIENT_EVENT_LEASE_LOST, lease_lost_cb, dhcp);
+
+       g_dhcp_client_register_event(dhcp_client,
+                       G_DHCP_CLIENT_EVENT_IPV4LL_LOST, ipv4ll_lost_cb, dhcp);
+
+       g_dhcp_client_register_event(dhcp_client,
+                       G_DHCP_CLIENT_EVENT_NO_LEASE, no_lease_cb, dhcp);
+
+       dhcp->dhcp_client = dhcp_client;
+
+       return g_dhcp_client_start(dhcp_client);
 }
 
-/**
- * connman_dhcp_driver_unregister:
- * @driver: DHCP driver definition
- *
- * Remove a previously registered DHCP driver
- */
-void connman_dhcp_driver_unregister(struct connman_dhcp_driver *driver)
+static int dhcp_release(struct connman_dhcp *dhcp)
 {
-       DBG("driver %p name %s", driver, driver->name);
+       DBG("dhcp %p", dhcp);
 
-       driver_list = g_slist_remove(driver_list, driver);
+       g_dhcp_client_stop(dhcp->dhcp_client);
+       g_dhcp_client_unref(dhcp->dhcp_client);
+
+       return 0;
 }
 
 static int dhcp_probe(struct connman_element *element)
 {
        struct connman_dhcp *dhcp;
-       GSList *list;
 
        DBG("element %p name %s", element, element->name);
 
@@ -287,7 +302,6 @@ static int dhcp_probe(struct connman_element *element)
        if (dhcp == NULL)
                return -ENOMEM;
 
-       dhcp->refcount = 1;
        dhcp->index = element->index;
        dhcp->state = CONNMAN_DHCP_STATE_IDLE;
 
@@ -295,21 +309,7 @@ static int dhcp_probe(struct connman_element *element)
 
        connman_element_set_data(element, dhcp);
 
-       for (list = driver_list; list; list = list->next) {
-               struct connman_dhcp_driver *driver = list->data;
-
-               DBG("driver %p name %s", driver, driver->name);
-
-               if (driver->request(dhcp) == 0) {
-                       dhcp->driver = driver;
-                       break;
-               }
-       }
-
-       if (dhcp->driver == NULL) {
-               connman_dhcp_unref(dhcp);
-               return -ENOENT;
-       }
+       dhcp_request(dhcp);
 
        return 0;
 }
@@ -322,12 +322,9 @@ static void dhcp_remove(struct connman_element *element)
 
        connman_element_set_data(element, NULL);
 
-       if (dhcp->driver) {
-               dhcp->driver->release(dhcp);
-               dhcp->driver = NULL;
-       }
+       dhcp_release(dhcp);
+       g_free(dhcp);
 
-       connman_dhcp_unref(dhcp);
        connman_element_unref(element);
 }
 
-- 
1.7.3.5

_______________________________________________
connman mailing list
[email protected]
http://lists.connman.net/listinfo/connman

Reply via email to