|
|
ad412c |
From 12708a0fc9f3da1d1cc492bb3a49844b02e76b40 Mon Sep 17 00:00:00 2001
|
|
|
ad412c |
From: Uri Lublin <uril@redhat.com>
|
|
|
ad412c |
Date: Sun, 11 Oct 2020 20:59:17 +0300
|
|
|
ad412c |
Subject: [PATCH vd_agent_linux 17/17] vdagentd: do not allow to use an already
|
|
|
ad412c |
used file-xfer id
|
|
|
ad412c |
|
|
|
ad412c |
Signed-off-by: Uri Lublin <uril@redhat.com>
|
|
|
ad412c |
Acked-by: Frediano Ziglio <fziglio@redhat.com>
|
|
|
ad412c |
---
|
|
|
ad412c |
src/vdagentd/vdagentd.c | 7 +++++++
|
|
|
ad412c |
1 file changed, 7 insertions(+)
|
|
|
ad412c |
|
|
|
ad412c |
diff --git a/src/vdagentd/vdagentd.c b/src/vdagentd/vdagentd.c
|
|
|
ad412c |
index 9243cfb..279e7c3 100644
|
|
|
ad412c |
--- a/src/vdagentd/vdagentd.c
|
|
|
ad412c |
+++ b/src/vdagentd/vdagentd.c
|
|
|
ad412c |
@@ -404,6 +404,13 @@ static void do_client_file_xfer(VirtioPort *vport,
|
|
|
ad412c |
"Cancelling client file-xfer request %u",
|
|
|
ad412c |
s->id, VD_AGENT_FILE_XFER_STATUS_ERROR, (void*) &error, detail_size);
|
|
|
ad412c |
return;
|
|
|
ad412c |
+ } else if (g_hash_table_lookup(active_xfers, GUINT_TO_POINTER(s->id)) != NULL) {
|
|
|
ad412c |
+ // id is already used -- client is confused
|
|
|
ad412c |
+ send_file_xfer_status(vport,
|
|
|
ad412c |
+ "File transfer ID is already used. "
|
|
|
ad412c |
+ "Cancelling client file-xfer request %u",
|
|
|
ad412c |
+ s->id, VD_AGENT_FILE_XFER_STATUS_ERROR, NULL, 0);
|
|
|
ad412c |
+ return;
|
|
|
ad412c |
}
|
|
|
ad412c |
msg_type = VDAGENTD_FILE_XFER_START;
|
|
|
ad412c |
id = s->id;
|
|
|
ad412c |
--
|
|
|
ad412c |
2.26.2
|
|
|
ad412c |
|