/* * * 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 #endif #include #include #ifndef IFF_LOWER_UP #define IFF_LOWER_UP 0x10000 #endif #include #define CONNMAN_API_SUBJECT_TO_CHANGE #include #include #include #include #include "inet.h" struct ethernet_data { int index; unsigned flags; unsigned int watch; }; static void ethernet_newlink(unsigned flags, unsigned change, void *user_data) { struct connman_device *device = user_data; struct ethernet_data *ethernet = connman_device_get_data(device); DBG("index %d flags %d change %d", ethernet->index, flags, change); if ((ethernet->flags & IFF_UP) != (flags & IFF_UP)) { if (flags & IFF_UP) { DBG("power on"); connman_device_set_powered(device, TRUE); } else { DBG("power off"); connman_device_set_powered(device, FALSE); } } if ((ethernet->flags & IFF_LOWER_UP) != (flags & IFF_LOWER_UP)) { if (flags & IFF_LOWER_UP) { DBG("carrier on"); connman_device_set_carrier(device, TRUE); } else { DBG("carrier off"); connman_device_set_carrier(device, FALSE); } } ethernet->flags = flags; } static int ethernet_probe(struct connman_device *device) { struct ethernet_data *ethernet; DBG("device %p", device); ethernet = g_try_new0(struct ethernet_data, 1); if (ethernet == NULL) return -ENOMEM; connman_device_set_data(device, ethernet); ethernet->index = connman_device_get_index(device); ethernet->flags = 0; ethernet->watch = connman_rtnl_add_newlink_watch(ethernet->index, ethernet_newlink, device); connman_rtnl_send_getlink(); return 0; } static void ethernet_remove(struct connman_device *device) { struct ethernet_data *ethernet = connman_device_get_data(device); DBG("device %p", device); connman_device_set_data(device, NULL); connman_rtnl_remove_watch(ethernet->watch); g_free(ethernet); } static int ethernet_enable(struct connman_device *device) { struct ethernet_data *ethernet = connman_device_get_data(device); DBG("device %p", device); return inet_ifup(ethernet->index); } static int ethernet_disable(struct connman_device *device) { struct ethernet_data *ethernet = connman_device_get_data(device); DBG("device %p", device); return inet_ifdown(ethernet->index); } static struct connman_device_driver ethernet_driver = { .name = "ethernet", .type = CONNMAN_DEVICE_TYPE_ETHERNET, .probe = ethernet_probe, .remove = ethernet_remove, .enable = ethernet_enable, .disable = ethernet_disable, }; static int ethernet_init(void) { return connman_device_driver_register(ðernet_driver); } static void ethernet_exit(void) { connman_device_driver_unregister(ðernet_driver); } CONNMAN_PLUGIN_DEFINE(ethernet, "Ethernet interface plugin", VERSION, CONNMAN_PLUGIN_PRIORITY_DEFAULT, ethernet_init, ethernet_exit)