blob: 625cb0a12bfd34677d7742f3903fb0a9041ed3ee [file] [log] [blame]
/*
*
* Connection Manager
*
* Copyright (C) 2007-2009 Intel Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
*/
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <glib.h>
#include "connman.h"
#define _DBG_UDEV(fmt, arg...) DBG(DBG_UDEV, fmt, ## arg)
static GSList *device_list = NULL;
static struct connman_device *find_device(int index)
{
GSList *list;
for (list = device_list; list; list = list->next) {
struct connman_device *device = list->data;
if (connman_device_get_index(device) == index)
return device;
}
return NULL;
}
static void detect_newlink(unsigned short type, int index,
unsigned flags, unsigned change)
{
struct connman_device *device;
enum connman_device_type devtype;
_DBG_UDEV("type %d index %d", type, index);
devtype = __connman_inet_get_device_type(index);
switch (devtype) {
case CONNMAN_DEVICE_TYPE_UNKNOWN:
case CONNMAN_DEVICE_TYPE_VENDOR:
case CONNMAN_DEVICE_TYPE_WIMAX:
case CONNMAN_DEVICE_TYPE_BLUETOOTH:
case CONNMAN_DEVICE_TYPE_GPS:
case CONNMAN_DEVICE_TYPE_NOZOMI:
case CONNMAN_DEVICE_TYPE_HUAWEI:
case CONNMAN_DEVICE_TYPE_CELLULAR:
return;
case CONNMAN_DEVICE_TYPE_ETHERNET:
case CONNMAN_DEVICE_TYPE_WIFI:
break;
}
device = find_device(index);
if (device != NULL)
return;
device = connman_inet_create_device(index);
if (device == NULL)
return;
if (connman_device_register(device) < 0) {
connman_device_unref(device);
return;
}
device_list = g_slist_append(device_list, device);
}
static void detect_dellink(unsigned short type, int index,
unsigned flags, unsigned change)
{
struct connman_device *device;
_DBG_UDEV("type %d index %d", type, index);
device = find_device(index);
if (device == NULL)
return;
device_list = g_slist_remove(device_list, device);
connman_device_unregister(device);
connman_device_unref(device);
}
static struct connman_rtnl detect_rtnl = {
RTNL_DEFINE("detect", CONNMAN_RTNL_PRIORITY_LOW),
.newlink = detect_newlink,
.dellink = detect_dellink,
};
char *__connman_udev_get_devtype(const char *ifname)
{
return NULL;
}
void __connman_udev_rfkill(const char *sysname, connman_bool_t blocked)
{
_DBG_UDEV("sysname %s blocked %d", sysname, blocked);
}
int __connman_udev_init(void)
{
_DBG_UDEV("");
return connman_rtnl_register(&detect_rtnl);
}
void __connman_udev_start(void)
{
_DBG_UDEV("");
}
void __connman_udev_cleanup(void)
{
GSList *list;
_DBG_UDEV("");
connman_rtnl_unregister(&detect_rtnl);
for (list = device_list; list; list = list->next) {
struct connman_device *device = list->data;
connman_device_unregister(device);
connman_device_unref(device);
}
g_slist_free(device_list);
device_list = NULL;
}