From bf543a1372bbb3aada53e0bd249ba52209cc07cd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B6rn=20Jacke?= Date: Wed, 9 Jun 2010 15:24:26 +0200 Subject: s3: fix calculation of st_blocks in streams_xattr Thanks to Joachim Schmitz for finding that miscalculation. (cherry picked from commit 6a6bb768c6542d738a8b2b6da282159a65ed611d) Fix bug #7503 (vfs_stream_xattr calculates st_blocks wrong). (cherry picked from commit 3f8a03cfdaa29e54b50738df4e7b782228e2d931) --- source3/modules/vfs_streams_xattr.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/source3/modules/vfs_streams_xattr.c b/source3/modules/vfs_streams_xattr.c index d7c0a834c00..3f7407a604c 100644 --- a/source3/modules/vfs_streams_xattr.c +++ b/source3/modules/vfs_streams_xattr.c @@ -237,7 +237,7 @@ static int streams_xattr_fstat(vfs_handle_struct *handle, files_struct *fsp, sbuf->st_ex_ino = stream_inode(sbuf, io->xattr_name); sbuf->st_ex_mode &= ~S_IFMT; sbuf->st_ex_mode |= S_IFREG; - sbuf->st_ex_blocks = sbuf->st_ex_size % STAT_ST_BLOCKSIZE + 1; + sbuf->st_ex_blocks = sbuf->st_ex_size / STAT_ST_BLOCKSIZE + 1; return 0; } @@ -290,7 +290,7 @@ static int streams_xattr_stat(vfs_handle_struct *handle, smb_fname->st.st_ex_mode &= ~S_IFMT; smb_fname->st.st_ex_mode |= S_IFREG; smb_fname->st.st_ex_blocks = - smb_fname->st.st_ex_size % STAT_ST_BLOCKSIZE + 1; + smb_fname->st.st_ex_size / STAT_ST_BLOCKSIZE + 1; result = 0; fail: @@ -341,7 +341,7 @@ static int streams_xattr_lstat(vfs_handle_struct *handle, smb_fname->st.st_ex_mode &= ~S_IFMT; smb_fname->st.st_ex_mode |= S_IFREG; smb_fname->st.st_ex_blocks = - smb_fname->st.st_ex_size % STAT_ST_BLOCKSIZE + 1; + smb_fname->st.st_ex_size / STAT_ST_BLOCKSIZE + 1; result = 0; -- cgit v1.2.1