mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2026-05-22 18:40:43 +03:00
Illumos #3996
3996 want a libzfs_core API to rollback to latest snapshot Reviewed by: Christopher Siden <christopher.siden@delphix.com> Reviewed by: Adam Leventhal <ahl@delphix.com> Reviewed by: George Wilson <george.wilson@delphix.com> Reviewed by: Andy Stormont <andyjstormont@gmail.com> Approved by: Richard Lowe <richlowe@richlowe.net> References: https://www.illumos.org/issues/3996 illumos/illumos-gate@a7027df17f Ported-by: Richard Yao <ryao@gentoo.org> Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Issue #1775
This commit is contained in:
committed by
Brian Behlendorf
parent
5d1f7fb647
commit
46ba1e59d3
@@ -1703,6 +1703,7 @@ dsl_dataset_handoff_check(dsl_dataset_t *ds, void *owner, dmu_tx_t *tx)
|
||||
typedef struct dsl_dataset_rollback_arg {
|
||||
const char *ddra_fsname;
|
||||
void *ddra_owner;
|
||||
nvlist_t *ddra_result;
|
||||
} dsl_dataset_rollback_arg_t;
|
||||
|
||||
static int
|
||||
@@ -1774,9 +1775,13 @@ dsl_dataset_rollback_sync(void *arg, dmu_tx_t *tx)
|
||||
dsl_pool_t *dp = dmu_tx_pool(tx);
|
||||
dsl_dataset_t *ds, *clone;
|
||||
uint64_t cloneobj;
|
||||
char namebuf[ZFS_MAXNAMELEN];
|
||||
|
||||
VERIFY0(dsl_dataset_hold(dp, ddra->ddra_fsname, FTAG, &ds));
|
||||
|
||||
dsl_dataset_name(ds->ds_prev, namebuf);
|
||||
fnvlist_add_string(ddra->ddra_result, "target", namebuf);
|
||||
|
||||
cloneobj = dsl_dataset_create_sync(ds->ds_dir, "%rollback",
|
||||
ds->ds_prev, DS_CREATE_FLAG_NODIRTY, kcred, tx);
|
||||
|
||||
@@ -1792,8 +1797,11 @@ dsl_dataset_rollback_sync(void *arg, dmu_tx_t *tx)
|
||||
}
|
||||
|
||||
/*
|
||||
* If owner != NULL:
|
||||
* Rolls back the given filesystem or volume to the most recent snapshot.
|
||||
* The name of the most recent snapshot will be returned under key "target"
|
||||
* in the result nvlist.
|
||||
*
|
||||
* If owner != NULL:
|
||||
* - The existing dataset MUST be owned by the specified owner at entry
|
||||
* - Upon return, dataset will still be held by the same owner, whether we
|
||||
* succeed or not.
|
||||
@@ -1802,15 +1810,16 @@ dsl_dataset_rollback_sync(void *arg, dmu_tx_t *tx)
|
||||
* notes above zfs_suspend_fs() for further details.
|
||||
*/
|
||||
int
|
||||
dsl_dataset_rollback(const char *fsname, void *owner)
|
||||
dsl_dataset_rollback(const char *fsname, void *owner, nvlist_t *result)
|
||||
{
|
||||
dsl_dataset_rollback_arg_t ddra;
|
||||
|
||||
ddra.ddra_fsname = fsname;
|
||||
ddra.ddra_owner = owner;
|
||||
ddra.ddra_result = result;
|
||||
|
||||
return (dsl_sync_task(fsname, dsl_dataset_rollback_check,
|
||||
dsl_dataset_rollback_sync, (void *)&ddra, 1));
|
||||
dsl_dataset_rollback_sync, &ddra, 1));
|
||||
}
|
||||
|
||||
struct promotenode {
|
||||
|
||||
Reference in New Issue
Block a user