Imported Upstream version 1.24
[platform/upstream/connman.git] / src / detect.c
1 /*
2  *
3  *  Connection Manager
4  *
5  *  Copyright (C) 2007-2013  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_rtnl_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_BLUETOOTH:
60         case CONNMAN_DEVICE_TYPE_CELLULAR:
61         case CONNMAN_DEVICE_TYPE_GPS:
62                 return;
63         case CONNMAN_DEVICE_TYPE_ETHERNET:
64         case CONNMAN_DEVICE_TYPE_WIFI:
65         case CONNMAN_DEVICE_TYPE_GADGET:
66                 break;
67         }
68
69         device = find_device(index);
70         if (device)
71                 return;
72
73         device = connman_device_create_from_index(index);
74         if (!device)
75                 return;
76
77         if (connman_device_register(device) < 0) {
78                 connman_device_unref(device);
79                 return;
80         }
81
82         device_list = g_slist_prepend(device_list, device);
83 }
84
85 static void detect_dellink(unsigned short type, int index,
86                                         unsigned flags, unsigned change)
87 {
88         struct connman_device *device;
89
90         DBG("type %d index %d", type, index);
91
92         device = find_device(index);
93         if (!device)
94                 return;
95
96         device_list = g_slist_remove(device_list, device);
97
98         connman_device_unregister(device);
99         connman_device_unref(device);
100 }
101
102 static struct connman_rtnl detect_rtnl = {
103         .name           = "detect",
104         .priority       = CONNMAN_RTNL_PRIORITY_LOW,
105         .newlink        = detect_newlink,
106         .dellink        = detect_dellink,
107 };
108
109 int __connman_detect_init(void)
110 {
111         DBG("");
112
113         return connman_rtnl_register(&detect_rtnl);
114 }
115
116 void __connman_detect_cleanup(void)
117 {
118         GSList *list;
119
120         DBG("");
121
122         connman_rtnl_unregister(&detect_rtnl);
123
124         for (list = device_list; list; list = list->next) {
125                 struct connman_device *device = list->data;
126
127                 connman_device_unregister(device);
128                 connman_device_unref(device);
129         }
130
131         g_slist_free(device_list);
132         device_list = NULL;
133 }