lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:	Fri, 23 Dec 2011 09:14:20 +0800
From:	Yongqiang Yang <xiaoqiangnk@...il.com>
To:	Djalal Harouni <tixxdz@...ndz.org>
Cc:	"Theodore Ts'o" <tytso@....edu>,
	Andreas Dilger <adilger.kernel@...ger.ca>,
	linux-ext4@...r.kernel.org, linux-kernel@...r.kernel.org,
	stable@...r.kernel.org
Subject: Re: [PATCH] fs/ext4: add missing ext4_resize_end

Thanks.

The patch looks good.   I have to update the new resize patch too.

Yongqiang.

On Thu, Dec 22, 2011 at 11:00 PM, Djalal Harouni <tixxdz@...ndz.org> wrote:
> Online resize ioctls 'EXT4_IOC_GROUP_EXTEND' and 'EXT4_IOC_GROUP_ADD'
> call ext4_resize_begin() to check permissions and to set the
> EXT4_RESIZING bit lock, they do their work and they must finish with
> ext4_resize_end() which calls clear_bit_unlock() to unlock and to
> avoid -EBUSY errors for the next resize operations.
>
> This patch adds the missing ext4_resize_end() calls on error paths.
>
> Patch tested.
>
> Cc: stable@...r.kernel.org
> Signed-off-by: Djalal Harouni <tixxdz@...ndz.org>
> ---
>  fs/ext4/ioctl.c |   28 ++++++++++++++++++----------
>  1 files changed, 18 insertions(+), 10 deletions(-)
>
> diff --git a/fs/ext4/ioctl.c b/fs/ext4/ioctl.c
> index a567968..ab25f57 100644
> --- a/fs/ext4/ioctl.c
> +++ b/fs/ext4/ioctl.c
> @@ -182,19 +182,22 @@ setversion_out:
>                if (err)
>                        return err;
>
> -               if (get_user(n_blocks_count, (__u32 __user *)arg))
> -                       return -EFAULT;
> +               if (get_user(n_blocks_count, (__u32 __user *)arg)) {
> +                       err = -EFAULT;
> +                       goto group_extend_out;
> +               }
>
>                if (EXT4_HAS_RO_COMPAT_FEATURE(sb,
>                               EXT4_FEATURE_RO_COMPAT_BIGALLOC)) {
>                        ext4_msg(sb, KERN_ERR,
>                                 "Online resizing not supported with bigalloc");
> -                       return -EOPNOTSUPP;
> +                       err = -EOPNOTSUPP;
> +                       goto group_extend_out;
>                }
>
>                err = mnt_want_write(filp->f_path.mnt);
>                if (err)
> -                       return err;
> +                       goto group_extend_out;
>
>                err = ext4_group_extend(sb, EXT4_SB(sb)->s_es, n_blocks_count);
>                if (EXT4_SB(sb)->s_journal) {
> @@ -204,9 +207,10 @@ setversion_out:
>                }
>                if (err == 0)
>                        err = err2;
> +
>                mnt_drop_write(filp->f_path.mnt);
> +group_extend_out:
>                ext4_resize_end(sb);
> -
>                return err;
>        }
>
> @@ -267,19 +271,22 @@ mext_out:
>                        return err;
>
>                if (copy_from_user(&input, (struct ext4_new_group_input __user *)arg,
> -                               sizeof(input)))
> -                       return -EFAULT;
> +                               sizeof(input))) {
> +                       err = -EFAULT;
> +                       goto group_add_out;
> +               }
>
>                if (EXT4_HAS_RO_COMPAT_FEATURE(sb,
>                               EXT4_FEATURE_RO_COMPAT_BIGALLOC)) {
>                        ext4_msg(sb, KERN_ERR,
>                                 "Online resizing not supported with bigalloc");
> -                       return -EOPNOTSUPP;
> +                       err = -EOPNOTSUPP;
> +                       goto group_add_out;
>                }
>
>                err = mnt_want_write(filp->f_path.mnt);
>                if (err)
> -                       return err;
> +                       goto group_add_out;
>
>                err = ext4_group_add(sb, &input);
>                if (EXT4_SB(sb)->s_journal) {
> @@ -289,9 +296,10 @@ mext_out:
>                }
>                if (err == 0)
>                        err = err2;
> +
>                mnt_drop_write(filp->f_path.mnt);
> +group_add_out:
>                ext4_resize_end(sb);
> -
>                return err;
>        }
>
> --
> 1.7.1
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@...r.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/



-- 
Best Wishes
Yongqiang Yang
--
To unsubscribe from this list: send the line "unsubscribe linux-ext4" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