mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2025-01-20 17:54:05 +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;
|
struct l_dbus_message *reply;
|
||||||
|
|
||||||
if (!success) {
|
if (!success) {
|
||||||
|
if (!device->disconnect_pending)
|
||||||
|
return;
|
||||||
|
|
||||||
dbus_pending_reply(&device->disconnect_pending,
|
dbus_pending_reply(&device->disconnect_pending,
|
||||||
dbus_error_failed(device->disconnect_pending));
|
dbus_error_failed(device->disconnect_pending));
|
||||||
return;
|
return;
|
||||||
@ -736,26 +739,27 @@ static void device_disconnect_cb(struct netdev *netdev, bool success,
|
|||||||
|
|
||||||
device_disassociated(device);
|
device_disassociated(device);
|
||||||
|
|
||||||
|
if (!device->disconnect_pending)
|
||||||
|
return;
|
||||||
|
|
||||||
reply = l_dbus_message_new_method_return(device->disconnect_pending);
|
reply = l_dbus_message_new_method_return(device->disconnect_pending);
|
||||||
l_dbus_message_set_arguments(reply, "");
|
l_dbus_message_set_arguments(reply, "");
|
||||||
dbus_pending_reply(&device->disconnect_pending, reply);
|
dbus_pending_reply(&device->disconnect_pending, reply);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct l_dbus_message *device_disconnect(struct l_dbus *dbus,
|
int device_disconnect(struct device *device)
|
||||||
struct l_dbus_message *message,
|
|
||||||
void *user_data)
|
|
||||||
{
|
{
|
||||||
struct device *device = user_data;
|
|
||||||
struct network *network = device->connected_network;
|
struct network *network = device->connected_network;
|
||||||
|
struct l_dbus *dbus = dbus_get_bus();
|
||||||
|
|
||||||
if (device->state == DEVICE_STATE_DISCONNECTING)
|
if (device->state == DEVICE_STATE_DISCONNECTING)
|
||||||
return dbus_error_busy(message);
|
return -EBUSY;
|
||||||
|
|
||||||
if (!device->connected_bss)
|
if (!device->connected_bss)
|
||||||
return dbus_error_not_connected(message);
|
return -ENOTCONN;
|
||||||
|
|
||||||
if (netdev_disconnect(device->netdev, device_disconnect_cb, device) < 0)
|
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->state == DEVICE_STATE_CONNECTING)
|
||||||
if (device->connect_pending)
|
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);
|
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);
|
device->disconnect_pending = l_dbus_message_ref(message);
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -884,7 +911,7 @@ static void setup_device_interface(struct l_dbus_interface *interface)
|
|||||||
l_dbus_interface_method(interface, "Scan", 0,
|
l_dbus_interface_method(interface, "Scan", 0,
|
||||||
device_scan, "", "");
|
device_scan, "", "");
|
||||||
l_dbus_interface_method(interface, "Disconnect", 0,
|
l_dbus_interface_method(interface, "Disconnect", 0,
|
||||||
device_disconnect, "", "");
|
device_dbus_disconnect, "", "");
|
||||||
l_dbus_interface_method(interface, "GetOrderedNetworks", 0,
|
l_dbus_interface_method(interface, "GetOrderedNetworks", 0,
|
||||||
device_get_networks, "a(osns)", "",
|
device_get_networks, "a(osns)", "",
|
||||||
"networks");
|
"networks");
|
||||||
|
@ -59,6 +59,7 @@ void device_disassociated(struct device *device);
|
|||||||
void device_connect_network(struct device *device, struct network *network,
|
void device_connect_network(struct device *device, struct network *network,
|
||||||
struct scan_bss *bss,
|
struct scan_bss *bss,
|
||||||
struct l_dbus_message *message);
|
struct l_dbus_message *message);
|
||||||
|
int device_disconnect(struct device *device);
|
||||||
|
|
||||||
struct device *device_create(struct wiphy *wiphy, struct netdev *netdev);
|
struct device *device_create(struct wiphy *wiphy, struct netdev *netdev);
|
||||||
void device_remove(struct device *device);
|
void device_remove(struct device *device);
|
||||||
|
Loading…
Reference in New Issue
Block a user