mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2025-01-20 17:54:05 +01:00
agent: Fix cancelling running request
If the request being cancelled by agent_request_cancel has already been sent over dbus we need to reset pending_id, the timeout, call l_dbus_cancel to avoid the agent_receive_reply callback (and crash) and perhaps start the next request. Alternatively we could only reset the callback and not free the request, then wait until the agent method to return before starting the next request.
This commit is contained in:
parent
55e8d7fdcc
commit
7fd6803c7a
14
src/agent.c
14
src/agent.c
@ -381,9 +381,21 @@ bool agent_request_cancel(unsigned int req_id, int reason)
|
|||||||
if (!request)
|
if (!request)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (!request->message)
|
if (!request->message) {
|
||||||
send_cancel_request(agent, reason);
|
send_cancel_request(agent, reason);
|
||||||
|
|
||||||
|
l_dbus_cancel(dbus_get_bus(), agent->pending_id);
|
||||||
|
|
||||||
|
agent->pending_id = 0;
|
||||||
|
|
||||||
|
if (agent->timeout) {
|
||||||
|
l_timeout_remove(agent->timeout);
|
||||||
|
agent->timeout = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
agent_send_next_request(agent);
|
||||||
|
}
|
||||||
|
|
||||||
agent_request_free(request);
|
agent_request_free(request);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
Loading…
Reference in New Issue
Block a user