Re: [PATCH 6/9] xfs_spaceman: add a superblock info command

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 4/17/18 9:46 PM, Darrick J. Wong wrote:
> From: Darrick J. Wong <darrick.wong@xxxxxxxxxx>
> 
> Add an 'info' command to pretty-print the superblock geometry.
> 
> Signed-off-by: Darrick J. Wong <darrick.wong@xxxxxxxxxx>
> ---



> diff --git a/spaceman/file.c b/spaceman/file.c
> index 4f9f66c..6adb4f5 100644
> --- a/spaceman/file.c
> +++ b/spaceman/file.c
> @@ -84,6 +84,8 @@ openfile(

        char            *path,
        xfs_fsop_geom_t *geom,
        struct fs_path  *fs_path)
{
..

        if (fs_path) {
...
>  			return -1;
>  		}
>  		memcpy(fs_path, fsp, sizeof(struct fs_path));
> +	} else {
> +		memset(fs_path, 0, sizeof(struct fs_path));
>  	}

so if fs_path == NULL memset(NULL, 0) ?

Not sure what's going on here.

(or maybe I've forgotten how C works)

>  	return fd;
>  }
> diff --git a/spaceman/info.c b/spaceman/info.c
> new file mode 100644
> index 0000000..b8b8133
> --- /dev/null
> +++ b/spaceman/info.c
> @@ -0,0 +1,96 @@
> +/*
> + * Copyright (C) 2018 Oracle.  All Rights Reserved.
> + *
> + * Author: Darrick J. Wong <darrick.wong@xxxxxxxxxx>
> + *
> + * 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.  The opened file must be a XFS\n"

"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);

We're certain that it won't fill in logsunit with junk, right?
Would it be any safer to set logsunit after or is that presupposing too
much about the interface?  I guess it's fine.

> +		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_("dump superblock info"),

"print geometry superblock info"

> +	.help =		info_help,
> +};
> +
> +void
> +info_init(void)
> +{
> +	add_command(&info_cmd);
> +}
> diff --git a/spaceman/init.c b/spaceman/init.c
> index b3eface..895504f 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 5f4a8a0..d2a2543 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_ */
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-xfs" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-xfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux