NVMe ZNS specification defines zone capacity. The report zone interface of Linux kernel supports it. Expose it in report zone by blkzone command. Signed-off-by: Hans Holmberg <hans.holmberg@xxxxxxx> Signed-off-by: Shin'ichiro Kawasaki <shinichiro.kawasaki@xxxxxxx> --- configure.ac | 4 ++++ sys-utils/blkzone.8 | 1 + sys-utils/blkzone.c | 20 ++++++++++++++++++-- 3 files changed, 23 insertions(+), 2 deletions(-) diff --git a/configure.ac b/configure.ac index e31dc3767..f3e9f5d0d 100644 --- a/configure.ac +++ b/configure.ac @@ -322,6 +322,10 @@ AC_CHECK_HEADERS([security/pam_misc.h], AC_CHECK_HEADERS([linux/blkzoned.h]) +AC_CHECK_DECLS([BLK_ZONE_REP_CAPACITY], [], [], [ + #include <linux/blkzoned.h> +]) + AC_CHECK_HEADERS([security/openpam.h], [], [], [ #ifdef HAVE_SECURITY_PAM_APPL_H #include <security/pam_appl.h> diff --git a/sys-utils/blkzone.8 b/sys-utils/blkzone.8 index 64ad23bb3..043bc96e2 100644 --- a/sys-utils/blkzone.8 +++ b/sys-utils/blkzone.8 @@ -29,6 +29,7 @@ tab(:); l l. start:Zone start sector len:Zone length in number of sectors +cap:Zone capacity in number of sectors wptr:Zone write pointer position reset:Reset write pointer recommended non-seq:Non-sequential write resources active diff --git a/sys-utils/blkzone.c b/sys-utils/blkzone.c index 11e90fb0e..0f62ca395 100644 --- a/sys-utils/blkzone.c +++ b/sys-utils/blkzone.c @@ -24,6 +24,7 @@ #include <stdlib.h> #include <stdio.h> #include <stdint.h> +#include <stdbool.h> #include <fcntl.h> #include <limits.h> #include <getopt.h> @@ -189,6 +190,14 @@ done: return rc == 0 ? sz : 0; } +#if HAVE_DECL_BLK_ZONE_REP_CAPACITY +#define has_zone_capacity(zi) ((zi)->flags & BLK_ZONE_REP_CAPACITY) +#define zone_capacity(z) (z)->capacity +#else +#define has_zone_capacity(zi) (false) +#define zone_capacity(z) (z)->len +#endif + /* * blkzone report */ @@ -262,15 +271,22 @@ static int blkzone_report(struct blkzone_control *ctl) uint64_t wp = entry->wp; uint8_t cond = entry->cond; uint64_t len = entry->len; + uint64_t cap; if (!len) { nr_zones = 0; break; } - printf(_(" start: 0x%09"PRIx64", len 0x%06"PRIx64", wptr 0x%06"PRIx64 + if (has_zone_capacity(zi)) + cap = zone_capacity(entry); + else + cap = entry->len; + + printf(_(" start: 0x%09"PRIx64", len 0x%06"PRIx64 + ", cap 0x%06"PRIx64", wptr 0x%06"PRIx64 " reset:%u non-seq:%u, zcond:%2u(%s) [type: %u(%s)]\n"), - start, len, (type == 0x1) ? 0 : wp - start, + start, len, cap, (type == 0x1) ? 0 : wp - start, entry->reset, entry->non_seq, cond, condition_str[cond & (ARRAY_SIZE(condition_str) - 1)], type, type_text[type]); -- 2.26.2