2022-06-08 14:10:51 +03:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Fabian Ebner <f.ebner@proxmox.com>
|
|
|
|
Date: Wed, 25 May 2022 13:59:37 +0200
|
|
|
|
Subject: [PATCH] PVE-Backup: create jobs: correctly cancel in error scenario
|
|
|
|
|
|
|
|
The first call to job_cancel_sync() will cancel and free all jobs in
|
|
|
|
the transaction, so ensure that it's called only once and get rid of
|
|
|
|
the job_unref() that would operate on freed memory.
|
|
|
|
|
|
|
|
It's also necessary to NULL backup_state.pbs in the error scenario,
|
|
|
|
because a subsequent backup_cancel QMP call (as happens in PVE when
|
|
|
|
the backup QMP command fails) would try to call proxmox_backup_abort()
|
|
|
|
and run into a segfault.
|
|
|
|
|
2022-12-14 17:16:32 +03:00
|
|
|
Signed-off-by: Fiona Ebner <f.ebner@proxmox.com>
|
2022-06-08 14:10:51 +03:00
|
|
|
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
|
2022-12-14 17:16:32 +03:00
|
|
|
[FE: adapt for new job lock mechanism replacing AioContext locks]
|
|
|
|
Signed-off-by: Fiona Ebner <f.ebner@proxmox.com>
|
2022-06-08 14:10:51 +03:00
|
|
|
---
|
|
|
|
pve-backup.c | 10 ++++++++--
|
|
|
|
1 file changed, 8 insertions(+), 2 deletions(-)
|
|
|
|
|
|
|
|
diff --git a/pve-backup.c b/pve-backup.c
|
2022-12-14 17:16:32 +03:00
|
|
|
index 262e7d3894..fde3554133 100644
|
2022-06-08 14:10:51 +03:00
|
|
|
--- a/pve-backup.c
|
|
|
|
+++ b/pve-backup.c
|
2022-12-14 17:16:32 +03:00
|
|
|
@@ -503,6 +503,11 @@ static void create_backup_jobs_bh(void *opaque) {
|
2022-06-08 14:10:51 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
if (*errp) {
|
|
|
|
+ /*
|
|
|
|
+ * It's enough to cancel one job in the transaction, the rest will
|
|
|
|
+ * follow automatically.
|
|
|
|
+ */
|
|
|
|
+ bool canceled = false;
|
|
|
|
l = backup_state.di_list;
|
|
|
|
while (l) {
|
|
|
|
PVEBackupDevInfo *di = (PVEBackupDevInfo *)l->data;
|
2022-12-14 17:16:32 +03:00
|
|
|
@@ -513,11 +518,11 @@ static void create_backup_jobs_bh(void *opaque) {
|
2022-06-08 14:10:51 +03:00
|
|
|
di->target = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
- if (di->job) {
|
|
|
|
+ if (!canceled && di->job) {
|
2022-12-14 17:16:32 +03:00
|
|
|
WITH_JOB_LOCK_GUARD() {
|
|
|
|
job_cancel_sync_locked(&di->job->job, true);
|
|
|
|
- job_unref_locked(&di->job->job);
|
|
|
|
}
|
2022-06-08 14:10:51 +03:00
|
|
|
+ canceled = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-12-14 17:16:32 +03:00
|
|
|
@@ -943,6 +948,7 @@ err:
|
2022-06-08 14:10:51 +03:00
|
|
|
|
|
|
|
if (pbs) {
|
|
|
|
proxmox_backup_disconnect(pbs);
|
|
|
|
+ backup_state.pbs = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (backup_dir) {
|