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