Commit 790669cc authored by Marcin Dziegielewski's avatar Marcin Dziegielewski Committed by Jim Harris
Browse files

lib/bdev/ocf: increase capabilites of vbdev_ocf_mngt_stop function



In current code there is no possibility to clean up vbdev in case
of error during management path. This patch introduces new version of
vbdev_ocf_mngt_stop function, now developer can pass handle to
path with rollback functions and therefore clean up not full initialised
vbdev instance. Changes in this path also allows to pass status explicitly
to vbdev_ocf_mngt_stop function.

Signed-off-by: default avatarMarcin Dziegielewski <marcin.dziegielewski@intel.com>
Change-Id: Ie9684981e48d24b3e55e4b1ab828dc8c01baa838
Reviewed-on: https://review.gerrithub.io/c/spdk/spdk/+/468471


Tested-by: default avatarSPDK CI Jenkins <sys_sgci@intel.com>
Reviewed-by: default avatarJim Harris <james.r.harris@intel.com>
Reviewed-by: default avatarTomasz Zawadzki <tomasz.zawadzki@intel.com>
parent 20894340
Loading
Loading
Loading
Loading
+19 −2
Original line number Diff line number Diff line
@@ -129,8 +129,19 @@ vbdev_ocf_mngt_poll(struct vbdev_ocf *vbdev, vbdev_ocf_mngt_fn fn)
}

void
vbdev_ocf_mngt_stop(struct vbdev_ocf *vbdev)
vbdev_ocf_mngt_stop(struct vbdev_ocf *vbdev, vbdev_ocf_mngt_fn *rollback_path, int status)
{
	if (status) {
		vbdev->mngt_ctx.status = status;
	}

	if (vbdev->mngt_ctx.status && rollback_path) {
		vbdev->mngt_ctx.poller_fn = NULL;
		vbdev->mngt_ctx.current_step = rollback_path;
		(*vbdev->mngt_ctx.current_step)(vbdev);
		return;
	}

	spdk_poller_unregister(&vbdev->mngt_ctx.poller);

	if (vbdev->mngt_ctx.cb) {
@@ -158,5 +169,11 @@ vbdev_ocf_mngt_continue(struct vbdev_ocf *vbdev, int status)
		return;
	}

	vbdev_ocf_mngt_stop(vbdev);
	vbdev_ocf_mngt_stop(vbdev, NULL, 0);
}

int
vbdev_ocf_mngt_get_status(struct vbdev_ocf *vbdev)
{
	return vbdev->mngt_ctx.status;
}
+6 −2
Original line number Diff line number Diff line
@@ -57,7 +57,11 @@ void vbdev_ocf_mngt_poll(struct vbdev_ocf *vbdev, vbdev_ocf_mngt_fn fn);
 * If next function is NULL, finish management operation and invoke callback */
void vbdev_ocf_mngt_continue(struct vbdev_ocf *vbdev, int status);

/* Stop the execution and invoke callback with last status returned */
void vbdev_ocf_mngt_stop(struct vbdev_ocf *vbdev);
/* Stop the execution, if status is non zero set it,
 * if rollback function is not null invoke rollback
 * else invoke callback with last status returned */
void vbdev_ocf_mngt_stop(struct vbdev_ocf *vbdev, vbdev_ocf_mngt_fn *rollback_path, int status);

/* Get status */
int vbdev_ocf_mngt_get_status(struct vbdev_ocf *vbdev);
#endif
+4 −8
Original line number Diff line number Diff line
@@ -986,8 +986,7 @@ start_cache(struct vbdev_ocf *vbdev)
	int rc;

	if (vbdev->ocf_cache) {
		vbdev->mngt_ctx.status = -EALREADY;
		vbdev_ocf_mngt_stop(vbdev);
		vbdev_ocf_mngt_stop(vbdev, NULL, -EALREADY);
		return;
	}

@@ -1005,8 +1004,7 @@ start_cache(struct vbdev_ocf *vbdev)

	vbdev->cache_ctx = calloc(1, sizeof(struct vbdev_ocf_cache_ctx));
	if (vbdev->cache_ctx == NULL) {
		vbdev->mngt_ctx.status = -ENOMEM;
		vbdev_ocf_mngt_stop(vbdev);
		vbdev_ocf_mngt_stop(vbdev, NULL, -ENOMEM);
		return;
	}

@@ -1016,8 +1014,7 @@ start_cache(struct vbdev_ocf *vbdev)
	rc = ocf_mngt_cache_start(vbdev_ocf_ctx, &vbdev->ocf_cache, &vbdev->cfg.cache);
	if (rc) {
		vbdev_ocf_cache_ctx_put(vbdev->cache_ctx);
		vbdev->mngt_ctx.status = rc;
		vbdev_ocf_mngt_stop(vbdev);
		vbdev_ocf_mngt_stop(vbdev, NULL, rc);
		return;
	}

@@ -1028,8 +1025,7 @@ start_cache(struct vbdev_ocf *vbdev)
	if (rc) {
		SPDK_ERRLOG("Unable to create mngt_queue: %d\n", rc);
		vbdev_ocf_cache_ctx_put(vbdev->cache_ctx);
		vbdev->mngt_ctx.status = rc;
		vbdev_ocf_mngt_stop(vbdev);
		vbdev_ocf_mngt_stop(vbdev, NULL, rc);
		return;
	}