diff options
author | Volker Lendecke <vl@samba.org> | 2009-05-18 09:36:16 +0200 |
---|---|---|
committer | Volker Lendecke <vl@samba.org> | 2009-05-18 10:42:22 +0200 |
commit | 8b9c5f04831216aa3d3b89fd2a81be12ac8592dd (patch) | |
tree | d5c96e7e84d7b09a35ff759ab5ce11f6a656a89e | |
parent | f140bf2e6578e45b8603d4a6c5feef9a3b735804 (diff) | |
download | samba-8b9c5f04831216aa3d3b89fd2a81be12ac8592dd.tar.gz samba-8b9c5f04831216aa3d3b89fd2a81be12ac8592dd.tar.bz2 samba-8b9c5f04831216aa3d3b89fd2a81be12ac8592dd.zip |
Fix a race condition in vfs_aio_fork with gpfs share modes
-rw-r--r-- | source3/modules/vfs_aio_fork.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/source3/modules/vfs_aio_fork.c b/source3/modules/vfs_aio_fork.c index 8568ec3916..e706495a56 100644 --- a/source3/modules/vfs_aio_fork.c +++ b/source3/modules/vfs_aio_fork.c @@ -357,6 +357,14 @@ static void aio_child_loop(int sockfd, struct mmap_area *map) ret_struct.ret_errno = errno; } + /* + * Close the fd before telling our parent we're done. The + * parent might close and re-open the file very quickly, and + * with system-level share modes (GPFS) we would get an + * unjustified SHARING_VIOLATION. + */ + close(fd); + ret = write_data(sockfd, (char *)&ret_struct, sizeof(ret_struct)); if (ret != sizeof(ret_struct)) { @@ -364,8 +372,6 @@ static void aio_child_loop(int sockfd, struct mmap_area *map) strerror(errno))); exit(2); } - - close(fd); } } |