Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
openSUSE:Step:15-SP4
xfsprogs.13989
xfsprogs-xfs_spaceman-add-a-superblock-info-com...
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File xfsprogs-xfs_spaceman-add-a-superblock-info-command.patch of Package xfsprogs.13989
From 6719d622819817b81c2bcade45181f53e4a3ad12 Mon Sep 17 00:00:00 2001 From: "Darrick J. Wong" <darrick.wong@oracle.com> Date: Wed, 23 May 2018 16:30:48 -0500 Subject: [PATCH] xfs_spaceman: add a superblock info command Git-commit: 6719d622819817b81c2bcade45181f53e4a3ad12 Patch-mainline: v4.17.0-rc1 References: bsc#1129859 Add an 'info' command to pretty-print the superblock geometry. Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com> Reviewed-by: Allison Henderson <allison.henderson@oracle.com> Reviewed-by: Eric Sandeen <sandeen@redhat.com> Signed-off-by: Eric Sandeen <sandeen@sandeen.net> Acked-by: Anthony Iliopoulos <ailiopoulos@suse.com> --- man/man8/xfs_spaceman.8 | 7 ++++ spaceman/Makefile | 2 +- spaceman/info.c | 96 +++++++++++++++++++++++++++++++++++++++++++++++++ spaceman/init.c | 1 + spaceman/space.h | 1 + 5 files changed, 106 insertions(+), 1 deletion(-) create mode 100644 spaceman/info.c diff --git a/man/man8/xfs_spaceman.8 b/man/man8/xfs_spaceman.8 index e4a9137f..12dd04e4 100644 --- a/man/man8/xfs_spaceman.8 +++ b/man/man8/xfs_spaceman.8 @@ -84,6 +84,13 @@ Display a summary of the free space information found. .PD .RE .TP +.B info +Displays selected geometry information about the filesystem. +The opened file must be a mount point of a XFS filesystem. +The output will have the same format that +.BR "xfs_info" "(8)" +prints when querying a filesystem. +.TP .BR "help [ " command " ]" Display a brief description of one or all commands. .TP diff --git a/spaceman/Makefile b/spaceman/Makefile index 8b310309..c1d903ba 100644 --- a/spaceman/Makefile +++ b/spaceman/Makefile @@ -7,7 +7,7 @@ include $(TOPDIR)/include/builddefs LTCOMMAND = xfs_spaceman HFILES = init.h space.h -CFILES = init.c file.c prealloc.c trim.c +CFILES = info.c init.c file.c prealloc.c trim.c LLDLIBS = $(LIBXCMD) $(LIBFROG) LTDEPENDENCIES = $(LIBXCMD) $(LIBFROG) diff --git a/spaceman/info.c b/spaceman/info.c new file mode 100644 index 00000000..8889346b --- /dev/null +++ b/spaceman/info.c @@ -0,0 +1,96 @@ +/* + * Copyright (C) 2018 Oracle. All Rights Reserved. + * + * Author: Darrick J. Wong <darrick.wong@oracle.com> + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it would be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. + */ +#include "libxfs.h" +#include "command.h" +#include "init.h" +#include "path.h" +#include "space.h" +#include "fsgeom.h" + +static void +info_help(void) +{ + printf(_( +"\n" +" Pretty-prints the filesystem geometry as derived from the superblock.\n" +" The output has the same format as mkfs.xfs, xfs_info, and other utilities.\n" +" The opened file must be an XFS mount point.\n" +"\n" +)); + +} + +static int +info_f( + int argc, + char **argv) +{ + struct xfs_fsop_geom geo; + int error; + + if (fs_table_lookup_mount(file->name) == NULL) { + fprintf(stderr, _("%s: Not a XFS mount point.\n"), file->name); + return 1; + } + + /* get the current filesystem size & geometry */ + error = ioctl(file->fd, XFS_IOC_FSGEOMETRY, &geo); + if (error) { + /* + * OK, new xfsctl barfed - back off and try earlier version + * as we're probably running an older kernel version. + * Only field added in the v2 geometry xfsctl is "logsunit" + * so we'll zero that out for later display (as zero). + */ + geo.logsunit = 0; + error = ioctl(file->fd, XFS_IOC_FSGEOMETRY_V1, &geo); + if (error) { + fprintf(stderr, _( + "%s: cannot determine geometry of filesystem" + " mounted at %s: %s\n"), + progname, file->name, strerror(errno)); + exitcode = 1; + return 0; + } + } + + xfs_report_geom(&geo, file->fs_path.fs_name, file->fs_path.fs_log, + file->fs_path.fs_rt); + return 0; +} + +static const struct cmdinfo info_cmd = { + .name = "info", + .altname = "i", + .cfunc = info_f, + .argmin = 0, + .argmax = 0, + .canpush = 0, + .args = NULL, + .flags = CMD_FLAG_ONESHOT, + .oneline = N_("pretty-print superblock geometry info"), + .help = info_help, +}; + +void +info_init(void) +{ + add_command(&info_cmd); +} diff --git a/spaceman/init.c b/spaceman/init.c index b3efacef..895504f3 100644 --- a/spaceman/init.c +++ b/spaceman/init.c @@ -40,6 +40,7 @@ init_commands(void) { print_init(); help_init(); + info_init(); prealloc_init(); quit_init(); trim_init(); diff --git a/spaceman/space.h b/spaceman/space.h index 5f4a8a0b..d2a25432 100644 --- a/spaceman/space.h +++ b/spaceman/space.h @@ -42,5 +42,6 @@ extern void freesp_init(void); #else # define freesp_init() do { } while (0) #endif +extern void info_init(void); #endif /* XFS_SPACEMAN_SPACE_H_ */ -- 2.16.4
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor