diff options
author | Jennifer Herbert <Jennifer.Herbert@citrix.com> | 2015-02-05 09:45:40 -0500 |
---|---|---|
committer | David Vrabel <david.vrabel@citrix.com> | 2015-02-05 10:04:46 -0500 |
commit | a2e75bc2ee207351e6806e77a5379c6c1dd4598a (patch) | |
tree | 3d2deab1b547ecb3fb46d4e0ce6bf46a221d6ae4 /drivers/xen/xenbus | |
parent | dab069c61aa386f6a46c620f3a1075a4818f285b (diff) |
xenbus: Add proper handling of XS_ERROR from Xenbus for transactions.
If Xenstore sends back a XS_ERROR for TRANSACTION_END, the driver BUGs
because it cannot find the matching transaction in the list. For
TRANSACTION_START, it leaks memory.
Check the message as returned from xenbus_dev_request_and_reply(), and
clean up for TRANSACTION_START or discard the error for
TRANSACTION_END.
Signed-off-by: Jennifer Herbert <Jennifer.Herbert@citrix.com>
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
Diffstat (limited to 'drivers/xen/xenbus')
-rw-r--r-- | drivers/xen/xenbus/xenbus_dev_frontend.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/drivers/xen/xenbus/xenbus_dev_frontend.c b/drivers/xen/xenbus/xenbus_dev_frontend.c index 85534ea63555..9433e46518c8 100644 --- a/drivers/xen/xenbus/xenbus_dev_frontend.c +++ b/drivers/xen/xenbus/xenbus_dev_frontend.c | |||
@@ -326,10 +326,13 @@ static int xenbus_write_transaction(unsigned msg_type, | |||
326 | } | 326 | } |
327 | 327 | ||
328 | if (msg_type == XS_TRANSACTION_START) { | 328 | if (msg_type == XS_TRANSACTION_START) { |
329 | trans->handle.id = simple_strtoul(reply, NULL, 0); | 329 | if (u->u.msg.type == XS_ERROR) |
330 | 330 | kfree(trans); | |
331 | list_add(&trans->list, &u->transactions); | 331 | else { |
332 | } else if (msg_type == XS_TRANSACTION_END) { | 332 | trans->handle.id = simple_strtoul(reply, NULL, 0); |
333 | list_add(&trans->list, &u->transactions); | ||
334 | } | ||
335 | } else if (u->u.msg.type == XS_TRANSACTION_END) { | ||
333 | list_for_each_entry(trans, &u->transactions, list) | 336 | list_for_each_entry(trans, &u->transactions, list) |
334 | if (trans->handle.id == u->u.msg.tx_id) | 337 | if (trans->handle.id == u->u.msg.tx_id) |
335 | break; | 338 | break; |