Add function to get index value from DHCP structure
[framework/connectivity/connman.git] / src / udev-compat.c
1 /*
2  *
3  *  Connection Manager
4  *
5  *  Copyright (C) 2007-2009  Intel Corporation. All rights reserved.
6  *
7  *  This program is free software; you can redistribute it and/or modify
8  *  it under the terms of the GNU General Public License version 2 as
9  *  published by the Free Software Foundation.
10  *
11  *  This program is distributed in the hope that it will be useful,
12  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  *  GNU General Public License for more details.
15  *
16  *  You should have received a copy of the GNU General Public License
17  *  along with this program; if not, write to the Free Software
18  *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19  *
20  */
21
22 #ifdef HAVE_CONFIG_H
23 #include <config.h>
24 #endif
25
26 #include <glib.h>
27
28 #include "connman.h"
29
30 static GSList *device_list = NULL;
31
32 static struct connman_device *find_device(int index)
33 {
34         GSList *list;
35
36         for (list = device_list; list; list = list->next) {
37                 struct connman_device *device = list->data;
38
39                 if (connman_device_get_index(device) == index)
40                         return device;
41         }
42
43         return NULL;
44 }
45
46 static void detect_newlink(unsigned short type, int index,
47                                         unsigned flags, unsigned change)
48 {
49         struct connman_device *device;
50         enum connman_device_type devtype;
51
52         DBG("type %d index %d", type, index);
53
54         devtype = __connman_inet_get_device_type(index);
55
56         switch (devtype) {
57         case CONNMAN_DEVICE_TYPE_UNKNOWN:
58         case CONNMAN_DEVICE_TYPE_VENDOR:
59         case CONNMAN_DEVICE_TYPE_WIMAX:
60         case CONNMAN_DEVICE_TYPE_BLUETOOTH:
61         case CONNMAN_DEVICE_TYPE_CELLULAR:
62         case CONNMAN_DEVICE_TYPE_GPS:
63                 return;
64         case CONNMAN_DEVICE_TYPE_ETHERNET:
65         case CONNMAN_DEVICE_TYPE_WIFI:
66         case CONNMAN_DEVICE_TYPE_MBM:
67         case CONNMAN_DEVICE_TYPE_HSO:
68                 break;
69         }
70
71         device = find_device(index);
72         if (device != NULL)
73                 return;
74
75         device = connman_inet_create_device(index);
76         if (device == NULL)
77                 return;
78
79         if (connman_device_register(device) < 0) {
80                 connman_device_unref(device);
81                 return;
82         }
83
84         device_list = g_slist_append(device_list, device);
85 }
86
87 static void detect_dellink(unsigned short type, int index,
88                                         unsigned flags, unsigned change)
89 {
90         struct connman_device *device;
91
92         DBG("type %d index %d", type, index);
93
94         device = find_device(index);
95         if (device == NULL)
96                 return;
97
98         device_list = g_slist_remove(device_list, device);
99
100         connman_device_unregister(device);
101         connman_device_unref(device);
102 }
103
104 static struct connman_rtnl detect_rtnl = {
105         .name           = "detect",
106         .priority       = CONNMAN_RTNL_PRIORITY_LOW,
107         .newlink        = detect_newlink,
108         .dellink        = detect_dellink,
109 };
110
111 void __connman_udev_enable_rfkill_processing(void)
112 {
113 }
114
115 char *__connman_udev_get_devtype(const char *ifname)
116 {
117         return NULL;
118 }
119
120 char *__connman_udev_get_mbm_devnode(const char *ifname)
121 {
122         return NULL;
123 }
124
125 void __connman_udev_rfkill(const char *sysname, connman_bool_t blocked)
126 {
127         DBG("sysname %s blocked %d", sysname, blocked);
128 }
129
130 int __connman_udev_init(void)
131 {
132         DBG("");
133
134         return connman_rtnl_register(&detect_rtnl);
135 }
136
137 void __connman_udev_start(void)
138 {
139         DBG("");
140 }
141
142 void __connman_udev_cleanup(void)
143 {
144         GSList *list;
145
146         DBG("");
147
148         connman_rtnl_unregister(&detect_rtnl);
149
150         for (list = device_list; list; list = list->next) {
151                 struct connman_device *device = list->data;
152
153                 connman_device_unregister(device);
154                 connman_device_unref(device);
155         }
156
157         g_slist_free(device_list);
158         device_list = NULL;
159 }