Re: [PATCH 1/1] xfsprogs/db: fix a segfault by bailing out the print on a corrupted block

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

 



On Fri, Apr 07, 2017 at 03:49:04PM +0800, Shan Hai wrote:
> The print command of the xfs_db would cause segfault on a corrupted
> or CRC error block, fix it by bailing out the print when encountered
> a corrupted or CRC error block, below is an example to reproduce the
> segfault:
> 
> mkfs.xfs -f /dev/sda1
> xfs_db -r -c "agf 0" -c "addr rmaproot" -c "p" /dev/sda1
> Metadata CRC error detected at xfs_rmapbt block 0x0/0x1000
> Segmentation fault (core dumped)
> 
> Signed-off-by: Shan Hai <shan.hai@xxxxxxxxxx>
> ---
>  db/print.c | 8 ++++++++
>  1 file changed, 8 insertions(+)
> 
> diff --git a/db/print.c b/db/print.c
> index e31372f..08bb39a 100644
> --- a/db/print.c
> +++ b/db/print.c
> @@ -69,11 +69,19 @@ print_f(
>  	char	**argv)
>  {
>  	pfunc_t	pf;
> +	int err;
>  
>  	if (cur_typ == NULL) {
>  		dbprintf(_("no current type\n"));
>  		return 0;
>  	}
> +
> +	err = iocur_top->bp->b_error;
> +	if ((err == -EFSCORRUPTED) || (err == -EFSBADCRC)) {

The double parentheses aren't needed for integer comparison.

Also, no need to send a cover letter if you're only sending one patch.

--D

> +		dbprintf(_("data corrupted or CRC error\n"));
> +		return 0;
> +	}
> +
>  	pf = cur_typ->pfunc;
>  	if (pf == NULL) {
>  		dbprintf(_("no print function for type %s\n"), cur_typ->name);
> -- 
> 2.7.4
> 
> --
> 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