1. 08 10月, 2008 1 次提交
    • S
      [CIFS] make sure we have the right resume info before calling CIFSFindNext · 0752f152
      Steve French 提交于
      When we do a seekdir() or equivalent, we usually end up doing a
      FindFirst call and then call FindNext until we get to the offset that we
      want. The problem is that when we call FindNext, the code usually
      doesn't have the proper info (mostly, the filename of the entry from the
      last search) to resume the search.
      
      Add a "last_entry" field to the cifs_search_info that points to the last
      entry in the search. We calculate this pointer by using the
      LastNameOffset field from the search parms that are returned. We then
      use that info to do a cifs_save_resume_key before we call CIFSFindNext.
      
      This patch allows CIFS to reliably pass the "telldir" connectathon test.
      Signed-off-by: NJeff Layton <jlayton@redhat.com>
      CC: Stable <stable@kernel.org>
      Signed-off-by: NSteve French <sfrench@us.ibm.com>
      0752f152
  2. 24 7月, 2008 1 次提交
  3. 24 5月, 2008 2 次提交
  4. 14 5月, 2008 1 次提交
    • S
      [CIFS] don't explicitly do a FindClose on rewind when directory search has ended · 77c57ec8
      Steve French 提交于
      Do the following series of operations on a CIFS share:
      
          opendir(dir)
          readdir(dir)
          unlink(file in dir)
          rewinddir(dir)
          readdir(dir)
      
      If the readdir read all entries in the directory this will make CIFS throw an error like this:
      
           CIFS VFS: Send error in FindClose = -9
      
      CIFS requests "Close at end of search" of the server by setting this bit when issuing FindFirst or FindNext.  Therefore when all search entries are returned, the server may return "end of search" and close the search implicitly when this bit is set by the client on the request.  We check for this when a readdir is explicitly closed - but when the client notices that a directory has changed after the last operation, we attempt to close the directory before reopening by reissuing a second FindFirst. But, the directory may already been implicitly closed (due to end of search) because the first readdir finished. So we only want to issue a FindClose call in this case when we don't expect it to already be closed.
      Signed-off-by: NJeff Layton <jlayton@redhat.com>
      Signed-off-by: NSteve French <sfrench@us.ibm.com>
      77c57ec8
  5. 29 4月, 2008 1 次提交
  6. 13 2月, 2008 1 次提交
  7. 08 2月, 2008 1 次提交
  8. 09 11月, 2007 1 次提交
    • S
      [CIFS] Fix stale mode after readdir when cifsacl specified · a6f8de3d
      Steve French 提交于
      When mounted with cifsacl mount option, readdir can not
      instantiate the inode with the estimated mode based on the ACL
      for each file since we have not queried for the ACL for
      each of these files yet.  So set the refresh time to zero
      for these inodes so that the next stat will cause the client
      to go to the server for the ACL info so we can build the estimated
      mode (this means we also will issue an extra QueryPathInfo if
      the stat happens within 1 second, but this is trivial compared to
      the time required to open/getacl/close for each).
      
      ls -l is slower when cifsacl mount option is specified, but
      displays correct mode information.
      Signed-off-by: NShirish Pargaonkar <shirishp@us.ibm.com>
      Signed-off-by: NSteve French <sfrench@us.ibm.com>
      a6f8de3d
  9. 06 11月, 2007 1 次提交
  10. 13 10月, 2007 1 次提交
  11. 31 8月, 2007 1 次提交
  12. 19 7月, 2007 1 次提交
  13. 13 7月, 2007 1 次提交
  14. 08 7月, 2007 2 次提交
  15. 07 7月, 2007 1 次提交
  16. 09 5月, 2007 1 次提交
  17. 01 5月, 2007 1 次提交
    • S
      [CIFS] UID/GID override on CIFS mounts to Samba · 4523cc30
      Steve French 提交于
      When CIFS Unix Extensions are negotiated we get the Unix uid and gid
      owners of the file from the server (on the Unix Query Path Info
      levels), but if the server's uids don't match the client uid's users
      were having to disable the Unix Extensions (which turned off features
      they still wanted).   The changeset patch allows users to override uid
      and/or gid for file/directory owner with a default uid and/or gid
      specified at mount (as is often done when mounting from Linux cifs
      client to Windows server).  This changeset also displays the uid
      and gid used by default in /proc/mounts (if applicable).
      
      Also cleans up code by adding some of the missing spaces after
      "if" keywords per-kernel style guidelines (as suggested by Randy Dunlap
      when he reviewed the patch).
      Signed-off-by: NSteve French <sfrench@us.ibm.com>
      4523cc30
  18. 25 4月, 2007 1 次提交
  19. 03 4月, 2007 1 次提交
  20. 10 3月, 2007 1 次提交
  21. 27 2月, 2007 1 次提交
  22. 17 2月, 2007 1 次提交
  23. 09 2月, 2007 1 次提交
  24. 07 2月, 2007 1 次提交
  25. 09 12月, 2006 1 次提交
  26. 31 10月, 2006 1 次提交
  27. 12 10月, 2006 2 次提交
  28. 07 10月, 2006 1 次提交
  29. 02 10月, 2006 1 次提交
  30. 28 9月, 2006 1 次提交
  31. 27 9月, 2006 1 次提交
  32. 07 9月, 2006 1 次提交
  33. 15 8月, 2006 1 次提交
  34. 07 6月, 2006 1 次提交
  35. 02 6月, 2006 1 次提交
  36. 01 6月, 2006 2 次提交