Hello,
the following patch against 2.6.11-rc3 fixes this compile time warning:

 CC [M]  fs/cifs/file.o
fs/cifs/file.c: In function `cifs_user_read':
fs/cifs/file.c:1168: warning: ignoring return value of
`copy_to_user', declared with attribute warn_unused_result

I also added an explicit check for errors other than -EAGAIN, since
CIFSSMBRead may return -ENOMEM if it's unable to allocate smb_com_read_rsp;
in that case we don't want to call copy_to_user with a NULL pointer.

Signed-off-by: Luca Tettamanti <[EMAIL PROTECTED]>

--- a/fs/cifs/file.c    2005-02-03 17:58:07.000000000 +0100
+++ b/fs/cifs/file.c    2005-02-03 18:17:37.000000000 +0100
@@ -1151,7 +1151,7 @@
                current_read_size = min_t(const int,read_size - 
total_read,cifs_sb->rsize);
                rc = -EAGAIN;
                smb_read_data = NULL;
-               while(rc == -EAGAIN) {
+               while(1) {
                        if ((open_file->invalidHandle) && 
(!open_file->closePend)) {
                                rc = cifs_reopen_file(file->f_dentry->d_inode,
                                        file,TRUE);
@@ -1164,13 +1164,22 @@
                                 current_read_size, *poffset,
                                 &bytes_read, &smb_read_data);
 
+                       if (rc == -EAGAIN)
+                               continue;
+                       else
+                               break;
+
                        pSMBr = (struct smb_com_read_rsp *)smb_read_data;
-                       copy_to_user(current_offset,smb_read_data + 4/* RFC1001 
hdr*/
+                       rc = copy_to_user(current_offset,smb_read_data + 4/* 
RFC1001 hdr*/
                                + le16_to_cpu(pSMBr->DataOffset), bytes_read);
                        if(smb_read_data) {
                                cifs_buf_release(smb_read_data);
                                smb_read_data = NULL;
                        }
+                       if (rc) {
+                               FreeXid(xid);
+                               return -EFAULT;
+                       }
                }
                if (rc || (bytes_read == 0)) {
                        if (total_read) {


Luca
-- 
Home: http://kronoz.cjb.net
Quando un uomo porta dei fiori a sua moglie senza motivo, 
un motivo c'e`.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to