From a72ea5e34b6b325e7eb9736d9f9ae07e7b299ba8 Mon Sep 17 00:00:00 2001 From: Jeremy Allison Date: Wed, 13 Jun 2012 10:48:32 -0700 Subject: [PATCH] Fix bug #8972 - Directory group write permission bit is set if unix extensions are enabled We can't manipulate file_attributes if it's a posix call. (cherry picked from commit bb750d7232bd266c06a14ac3ea577aeecfb81b14) (cherry picked from commit fe7d9d85102613346a1365929f4545e43f412ab8) --- source3/smbd/open.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/source3/smbd/open.c b/source3/smbd/open.c index ded07a13761..dfa45ef739a 100644 --- a/source3/smbd/open.c +++ b/source3/smbd/open.c @@ -2296,8 +2296,10 @@ static NTSTATUS open_directory(connection_struct *conn, SMB_ASSERT(!is_ntfs_stream_smb_fname(smb_dname)); - /* Ensure we have a directory attribute. */ - file_attributes |= FILE_ATTRIBUTE_DIRECTORY; + if (!(file_attributes & FILE_FLAG_POSIX_SEMANTICS)) { + /* Ensure we have a directory attribute. */ + file_attributes |= FILE_ATTRIBUTE_DIRECTORY; + } DEBUG(5,("open_directory: opening directory %s, access_mask = 0x%x, " "share_access = 0x%x create_options = 0x%x, " -- 2.11.4.GIT