From 89b6af0982fc935c6b9b0f5aa2beea696b332709 Mon Sep 17 00:00:00 2001 From: Jeremy Allison Date: Fri, 18 Mar 2011 14:57:05 -0700 Subject: SMB2 renames return SHARING_VIOLATION if there is any existing oplock on a file. Autobuild-User: Jeremy Allison Autobuild-Date: Fri Mar 18 23:39:49 CET 2011 on sn-devel-104 --- source3/smbd/smb2_setinfo.c | 6 ++++++ 1 file changed, 6 insertions(+) (limited to 'source3/smbd/smb2_setinfo.c') diff --git a/source3/smbd/smb2_setinfo.c b/source3/smbd/smb2_setinfo.c index 9afb487dce..26d94e2b10 100644 --- a/source3/smbd/smb2_setinfo.c +++ b/source3/smbd/smb2_setinfo.c @@ -216,6 +216,12 @@ static struct tevent_req *smbd_smb2_setinfo_send(TALLOC_CTX *mem_ctx, if (file_info_level == SMB_FILE_RENAME_INFORMATION) { /* SMB2_FILE_RENAME_INFORMATION_INTERNAL == 0xFF00 + in_file_info_class */ file_info_level = SMB2_FILE_RENAME_INFORMATION_INTERNAL; + if (fsp->oplock_type != FAKE_LEVEL_II_OPLOCK && + fsp->oplock_type != NO_OPLOCK) { + /* No break, but error. */ + tevent_req_nterror(req, NT_STATUS_SHARING_VIOLATION); + return tevent_req_post(req, ev); + } } if (fsp->fh->fd == -1) { -- cgit