summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fdisks/fdisk.c2
-rw-r--r--libfdisk/src/fdiskP.h1
-rw-r--r--libfdisk/src/label.c2
-rw-r--r--libfdisk/src/libfdisk.h3
-rw-r--r--libfdisk/src/partition.c28
5 files changed, 27 insertions, 9 deletions
diff --git a/fdisks/fdisk.c b/fdisks/fdisk.c
index db3b29870..3e0d75205 100644
--- a/fdisks/fdisk.c
+++ b/fdisks/fdisk.c
@@ -193,7 +193,7 @@ void change_partition_type(struct fdisk_context *cxt)
_("Type of partition %zu is unchanged: %s."),
i + 1, old);
- fdisk_free_partition(pa);
+ fdisk_unref_partition(pa);
}
void list_disk_geometry(struct fdisk_context *cxt)
diff --git a/libfdisk/src/fdiskP.h b/libfdisk/src/fdiskP.h
index 881e1b2b6..2defe3367 100644
--- a/libfdisk/src/fdiskP.h
+++ b/libfdisk/src/fdiskP.h
@@ -129,6 +129,7 @@ enum {
struct fdisk_partition {
struct fdisk_context *cxt;
+ int refcount;
size_t partno;
uint64_t start;
diff --git a/libfdisk/src/label.c b/libfdisk/src/label.c
index e243dc05f..db9c40204 100644
--- a/libfdisk/src/label.c
+++ b/libfdisk/src/label.c
@@ -412,7 +412,7 @@ done:
if (org != cols)
free(cols);
tt_free_table(tb);
- fdisk_free_partition(pa);
+ fdisk_unref_partition(pa);
return rc;
}
diff --git a/libfdisk/src/libfdisk.h b/libfdisk/src/libfdisk.h
index 22741d80f..ef9b1a129 100644
--- a/libfdisk/src/libfdisk.h
+++ b/libfdisk/src/libfdisk.h
@@ -181,7 +181,8 @@ extern int fdisk_partition_toggle_flag(struct fdisk_context *cxt, size_t partnum
extern struct fdisk_partition *fdisk_new_partition(void);
extern void fdisk_reset_partition(struct fdisk_partition *pa);
-extern void fdisk_free_partition(struct fdisk_partition *pa);
+extern void fdisk_ref_partition(struct fdisk_partition *pa);
+extern void fdisk_unref_partition(struct fdisk_partition *pa);
extern int fdisk_partition_is_freespace(struct fdisk_partition *pa);
extern int fdisk_partition_set_start(struct fdisk_partition *pa, uint64_t off);
extern uint64_t fdisk_partition_get_start(struct fdisk_partition *pa);
diff --git a/libfdisk/src/partition.c b/libfdisk/src/partition.c
index 57c5eb976..3cef46c20 100644
--- a/libfdisk/src/partition.c
+++ b/libfdisk/src/partition.c
@@ -8,6 +8,7 @@ struct fdisk_partition *fdisk_new_partition(void)
{
struct fdisk_partition *pa = calloc(1, sizeof(*pa));
+ pa->refcount = 1;
pa->partno = FDISK_EMPTY_PARTNO;
DBG(PART, dbgprint("new %p", pa));
return pa;
@@ -15,23 +16,38 @@ struct fdisk_partition *fdisk_new_partition(void)
void fdisk_reset_partition(struct fdisk_partition *pa)
{
+ int ref;
+
if (!pa)
return;
+
+ ref = pa->refcount;
fdisk_free_parttype(pa->type);
free(pa->name);
free(pa->uuid);
free(pa->attrs);
memset(pa, 0, sizeof(*pa));
pa->partno = FDISK_EMPTY_PARTNO;
+ pa->refcount = ref;
}
-void fdisk_free_partition(struct fdisk_partition *pa)
+void fdisk_ref_partition(struct fdisk_partition *pa)
+{
+ if (pa)
+ pa->refcount++;
+}
+
+void fdisk_unref_partition(struct fdisk_partition *pa)
{
if (!pa)
return;
- fdisk_reset_partition(pa);
- DBG(PART, dbgprint("free %p", pa));
- free(pa);
+
+ pa->refcount--;
+ if (pa->refcount <= 0) {
+ fdisk_reset_partition(pa);
+ DBG(PART, dbgprint("free %p", pa));
+ free(pa);
+ }
}
int fdisk_partition_set_start(struct fdisk_partition *pa, uint64_t off)
@@ -212,13 +228,13 @@ int fdisk_partition_next_partno(
*
* For exmaple
*
- * struct fdisk_parition *pa = fdisk_new_partition();
+ * struct fdisk_parition *pa;
*
* fdisk_get_partition(cxt, 0, &pa);
* fdisk_partition_to_string(pa, FDISK_COL_UUID, &data);
* printf("first partition uuid: %s\n", data);
* free(data);
- * fdisk_free_partition(pa);
+ * fdisk_unref_partition(pa);
*
* returns UUID for the first partition.
*