mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
Pageant: actually link requests on to their queues.
When I create any class that implements PageantAsyncOp, I had intended to link its pao.cr list node on to the list in the appropriate PageantClientInfo, so that if that PageantClientInfo was destroyed prematurely (e.g. an agent connection was abruptly closed), we could destroy all the pending requests containing a pointer to it. I did this linking by setting the linked-list fields in pao.cr to point to the appropriate places in the existing list - but I didn't modify the pointer fields _in_ the existing list to point to the new operation at all. So nothing ever actually got linked on to any of those queues!
This commit is contained in:
parent
6dfe941a73
commit
e7dd2421cf
@ -836,6 +836,7 @@ static PageantAsyncOp *pageant_make_op(
|
|||||||
so->pao.info = pc->info;
|
so->pao.info = pc->info;
|
||||||
so->pao.cr.prev = pc->info->head.prev;
|
so->pao.cr.prev = pc->info->head.prev;
|
||||||
so->pao.cr.next = &pc->info->head;
|
so->pao.cr.next = &pc->info->head;
|
||||||
|
so->pao.cr.prev->next = so->pao.cr.next->prev = &so->pao.cr;
|
||||||
so->pao.reqid = reqid;
|
so->pao.reqid = reqid;
|
||||||
so->pk = pk;
|
so->pk = pk;
|
||||||
so->pkr.prev = so->pkr.next = NULL;
|
so->pkr.prev = so->pkr.next = NULL;
|
||||||
@ -1353,6 +1354,7 @@ static PageantAsyncOp *pageant_make_op(
|
|||||||
io->pao.info = pc->info;
|
io->pao.info = pc->info;
|
||||||
io->pao.cr.prev = pc->info->head.prev;
|
io->pao.cr.prev = pc->info->head.prev;
|
||||||
io->pao.cr.next = &pc->info->head;
|
io->pao.cr.next = &pc->info->head;
|
||||||
|
io->pao.cr.prev->next = io->pao.cr.next->prev = &io->pao.cr;
|
||||||
io->pao.reqid = reqid;
|
io->pao.reqid = reqid;
|
||||||
io->response = sb;
|
io->response = sb;
|
||||||
io->crLine = 0;
|
io->crLine = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user