[SCM] Samba Shared Repository - branch v4-4-test updated

Stefan Metzmacher metze at samba.org
Wed Jul 12 06:57:17 UTC 2017


The branch, v4-4-test has been updated
       via  c8dea65 Revert "s3: locking: Move two leases functions into a new file."
       via  8d23e33 Revert "s3: locking: Update oplock optimization for the leases era !"
      from  a709729 VERSION: Bump version up to 4.4.15.

https://git.samba.org/?p=samba.git;a=shortlog;h=v4-4-test


- Log -----------------------------------------------------------------
commit c8dea6522d9a202e04a8fe2334bff6571df55480
Author: Stefan Metzmacher <metze at samba.org>
Date:   Wed Jul 12 08:49:30 2017 +0200

    Revert "s3: locking: Move two leases functions into a new file."
    
    This reverts commit 419f5cca88fa31d723f4bfe243d72398d4445801.
    
    This should not have been in 4-4-test, see
    https://bugzilla.samba.org/show_bug.cgi?id=12628#c6
    v4-4-test is in the security fixes only mode.
    
    This also introduces a regression that's fixed in v4-5 and higer only,
    see https://bugzilla.samba.org/show_bug.cgi?id=12798
    
    Signed-off-by: Stefan Metzmacher <metze at samba.org>

commit 8d23e3321d7c7013530969d354b8e47f1724ba93
Author: Stefan Metzmacher <metze at samba.org>
Date:   Wed Jul 12 08:47:33 2017 +0200

    Revert "s3: locking: Update oplock optimization for the leases era !"
    
    This reverts commit 2e00feb278e174fd28d003c4d5a576f91c0bd7d0.
    
    This should not have been in 4-4-test, see
    https://bugzilla.samba.org/show_bug.cgi?id=12628#c6
    v4-4-test is in the security fixes only mode.
    
    This also introduces a regression that's fixed in v4-5 and higer only,
    see https://bugzilla.samba.org/show_bug.cgi?id=12798
    
    Signed-off-by: Stefan Metzmacher <metze at samba.org>

-----------------------------------------------------------------------

Summary of changes:
 source3/locking/leases_util.c | 55 -------------------------------------------
 source3/locking/locking.c     | 22 +++++++----------
 source3/locking/proto.h       |  4 ----
 source3/smbd/files.c          |  8 +++++++
 source3/smbd/oplock.c         | 22 +++++++++++++++++
 source3/smbd/proto.h          |  2 ++
 source3/wscript_build         |  6 -----
 7 files changed, 41 insertions(+), 78 deletions(-)
 delete mode 100644 source3/locking/leases_util.c


Changeset truncated at 500 lines:

