mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2025-01-03 19:02:34 +01:00
device: Add public device_disconnect function
This commit is contained in:
parent
f468fceb02
commit
a2771d22f4
43
src/device.c
43
src/device.c
@ -729,6 +729,9 @@ static void device_disconnect_cb(struct netdev *netdev, bool success,
|
||||
struct l_dbus_message *reply;
|
||||
|
||||
if (!success) {
|
||||
if (!device->disconnect_pending)
|
||||
return;
|
||||
|
||||
dbus_pending_reply(&device->disconnect_pending,
|
||||
dbus_error_failed(device->disconnect_pending));
|
||||
return;
|
||||
@ -736,26 +739,27 @@ static void device_disconnect_cb(struct netdev *netdev, bool success,
|
||||
|
||||
device_disassociated(device);
|
||||
|
||||
if (!device->disconnect_pending)
|
||||
return;
|
||||
|
||||
reply = l_dbus_message_new_method_return(device->disconnect_pending);
|
||||
l_dbus_message_set_arguments(reply, "");
|
||||
dbus_pending_reply(&device->disconnect_pending, reply);
|
||||
}
|
||||
|
||||
static struct l_dbus_message *device_disconnect(struct l_dbus *dbus,
|
||||
struct l_dbus_message *message,
|
||||
void *user_data)
|
||||
int device_disconnect(struct device *device)
|
||||
{
|
||||
struct device *device = user_data;
|
||||
struct network *network = device->connected_network;
|
||||
struct l_dbus *dbus = dbus_get_bus();
|
||||
|
||||
if (device->state == DEVICE_STATE_DISCONNECTING)
|
||||
return dbus_error_busy(message);
|
||||
return -EBUSY;
|
||||
|
||||
if (!device->connected_bss)
|
||||
return dbus_error_not_connected(message);
|
||||
return -ENOTCONN;
|
||||
|
||||
if (netdev_disconnect(device->netdev, device_disconnect_cb, device) < 0)
|
||||
return dbus_error_failed(message);
|
||||
return -EIO;
|
||||
|
||||
if (device->state == DEVICE_STATE_CONNECTING)
|
||||
if (device->connect_pending)
|
||||
@ -780,6 +784,29 @@ static struct l_dbus_message *device_disconnect(struct l_dbus *dbus,
|
||||
|
||||
device_enter_state(device, DEVICE_STATE_DISCONNECTING);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static struct l_dbus_message *device_dbus_disconnect(struct l_dbus *dbus,
|
||||
struct l_dbus_message *message,
|
||||
void *user_data)
|
||||
{
|
||||
struct device *device = user_data;
|
||||
int result;
|
||||
|
||||
l_debug("");
|
||||
|
||||
result = device_disconnect(device);
|
||||
|
||||
if (result == -EBUSY)
|
||||
return dbus_error_busy(message);
|
||||
|
||||
if (result == -ENOTCONN)
|
||||
return dbus_error_not_connected(message);
|
||||
|
||||
if (result < 0)
|
||||
return dbus_error_failed(message);
|
||||
|
||||
device->disconnect_pending = l_dbus_message_ref(message);
|
||||
|
||||
return NULL;
|
||||
@ -884,7 +911,7 @@ static void setup_device_interface(struct l_dbus_interface *interface)
|
||||
l_dbus_interface_method(interface, "Scan", 0,
|
||||
device_scan, "", "");
|
||||
l_dbus_interface_method(interface, "Disconnect", 0,
|
||||
device_disconnect, "", "");
|
||||
device_dbus_disconnect, "", "");
|
||||
l_dbus_interface_method(interface, "GetOrderedNetworks", 0,
|
||||
device_get_networks, "a(osns)", "",
|
||||
"networks");
|
||||
|
@ -59,6 +59,7 @@ void device_disassociated(struct device *device);
|
||||
void device_connect_network(struct device *device, struct network *network,
|
||||
struct scan_bss *bss,
|
||||
struct l_dbus_message *message);
|
||||
int device_disconnect(struct device *device);
|
||||
|
||||
struct device *device_create(struct wiphy *wiphy, struct netdev *netdev);
|
||||
void device_remove(struct device *device);
|
||||
|
Loading…
Reference in New Issue
Block a user