Commit 87666f52 authored by Mike Gerdts's avatar Mike Gerdts Committed by Jim Harris
Browse files

blob: esnap clones are not clones



spdk_blob_is_clone() should return true only for normal clones. To
detect esnap clones, use spdk_blob_is_esnap_clone(). This also clarifies
documentation of spdk_blob_is_esnap_clone() to match the implementation.

Signed-off-by: default avatarMike Gerdts <mgerdts@nvidia.com>
Change-Id: I9993ab60c1a097531a46fb6760124a632f6857cd
Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/17544


Tested-by: default avatarSPDK CI Jenkins <sys_sgci@intel.com>
Reviewed-by: default avatarBen Walker <benjamin.walker@intel.com>
Reviewed-by: default avatarJim Harris <james.r.harris@intel.com>
parent 8b3dcd61
Loading
Loading
Loading
Loading
+5 −3
Original line number Diff line number Diff line
@@ -689,11 +689,13 @@ bool spdk_blob_is_read_only(struct spdk_blob *blob);
bool spdk_blob_is_snapshot(struct spdk_blob *blob);

/**
 * Check if blob is a clone.
 * Check if blob is a clone of a blob.
 *
 * Clones of external snapshots will return false. See spdk_blob_is_esnap_clone.
 *
 * \param blob Blob.
 *
 * \return true if blob is a clone.
 * \return true if blob is a clone of a blob.
 */
bool spdk_blob_is_clone(struct spdk_blob *blob);

@@ -707,7 +709,7 @@ bool spdk_blob_is_clone(struct spdk_blob *blob);
bool spdk_blob_is_thin_provisioned(struct spdk_blob *blob);

/**
 * Check if blob is a clone of an external bdev.
 * Check if blob is a clone of an external snapshot.
 *
 * \param blob Blob.
 *
+2 −1
Original line number Diff line number Diff line
@@ -8478,7 +8478,8 @@ spdk_blob_is_clone(struct spdk_blob *blob)
{
	assert(blob != NULL);

	if (blob->parent_id != SPDK_BLOBID_INVALID) {
	if (blob->parent_id != SPDK_BLOBID_INVALID &&
	    blob->parent_id != SPDK_BLOBID_EXTERNAL_SNAPSHOT) {
		assert(spdk_blob_is_thin_provisioned(blob));
		return true;
	}
+1 −0
Original line number Diff line number Diff line
@@ -7486,6 +7486,7 @@ blob_esnap_create(void)
	SPDK_CU_ASSERT_FATAL(blob != NULL);
	SPDK_CU_ASSERT_FATAL(spdk_blob_is_esnap_clone(blob));
	SPDK_CU_ASSERT_FATAL(blob_is_esnap_clone(blob));
	SPDK_CU_ASSERT_FATAL(!spdk_blob_is_clone(blob));
	sz = spdk_blob_get_num_clusters(blob);
	CU_ASSERT(sz == esnap_num_clusters);
	ut_blob_close_and_delete(bs, blob);