diff --git a/source3/locking/leases_util.c b/source3/locking/leases_util.c
deleted file mode 100644
index cb307c8..0000000
--- a/source3/locking/leases_util.c
+++ /dev/null
@@ -1,55 +0,0 @@
-/*
-   Unix SMB/CIFS implementation.
-   Lease utility functions
-
-   Copyright (C) Jeremy Allison 2017.
-   Copyright (C) Stefan (metze) Metzmacher 2017.
-
-   This program is free software; you can redistribute it and/or modify
-   it under the terms of the GNU General Public License as published by
-   the Free Software Foundation; either version 3 of the License, or
-   (at your option) any later version.
-
-   This program is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-   GNU General Public License for more details.
-
-   You should have received a copy of the GNU General Public License
-   along with this program.  If not, see <http://www.gnu.org/licenses/>.
-*/
-
-#define DBGC_CLASS DBGC_LOCKING
-#include "includes.h"
-#include "../librpc/gen_ndr/open_files.h"
-#include "locking/proto.h"
-
-uint32_t map_oplock_to_lease_type(uint16_t op_type)
-{
-	uint32_t ret;
-
-	switch(op_type) {
-	case BATCH_OPLOCK:
-	case BATCH_OPLOCK|EXCLUSIVE_OPLOCK:
-		ret = SMB2_LEASE_READ|SMB2_LEASE_WRITE|SMB2_LEASE_HANDLE;
-		break;
-	case EXCLUSIVE_OPLOCK:
-		ret = SMB2_LEASE_READ|SMB2_LEASE_WRITE;
-		break;
-	case LEVEL_II_OPLOCK:
-		ret = SMB2_LEASE_READ;
-		break;
-	default:
-		ret = SMB2_LEASE_NONE;
-		break;
-	}
-	return ret;
-}
-
-uint32_t fsp_lease_type(struct files_struct *fsp)
-{
-	if (fsp->oplock_type == LEASE_OPLOCK) {
-		return fsp->lease->lease.lease_state;
-	}
-	return map_oplock_to_lease_type(fsp->oplock_type);
-}
diff --git a/source3/locking/locking.c b/source3/locking/locking.c
index e6d3918..5a97460 100644
--- a/source3/locking/locking.c
+++ b/source3/locking/locking.c
@@ -118,21 +118,17 @@ bool strict_lock_default(files_struct *fsp, struct lock_struct *plock)
 	}
 
 	if (strict_locking == Auto) {
-		uint32_t lease_type = fsp_lease_type(fsp);
-
-		if ((lease_type & SMB2_LEASE_READ) &&
-		     (plock->lock_type == READ_LOCK))
-		{
-			DBG_DEBUG("optimisation - read lease on file %s\n",
-				  fsp_str_dbg(fsp));
+		if  (EXCLUSIVE_OPLOCK_TYPE(fsp->oplock_type) &&
+		     (plock->lock_type == READ_LOCK ||
+		      plock->lock_type == WRITE_LOCK)) {
+			DEBUG(10, ("is_locked: optimisation - exclusive oplock "
+				   "on file %s\n", fsp_str_dbg(fsp)));
 			return true;
 		}
-
-		if ((lease_type & SMB2_LEASE_WRITE) &&
-		     (plock->lock_type == WRITE_LOCK))
-		{
-			DBG_DEBUG("optimisation - write lease on file %s\n",
-				  fsp_str_dbg(fsp));
+		if ((fsp->oplock_type == LEVEL_II_OPLOCK) &&
+		    (plock->lock_type == READ_LOCK)) {
+			DEBUG(10, ("is_locked: optimisation - level II oplock "
+				   "on file %s\n", fsp_str_dbg(fsp)));
 			return true;
 		}
 	}
diff --git a/source3/locking/proto.h b/source3/locking/proto.h
index 4fc8da8..8ff1c7c 100644
--- a/source3/locking/proto.h
+++ b/source3/locking/proto.h
@@ -247,8 +247,4 @@ bool release_posix_lock_posix_flavour(files_struct *fsp,
 				const struct lock_struct *plocks,
 				int num_locks);
 
-/* The following definitions come from locking/leases_util.c */
-uint32_t map_oplock_to_lease_type(uint16_t op_type);
-uint32_t fsp_lease_type(struct files_struct *fsp);
-
 #endif /* _LOCKING_PROTO_H_ */
diff --git a/source3/smbd/files.c b/source3/smbd/files.c
index ada8bfc..8fefddd 100644
--- a/source3/smbd/files.c
+++ b/source3/smbd/files.c
@@ -773,3 +773,11 @@ const struct GUID *fsp_client_guid(const files_struct *fsp)
 {
 	return &fsp->conn->sconn->client->connections->smb2.client.guid;
 }
+
+uint32_t fsp_lease_type(struct files_struct *fsp)
+{
+	if (fsp->oplock_type == LEASE_OPLOCK) {
+		return fsp->lease->lease.lease_state;
+	}
+	return map_oplock_to_lease_type(fsp->oplock_type);
+}
diff --git a/source3/smbd/oplock.c b/source3/smbd/oplock.c
index f94d9cc..56b4499 100644
--- a/source3/smbd/oplock.c
+++ b/source3/smbd/oplock.c
@@ -149,6 +149,28 @@ static void downgrade_file_oplock(files_struct *fsp)
 	TALLOC_FREE(fsp->oplock_timeout);
 }
 
+uint32_t map_oplock_to_lease_type(uint16_t op_type)
+{
+	uint32_t ret;
+
+	switch(op_type) {
+	case BATCH_OPLOCK:
+	case BATCH_OPLOCK|EXCLUSIVE_OPLOCK:
+		ret = SMB2_LEASE_READ|SMB2_LEASE_WRITE|SMB2_LEASE_HANDLE;
+		break;
+	case EXCLUSIVE_OPLOCK:
+		ret = SMB2_LEASE_READ|SMB2_LEASE_WRITE;
+		break;
+	case LEVEL_II_OPLOCK:
+		ret = SMB2_LEASE_READ;
+		break;
+	default:
+		ret = SMB2_LEASE_NONE;
+		break;
+	}
+	return ret;
+}
+
 uint32_t get_lease_type(const struct share_mode_data *d,
 			const struct share_mode_entry *e)
 {
diff --git a/source3/smbd/proto.h b/source3/smbd/proto.h
index 9103e6e..44a2daa 100644
--- a/source3/smbd/proto.h
+++ b/source3/smbd/proto.h
@@ -395,6 +395,7 @@ NTSTATUS file_name_hash(connection_struct *conn,
 NTSTATUS fsp_set_smb_fname(struct files_struct *fsp,
 			   const struct smb_filename *smb_fname_in);
 const struct GUID *fsp_client_guid(const files_struct *fsp);
+uint32_t fsp_lease_type(struct files_struct *fsp);
 
 /* The following definitions come from smbd/ipc.c  */
 
@@ -677,6 +678,7 @@ NTSTATUS get_relative_fid_filename(connection_struct *conn,
 
 /* The following definitions come from smbd/oplock.c  */
 
+uint32_t map_oplock_to_lease_type(uint16_t op_type);
 uint32_t get_lease_type(const struct share_mode_data *d,
 			const struct share_mode_entry *e);
 bool update_num_read_oplocks(files_struct *fsp, struct share_mode_lock *lck);
diff --git a/source3/wscript_build b/source3/wscript_build
index 2bd684e..dabe262b 100755
--- a/source3/wscript_build
+++ b/source3/wscript_build
@@ -625,7 +625,6 @@ bld.SAMBA3_LIBRARY('smbd_base',
                    RPC_SERVICE
                    NDR_SMBXSRV
                    LEASES_DB
-		   LEASES_UTIL
                    LIBASYS
                    sysquotas
                    NDR_SMB_ACL
@@ -647,7 +646,6 @@ bld.SAMBA3_SUBSYSTEM('LOCKING',
                     tdb
                     talloc
                     LEASES_DB
-		    LEASES_UTIL
                     NDR_OPEN_FILES
                     FNAME_UTIL''')
 
@@ -655,10 +653,6 @@ bld.SAMBA3_SUBSYSTEM('LEASES_DB',
                     source='locking/leases_db.c',
                     deps='NDR_LEASES_DB')
 
-bld.SAMBA3_SUBSYSTEM('LEASES_UTIL',
-                    source='locking/leases_util.c',
-                    deps='NDR_OPEN_FILES')
-
 if bld.CONFIG_GET("WITH_PROFILE"):
     bld.SAMBA3_SUBSYSTEM('PROFILE',
                          source='profile/profile.c',


-- 
Samba Shared Repository



More information about the samba-cvs mailing list