gdhcp: Use gcc atomics instead glib's ones
[framework/connectivity/connman.git] / gdhcp / gdhcp.h
index 052ab90..d89446e 100644 (file)
@@ -45,14 +45,17 @@ typedef enum {
 
 typedef enum {
        G_DHCP_CLIENT_EVENT_LEASE_AVAILABLE,
+       G_DHCP_CLIENT_EVENT_IPV4LL_AVAILABLE,
        G_DHCP_CLIENT_EVENT_NO_LEASE,
        G_DHCP_CLIENT_EVENT_LEASE_LOST,
+       G_DHCP_CLIENT_EVENT_IPV4LL_LOST,
        G_DHCP_CLIENT_EVENT_ADDRESS_CONFLICT,
 } GDHCPClientEvent;
 
 typedef enum {
        G_DHCP_IPV4,
        G_DHCP_IPV6,
+       G_DHCP_IPV4LL,
 } GDHCPType;
 
 #define G_DHCP_SUBNET          0x01
@@ -70,7 +73,7 @@ typedef void (*GDHCPDebugFunc)(const char *str, gpointer user_data);
 GDHCPClient *g_dhcp_client_new(GDHCPType type, int index,
                                                GDHCPClientError *error);
 
-int g_dhcp_client_start(GDHCPClient *client);
+int g_dhcp_client_start(GDHCPClient *client, const char *last_address);
 void g_dhcp_client_stop(GDHCPClient *client);
 
 GDHCPClient *g_dhcp_client_ref(GDHCPClient *client);
@@ -88,6 +91,7 @@ GDHCPClientError g_dhcp_client_set_send(GDHCPClient *client,
                                                const char *option_value);
 
 char *g_dhcp_client_get_address(GDHCPClient *client);
+char *g_dhcp_client_get_netmask(GDHCPClient *client);
 GList *g_dhcp_client_get_option(GDHCPClient *client,
                                                unsigned char option_code);
 int g_dhcp_client_get_index(GDHCPClient *client);