summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSamuel Ortiz <sameo@linux.intel.com>2010-08-03 16:52:16 +0200
committerSamuel Ortiz <sameo@linux.intel.com>2010-08-03 17:32:04 +0200
commitdb65803292a9f87f15ec5ab704e2d294f5225c79 (patch)
tree667ee3f767b5b1f6efaa12e452e76bfb0c86eed0 /src
parent64439d8d3edfe4fe7d2423dfa1156097fa1869bd (diff)
downloadconnman-db65803292a9f87f15ec5ab704e2d294f5225c79.tar.gz
connman-db65803292a9f87f15ec5ab704e2d294f5225c79.tar.bz2
connman-db65803292a9f87f15ec5ab704e2d294f5225c79.zip
Use __connman_device_[enable|disable] from set_powered
Diffstat (limited to 'src')
-rw-r--r--src/device.c143
1 files changed, 52 insertions, 91 deletions
diff --git a/src/device.c b/src/device.c
index aab0c83d..33ee896e 100644
--- a/src/device.c
+++ b/src/device.c
@@ -194,53 +194,73 @@ static void powered_changed(struct connman_device *device)
DBUS_TYPE_BOOLEAN, &device->powered);
}
-static int set_powered(struct connman_device *device, connman_bool_t powered)
+int __connman_device_enable(struct connman_device *device)
{
- struct connman_device_driver *driver = device->driver;
int err;
- DBG("device %p powered %d", device, powered);
+ DBG("device %p", device);
- if (device->powered_pending == powered)
+ if (!device->driver || !device->driver->enable)
+ return -EOPNOTSUPP;
+
+ if (device->powered_pending == TRUE)
return -EALREADY;
- if (!driver)
- return -EINVAL;
+ device->powered_pending = TRUE;
- if (powered == TRUE) {
- if (driver->enable) {
- device->powered_pending = powered;
+ err = device->driver->enable(device);
+ if (err < 0)
+ return err;
- err = driver->enable(device);
- if (err == 0)
- __connman_technology_enable_device(device);
- } else
- err = -EINVAL;
- } else {
- device->powered_pending = powered;
+ device->powered = TRUE;
- device->reconnect = FALSE;
+ __connman_technology_enable_device(device);
- clear_scan_trigger(device);
+ return 0;
+}
- g_hash_table_remove_all(device->networks);
+int __connman_device_disable(struct connman_device *device)
+{
+ int err;
- if (driver->disable) {
- err = driver->disable(device);
- if (err == 0)
- __connman_technology_disable_device(device);
- } else
- err = -EINVAL;
- }
+ DBG("device %p", device);
- if (err == 0) {
- device->powered = powered;
+ if (!device->driver || !device->driver->disable)
+ return -EOPNOTSUPP;
- if (device->registered == TRUE)
- powered_changed(device);
- }
+ if (device->powered == FALSE)
+ return -ENOLINK;
- return err;
+ if (device->powered_pending == FALSE)
+ return -EALREADY;
+
+ device->powered_pending = FALSE;
+
+ device->reconnect = FALSE;
+
+ clear_scan_trigger(device);
+
+ g_hash_table_remove_all(device->networks);
+
+ err = device->driver->disable(device);
+ if (err < 0)
+ return err;
+
+ device->powered = FALSE;
+
+ __connman_technology_disable_device(device);
+
+ return 0;
+}
+
+static int set_powered(struct connman_device *device, connman_bool_t powered)
+{
+ DBG("device %p powered %d", device, powered);
+
+ if (powered == TRUE)
+ return __connman_device_enable(device);
+ else
+ return __connman_device_disable(device);
}
void __connman_device_list(DBusMessageIter *iter, void *user_data)
@@ -1029,31 +1049,6 @@ int __connman_device_scan(struct connman_device *device)
return device->driver->scan(device);
}
-int __connman_device_enable(struct connman_device *device)
-{
- int err;
-
- DBG("device %p", device);
-
- if (!device->driver || !device->driver->enable)
- return -EOPNOTSUPP;
-
- if (device->powered_pending == TRUE)
- return -EALREADY;
-
- device->powered_pending = TRUE;
-
- err = device->driver->enable(device);
- if (err < 0)
- return err;
-
- device->powered = TRUE;
-
- __connman_technology_enable_device(device);
-
- return 0;
-}
-
int __connman_device_enable_persistent(struct connman_device *device)
{
int err;
@@ -1074,40 +1069,6 @@ int __connman_device_enable_persistent(struct connman_device *device)
return err;
}
-int __connman_device_disable(struct connman_device *device)
-{
- int err;
-
- DBG("device %p", device);
-
- if (!device->driver || !device->driver->disable)
- return -EOPNOTSUPP;
-
- if (device->powered == FALSE)
- return -ENOLINK;
-
- if (device->powered_pending == FALSE)
- return -EALREADY;
-
- device->powered_pending = FALSE;
-
- device->reconnect = FALSE;
-
- clear_scan_trigger(device);
-
- g_hash_table_remove_all(device->networks);
-
- err = device->driver->disable(device);
- if (err < 0)
- return err;
-
- device->powered = FALSE;
-
- __connman_technology_disable_device(device);
-
- return 0;
-}
-
int __connman_device_disable_persistent(struct connman_device *device)
{
DBG("device %p", device);