Skip to content

Commit 1e68722

Browse files
Keith Buschdavejiang
authored andcommitted
libnvdimm: Export max available extent
The 'available_size' attribute showing the combined total of all unallocated space isn't always useful to know how large of a namespace a user may be able to allocate if the region is fragmented. This patch will export the largest extent of unallocated space that may be allocated to create a new namespace. Signed-off-by: Keith Busch <keith.busch@intel.com> Reviewed-by: Vishal Verma <vishal.l.verma@intel.com> Signed-off-by: Dave Jiang <dave.jiang@intel.com>
1 parent 12e3129 commit 1e68722

File tree

1 file changed

+16
-0
lines changed

1 file changed

+16
-0
lines changed

drivers/nvdimm/region_devs.c

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -434,6 +434,21 @@ static ssize_t available_size_show(struct device *dev,
434434
}
435435
static DEVICE_ATTR_RO(available_size);
436436

437+
static ssize_t max_available_extent_show(struct device *dev,
438+
struct device_attribute *attr, char *buf)
439+
{
440+
struct nd_region *nd_region = to_nd_region(dev);
441+
unsigned long long available = 0;
442+
443+
nvdimm_bus_lock(dev);
444+
wait_nvdimm_bus_probe_idle(dev);
445+
available = nd_region_allocatable_dpa(nd_region);
446+
nvdimm_bus_unlock(dev);
447+
448+
return sprintf(buf, "%llu\n", available);
449+
}
450+
static DEVICE_ATTR_RO(max_available_extent);
451+
437452
static ssize_t init_namespaces_show(struct device *dev,
438453
struct device_attribute *attr, char *buf)
439454
{
@@ -585,6 +600,7 @@ static struct attribute *nd_region_attributes[] = {
585600
&dev_attr_read_only.attr,
586601
&dev_attr_set_cookie.attr,
587602
&dev_attr_available_size.attr,
603+
&dev_attr_max_available_extent.attr,
588604
&dev_attr_namespace_seed.attr,
589605
&dev_attr_init_namespaces.attr,
590606
&dev_attr_badblocks.attr,

0 commit comments

Comments
 (0)