Remove unneeded plugin for Option HSO support
[framework/connectivity/connman.git] / src / udev-compat.c
1 /*
2  *
3  *  Connection Manager
4  *
5  *  Copyright (C) 2007-2010  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                 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_append(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 void __connman_udev_enable_rfkill_processing(void)
111 {
112 }
113
114 char *__connman_udev_get_devtype(const char *ifname)
115 {
116         return NULL;
117 }
118
119 char *__connman_udev_get_mbm_devnode(const char *ifname)
120 {
121         return NULL;
122 }
123
124 void __connman_udev_rfkill(const char *sysname, connman_bool_t blocked)
125 {
126         DBG("sysname %s blocked %d", sysname, blocked);
127 }
128
129 connman_bool_t __connman_udev_get_blocked(int phyindex)
130 {
131         return FALSE;
132 }
133
134 int __connman_udev_init(void)
135 {
136         DBG("");
137
138         return connman_rtnl_register(&detect_rtnl);
139 }
140
141 void __connman_udev_start(void)
142 {
143         DBG("");
144 }
145
146 void __connman_udev_cleanup(void)
147 {
148         GSList *list;
149
150         DBG("");
151
152         connman_rtnl_unregister(&detect_rtnl);
153
154         for (list = device_list; list; list = list->next) {
155                 struct connman_device *device = list->data;
156
157                 connman_device_unregister(device);
158                 connman_device_unref(device);
159         }
160
161         g_slist_free(device_list);
162         device_list = NULL;
163 }