summaryrefslogtreecommitdiffstats
path: root/source3/modules
Commit message (Collapse)AuthorAgeFilesLines
...
* In aio_fork, we have to close all fd's, we might hold a gpfs share modeVolker Lendecke2009-05-181-0/+16
| | | | Keeping such an fd open prohibits another open of that same file.
* Fix a race condition in vfs_aio_fork with gpfs share modesVolker Lendecke2009-05-181-2/+8
|
* s3 onefs: Self-contend level2 oplocks on BRLZack Kirsch2009-05-121-1/+14
|
* s3 onefs: Fix ignore sacl parameterTim Prouty2009-05-124-24/+36
|
* Clean up assignments to iov_base, ensure it's always cast to void *. This ↵Jeremy Allison2009-05-122-4/+4
| | | | | | should quieten some warnings with picky compilers on the buildfarm. Jeremy.
* Fix a bunch of compiler warnings about wrong format types.Jeremy Allison2009-05-111-7/+7
| | | | | Should make Solaris 10 builds look cleaner. Jeremy.
* s3 onefs: Turn up the debug level for non-error casestprouty2009-05-051-3/+3
|
* s3: Fix trans2 path to use case-insensitive stat optimizationtprouty2009-05-051-2/+6
| | | | | | | | | | | | | | | | | | | | Often times before creating a file, a client will first query to see if it already exists. Since some systems have a case-insensitive stat that is called from unix_convert, we can definitively return STATUS_NO_SUCH_FILE to the client without scanning the whole directory. This code path is taken from trans2querypathinfo, but trans2findfirst still does a full directory scan even though the get_real_filename (the case-insensitive stat vfs call) can prevent this. This patch adds the get_real_filename call to the trans2find* path, and also changes the vfs_default behavior for SMB_VFS_GET_REAL_FILENAME. Previously, in the absence of a get_real_filename implementation, we would fallback to the full directory scan. The default behavior now returns -1 and sets errno to EOPNOTSUPP. This allows SMB_VFS_GET_REALFILENAME to be called from trans2* and unix_convert.
* s3:onefs.so Change system function namesSteven Danneman2009-05-051-4/+4
| | | | Addendum to c49730e1. Use newer cookie conversion names.
* s3:onefs.so fix issue with missing entries when enumerating directoriesSteven Danneman2009-05-041-130/+75
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This bug prompted several, fairly large changes to the of OneFS's readdirplus() within Samba. One fundamental problem is that we kept our cache cursor pointed at the next entry to be returned from onefs_readdir(), while the resume cookie needed to refill the cache such that our cursor would be on this entry, was located in the previous cache entry. This meant that to correctly handle seekdir() cases which could be found within the existing cache, and cases where a cache reload was needed, required that the cache always hold at least two entries: the entry we wished to return, and the previous entry which held the resume cookie. Since the readdirplus() syscall gives us no guarantee that it will always return these two direntries, there was a fundamental problem with this design. To fix this problem, I have rearchitected the onefs_readdir() path to keep its pointer on the entry which contains the resume_cookie, not the entry which will be returned next. Essentially, I changed onefs_readdir() from a "return an entry then increment the cursor" model to "increment the cursor then return an entry". By doing this, we only require that a single entry be within the cache: the entry containing the resume cookie. Second, there have been numerous off-by-one bugs in my implementation of onefs_seekdir() which did a mapping between the 64-bit resume cookie returned by readdirplus() and its own monotonically increasing "location" offset. Furthermore, this design caused a somewhat frequent waste of cycles, as in some cases we'd need to re-enumerate the entire directory to recover the current "location" from an old resume cookie. As this code was somewhat difficult to understand, prone to bugs, and innefficient in some cases I decided it was better to wholesale replace it now, rather than later. It is possible to algorithmically map the 64-bit resume cookies from readdirplus() into 32-bit offset values which SMB requires. The onefs.so module now calls into a system library to do this conversion. This greatly simplifies both the seekdir() and telldir() paths and is more efficient.
* Fix annoying debug messages when no snapshots are usedVolker Lendecke2009-04-281-2/+3
| | | | | | | Not being able to open the shadow copy directory is the same as having no shadow copy support at all. The VFS module should in this case not log with debug level 0 and set ENOSYS to indicate "no shadow copies used" to the higher levels.
* s3 onefs: Fix case-insensitivity for mangled namesTim Prouty2009-04-071-0/+12
| | | | | onefs_get_real_filename needs to demangle the filename before doing the case-insensitive estat
* Make some functions static to vfs_gpfs.cVolker Lendecke2009-04-061-14/+14
|
* Add prototype for smbd_gpfs_get_realfilename_pathVolker Lendecke2009-04-061-0/+2
|
* Fix two c++ warnings in vfs_gpfs.cVolker Lendecke2009-04-061-2/+2
|
* s3 onefs: Quiet a log message about oplocks being requested on streamsTim Prouty2009-04-011-21/+16
|
* s3 onefs: Add missing newlines to debug statements in the onefs moduleTim Prouty2009-03-314-15/+16
|
* s3 onefs: Async failures are resulting in SMB_ASSERT->smb_panic while ↵Zack Kirsch2009-03-311-2/+2
| | | | | | | running many of the LOCK torture tests. Return true from the onefs cancel function if we've errored, which can happen when the CBRL domain is configured to only give out 1 lock. :)
* s3: added per-client statistics to onefs perfcount moduleScott Urban2009-03-272-23/+38
| | | | | | * we now track, uid, remote ip, and local ip per CIFS operation * removed perfcount_set_client() from perfcount interface as it's unecessary
* Fix the build of nfsv4_acls.cVolker Lendecke2009-03-271-1/+1
| | | | .. after adding smb_iconv_convenience to ndr_size_security_descriptor()
* Try and fix the build farm RAW-STREAMS errors. Ordering ofJeremy Allison2009-03-261-2/+2
| | | | | | | modules shouldn't matter, so as vfs_streams_depot doesn't implement get/setxattrs then call into the full VFS stack at the top. Jeremy
* Add missing newlines to debug statementsSteven Danneman2009-03-251-2/+2
|
* s3 onefs: Change error status to NT_ACCESS_DENIED for errors in ↵David Kwan2009-03-241-5/+5
| | | | SET_SECURITY_DESC
* s3 OneFS: Remove usage of non-existant functionTim Prouty2009-03-231-9/+0
| | | | | The function was removed in: c16c90a1cb3b0e2ceadd3dea835a4e69acfc2fae
* Use StrCaseCmp in the dirsort moduleVolker Lendecke2009-03-221-1/+1
|
* Add dirsort moduleAndy Kelk2009-03-221-0/+194
|
* s3 onefs: Correctly error out when the read returns EOFTim Prouty2009-03-181-5/+9
| | | | Also add some more debugging.
* s3: Don't return in a void funtionTim Prouty2009-03-131-1/+1
|
* s3 OneFS: Add kernel strict locking supportDave Richards2009-03-133-10/+95
|
* s3: Add strict lock/unlock calls to the vfs layer to replace is_lockedDave Richards2009-03-132-0/+64
|
* Add a vfs_preopen module to hide fs latenciesVolker Lendecke2009-03-101-0/+456
|
* s3 OneFS: Use the public open_streams_for_deleteTim Prouty2009-03-041-113/+0
|
* Fix crashes when running RAW-ACLs against system with tdb ACL modulesJeremy Allison2009-03-042-3/+3
| | | | | (caused by the POSIX pathname fixes). Jeremy.
* Make use of gpfs_get_real_filename optionalVolker Lendecke2009-03-042-1/+10
|
* s3 OneFS: Add parameter to ignore streamsTim Prouty2009-03-034-3/+17
|
* s3 OneFS: Refactor config code and cleanup includesTim Prouty2009-03-0111-385/+453
|
* Use fsp->posix_open in preference if we have it.Jeremy Allison2009-02-252-7/+7
| | | | Jeremy.
* Ensure ACL modules work with POSIX paths.Jeremy Allison2009-02-252-22/+79
| | | | Jeremy.
* s3 OneFS: Add .snapshot directory configuration handlingTim Prouty2009-02-254-27/+201
|
* Fix use of streams modules with CIFSFS client.Jeremy Allison2009-02-252-4/+25
| | | | Jeremy.
* s3 OneFS: Fix uninitialized variableTim Prouty2009-02-241-1/+1
|
* s3: onefs_acl.c cleanupDan Sledz2009-02-241-4/+1
| | | | | Remove some duplicate code. Add a \n to a debugging statement
* S3: Add in profile counters for new vfs and syscall entries.todd stecher2009-02-244-6/+65
|
* s3 OneFS: Add a parameter that unconditionally allows execute accessTim Prouty2009-02-232-0/+26
|
* More warning fixes for Solaris.Jeremy Allison2009-02-231-4/+4
| | | | Jeremy.
* More warning fixes for Solaris.Jeremy Allison2009-02-231-4/+5
| | | | Jeremy.
* Quieten down a boatload of shadowed variable warnings on Solaris.Jeremy Allison2009-02-232-47/+47
| | | | | Makes real problems easier to spot. Jeremy.
* s3 OneFS: Add an atomic sendfile implementationTim Prouty2009-02-213-0/+282
|
* s3 OneFS: Add debugging for createfile_flagsZack Kirsch2009-02-201-12/+15
|
* s3: OneFS implementation of change notifySteven Danneman2009-02-203-0/+691
| | | | | | | | | | | | | | | The OneFS Samba implementation of change notify is modeled after the usage of Linux's inotify kernel subsystem. A single call is made into the onefs.so VFS module to initialize kernel tracking of certain file change events. When these events occur a kernel notification is sent to smbd and the notification event is translated and given to the general Samba Change Notify layer through a callback function. The most difficult aspect is converting an SMB CompletionFilter to a matching ifs_event mask, and then back to an appropriate change notify action. Currently, not all possible cases are handled by the this module, but the most prevalent ones, which are tested by smbtorture, are implemented.