* [PATCH] orangefs: off by ones in xattr size checks
@ 2017-05-22 12:08 Dan Carpenter
2017-05-22 20:53 ` Martin Brandenburg
0 siblings, 1 reply; 2+ messages in thread
From: Dan Carpenter @ 2017-05-22 12:08 UTC (permalink / raw)
To: Mike Marshall, Martin Brandenburg; +Cc: linux-kernel, kernel-janitors
A previous patch which claimed to remove off by ones actually introduced
them.
strlen() returns the length of the string not including the NUL
character. We are using strcpy() to copy "name" into a buffer which is
ORANGEFS_MAX_XATTR_NAMELEN characters long. We should make sure to
leave space for the NUL, otherwise we're writing one character beyond
the end of the buffer.
Fixes: e675c5ec51fe ("orangefs: clean up oversize xattr validation")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
diff --git a/fs/orangefs/xattr.c b/fs/orangefs/xattr.c
index 237c9c04dc3b..a34b25be39c5 100644
--- a/fs/orangefs/xattr.c
+++ b/fs/orangefs/xattr.c
@@ -76,7 +76,7 @@ ssize_t orangefs_inode_getxattr(struct inode *inode, const char *name,
if (S_ISLNK(inode->i_mode))
return -EOPNOTSUPP;
- if (strlen(name) > ORANGEFS_MAX_XATTR_NAMELEN)
+ if (strlen(name) >= ORANGEFS_MAX_XATTR_NAMELEN)
return -EINVAL;
fsuid = from_kuid(&init_user_ns, current_fsuid());
@@ -169,7 +169,7 @@ static int orangefs_inode_removexattr(struct inode *inode, const char *name,
struct orangefs_kernel_op_s *new_op = NULL;
int ret = -ENOMEM;
- if (strlen(name) > ORANGEFS_MAX_XATTR_NAMELEN)
+ if (strlen(name) >= ORANGEFS_MAX_XATTR_NAMELEN)
return -EINVAL;
down_write(&orangefs_inode->xattr_sem);
@@ -233,7 +233,7 @@ int orangefs_inode_setxattr(struct inode *inode, const char *name,
if (size > ORANGEFS_MAX_XATTR_VALUELEN)
return -EINVAL;
- if (strlen(name) > ORANGEFS_MAX_XATTR_NAMELEN)
+ if (strlen(name) >= ORANGEFS_MAX_XATTR_NAMELEN)
return -EINVAL;
internal_flag = convert_to_internal_xattr_flags(flags);
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH] orangefs: off by ones in xattr size checks
2017-05-22 12:08 [PATCH] orangefs: off by ones in xattr size checks Dan Carpenter
@ 2017-05-22 20:53 ` Martin Brandenburg
0 siblings, 0 replies; 2+ messages in thread
From: Martin Brandenburg @ 2017-05-22 20:53 UTC (permalink / raw)
To: Dan Carpenter; +Cc: Mike Marshall, linux-kernel, kernel-janitors
On 5/22/17, Dan Carpenter <dan.carpenter@oracle.com> wrote:
> A previous patch which claimed to remove off by ones actually introduced
> them.
>
> strlen() returns the length of the string not including the NUL
> character. We are using strcpy() to copy "name" into a buffer which is
> ORANGEFS_MAX_XATTR_NAMELEN characters long. We should make sure to
> leave space for the NUL, otherwise we're writing one character beyond
> the end of the buffer.
>
> Fixes: e675c5ec51fe ("orangefs: clean up oversize xattr validation")
> Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Crap. This is right. The OrangeFS userspace tools and the kernel both
pass the zero byte. The server itself and our database is perfectly
capable of handling any byte array. The value can be passed unchanged
though (and you have left that). We still pass xfstests generic/020
with this applied.
Reviewed-by: Martin Brandenburg <martin@omnibond.com>
>
> diff --git a/fs/orangefs/xattr.c b/fs/orangefs/xattr.c
> index 237c9c04dc3b..a34b25be39c5 100644
> --- a/fs/orangefs/xattr.c
> +++ b/fs/orangefs/xattr.c
> @@ -76,7 +76,7 @@ ssize_t orangefs_inode_getxattr(struct inode *inode, const
> char *name,
> if (S_ISLNK(inode->i_mode))
> return -EOPNOTSUPP;
>
> - if (strlen(name) > ORANGEFS_MAX_XATTR_NAMELEN)
> + if (strlen(name) >= ORANGEFS_MAX_XATTR_NAMELEN)
> return -EINVAL;
>
> fsuid = from_kuid(&init_user_ns, current_fsuid());
> @@ -169,7 +169,7 @@ static int orangefs_inode_removexattr(struct inode
> *inode, const char *name,
> struct orangefs_kernel_op_s *new_op = NULL;
> int ret = -ENOMEM;
>
> - if (strlen(name) > ORANGEFS_MAX_XATTR_NAMELEN)
> + if (strlen(name) >= ORANGEFS_MAX_XATTR_NAMELEN)
> return -EINVAL;
>
> down_write(&orangefs_inode->xattr_sem);
> @@ -233,7 +233,7 @@ int orangefs_inode_setxattr(struct inode *inode, const
> char *name,
>
> if (size > ORANGEFS_MAX_XATTR_VALUELEN)
> return -EINVAL;
> - if (strlen(name) > ORANGEFS_MAX_XATTR_NAMELEN)
> + if (strlen(name) >= ORANGEFS_MAX_XATTR_NAMELEN)
> return -EINVAL;
>
> internal_flag = convert_to_internal_xattr_flags(flags);
>
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2017-05-22 20:53 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-05-22 12:08 [PATCH] orangefs: off by ones in xattr size checks Dan Carpenter
2017-05-22 20:53 ` Martin Brandenburg
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox