An error occurred fetching the project authors.
  1. 01 Sep, 2009 2 commits
    • Steve French's avatar
      [CIFS] Fix checkpatch warnings · ca43e3be
      Steve French authored
      Also update version number to 1.61
      Signed-off-by: default avatarSteve French <sfrench@us.ibm.com>
      ca43e3be
    • Suresh Jayaraman's avatar
      PATCH] cifs: fix broken mounts when a SSH tunnel is used (try #4) · bdb97adc
      Suresh Jayaraman authored
      One more try..
      
      It seems there is a regression that got introduced while Jeff fixed
      all the mount/umount races. While attempting to find whether a tcp
      session is already existing, we were not checking whether the "port"
      used are the same. When a second mount is attempted with a different
      "port=" option, it is being ignored. Because of this the cifs mounts
      that uses a SSH tunnel appears to be broken.
      
      Steps to reproduce:
      
      1. create 2 shares
      # SSH Tunnel a SMB session
      2. ssh -f -L 6111:127.0.0.1:445 root@localhost "sleep 86400"
      3. ssh -f -L 6222:127.0.0.1:445 root@localhost "sleep 86400"
      4. tcpdump -i lo 6111 &
      5. mkdir -p /mnt/mnt1
      6. mkdir -p /mnt/mnt2
      7. mount.cifs //localhost/a /mnt/mnt1 -o username=guest,ip=127.0.0.1,port=6111
      #(shows tcpdump activity on port 6111)
      8. mount.cifs //localhost/b /mnt/mnt2 -o username=guest,ip=127.0.0.1,port=6222
      #(shows tcpdump activity only on port 6111 and not on 6222
      
      Fix by adding a check to compare the port _only_ if the user tries to
      override the tcp port with "port=" option, before deciding that an
      existing tcp session is found. Also, clean up a bit by replacing
      if-else if by a switch statment while at it as suggested by Jeff.
      Reviewed-by: default avatarJeff Layton <jlayton@redhat.com>
      Reviewed-by: default avatarShirish Pargaonkar <shirishp@us.ibm.com>
      Signed-off-by: default avatarSuresh Jayaraman <sjayaraman@suse.de>
      Signed-off-by: default avatarSteve French <sfrench@us.ibm.com>
      bdb97adc
  2. 02 Aug, 2009 1 commit
  3. 28 Jul, 2009 1 commit
  4. 22 Jul, 2009 1 commit
    • Jeff Layton's avatar
      cifs: fix sb->s_maxbytes so that it casts properly to a signed value · 03aa3a49
      Jeff Layton authored
      This off-by-one bug causes sendfile() to not work properly. When a task
      calls sendfile() on a file on a CIFS filesystem, the syscall returns -1
      and sets errno to EOVERFLOW.
      
      do_sendfile uses s_maxbytes to verify the returned offset of the file.
      The problem there is that this value is cast to a signed value (loff_t).
      When this is done on the s_maxbytes value that cifs uses, it becomes
      negative and the comparisons against it fail.
      
      Even though s_maxbytes is an unsigned value, it seems that it's not OK
      to set it in such a way that it'll end up negative when it's cast to a
      signed value. These casts happen in other codepaths besides sendfile
      too, but the VFS is a little hard to follow in this area and I can't
      be sure if there are other bugs that this will fix.
      
      It's not clear to me why s_maxbytes isn't just declared as loff_t in the
      first place, but either way we still need to fix these values to make
      sendfile work properly. This is also an opportunity to replace the magic
      bit-shift values here with the standard #defines for this.
      
      This fixes the reproducer program I have that does a sendfile and
      will probably also fix the situation where apache is serving from a
      CIFS share.
      Acked-by: default avatarJohannes Weiner <hannes@cmpxchg.org>
      Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
      Signed-off-by: default avatarSteve French <sfrench@us.ibm.com>
      03aa3a49
  5. 20 Jul, 2009 1 commit
  6. 26 Jun, 2009 1 commit
  7. 25 Jun, 2009 3 commits
  8. 13 Jun, 2009 1 commit
  9. 10 Jun, 2009 2 commits
  10. 06 Jun, 2009 1 commit
    • Jeff Layton's avatar
      cifs: make overriding of ownership conditional on new mount options · 4ae1507f
      Jeff Layton authored
      We have a bit of a problem with the uid= option. The basic issue is that
      it means too many things and has too many side-effects.
      
      It's possible to allow an unprivileged user to mount a filesystem if the
      user owns the mountpoint, /bin/mount is setuid root, and the mount is
      set up in /etc/fstab with the "user" option.
      
      When doing this though, /bin/mount automatically adds the "uid=" and
      "gid=" options to the share. This is fortunate since the correct uid=
      option is needed in order to tell the upcall what user's credcache to
      use when generating the SPNEGO blob.
      
      On a mount without unix extensions this is fine -- you generally will
      want the files to be owned by the "owner" of the mount. The problem
      comes in on a mount with unix extensions. With those enabled, the
      uid/gid options cause the ownership of files to be overriden even though
      the server is sending along the ownership info.
      
      This means that it's not possible to have a mount by an unprivileged
      user that shows the server's file ownership info. The result is also
      inode permissions that have no reflection at all on the server. You
      simply cannot separate ownership from the mode in this fashion.
      
      This behavior also makes MultiuserMount option less usable. Once you
      pass in the uid= option for a mount, then you can't use unix ownership
      info and allow someone to share the mount.
      
      While I'm not thrilled with it, the only solution I can see is to stop
      making uid=/gid= force the overriding of ownership on mounts, and to add
      new mount options that turn this behavior on.
      Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
      Signed-off-by: default avatarSteve French <sfrench@us.ibm.com>
      4ae1507f
  11. 02 Jun, 2009 1 commit
  12. 28 May, 2009 1 commit
  13. 26 May, 2009 1 commit
    • Jeff Layton's avatar
      cifs: tighten up default file_mode/dir_mode · f55ed1a8
      Jeff Layton authored
      The current default file mode is 02767 and dir mode is 0777. This is
      extremely "loose". Given that CIFS is a single-user protocol, these
      permissions allow anyone to use the mount -- in effect, giving anyone on
      the machine access to the credentials used to mount the share.
      
      Change this by making the default permissions restrict write access to
      the default owner of the mount. Give read and execute permissions to
      everyone else. These are the same permissions that VFAT mounts get by
      default so there is some precedent here.
      
      Note that this patch also removes the mandatory locking flags from the
      default file_mode. After having looked at how these flags are used by
      the kernel, I don't think that keeping them as the default offers any
      real benefit. That flag combination makes it so that the kernel enforces
      mandatory locking.
      
      Since the server is going to do that for us anyway, I don't think we
      want the client to enforce this by default on applications that just
      want advisory locks. Anyone that does want this behavior can always
      enable it by setting the file_mode appropriately.
      Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
      Signed-off-by: default avatarSteve French <sfrench@us.ibm.com>
      f55ed1a8
  14. 06 May, 2009 1 commit
  15. 02 May, 2009 1 commit
  16. 01 May, 2009 2 commits
  17. 30 Apr, 2009 5 commits
  18. 17 Apr, 2009 7 commits
  19. 18 Mar, 2009 1 commit
  20. 12 Mar, 2009 2 commits
    • Steve French's avatar
      [CIFS] fix build error · 4717bed6
      Steve French authored
      Signed-off-by: default avatarSteve French <sfrench@us.ibm.com>
      4717bed6
    • Steve French's avatar
      [CIFS] Add new nostrictsync cifs mount option to avoid slow SMB flush · be652445
      Steve French authored
      If this mount option is set, when an application does an
      fsync call then the cifs client does not send an SMB Flush
      to the server (to force the server to write all dirty data
      for this file immediately to disk), although cifs still sends
      all dirty (cached) file data to the server and waits for the
      server to respond to the write write.  Since SMB Flush can be
      very slow, and some servers may be reliable enough (to risk
      delaying slightly flushing the data to disk on the server),
      turning on this option may be useful to improve performance for
      applications that fsync too much, at a small risk of server
      crash.  If this mount option is not set, by default cifs will
      send an SMB flush request (and wait for a response) on every
      fsync call.
      Signed-off-by: default avatarSteve French <sfrench@us.ibm.com>
      be652445
  21. 21 Feb, 2009 1 commit
  22. 30 Jan, 2009 1 commit
  23. 29 Jan, 2009 2 commits