⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 oplock.c

📁 samba最新软件
💻 C
📖 第 1 页 / 共 5 页
字号:
	CHECK_STATUS(tctx, status, NT_STATUS_OK);	CHECK_VAL(break_info.count, 1);	CHECK_VAL(break_info.failures, 0);	CHECK_VAL(break_info.level, OPLOCK_BREAK_TO_NONE);	smbcli_close(cli1->tree, fnum);done:	smb_raw_exit(cli1->session);	smb_raw_exit(cli2->session);	smbcli_deltree(cli1->tree, BASEDIR);	return ret;}static bool test_raw_oplock_exclusive4(struct torture_context *tctx, struct smbcli_state *cli1, struct smbcli_state *cli2){	const char *fname = BASEDIR "\\test_exclusive4.dat";	NTSTATUS status;	bool ret = true;	union smb_open io;	uint16_t fnum=0, fnum2=0;	if (!torture_setup_dir(cli1, BASEDIR)) {		return false;	}	/* cleanup */	smbcli_unlink(cli1->tree, fname);	smbcli_oplock_handler(cli1->transport, oplock_handler_ack_to_given, cli1->tree);	/*	  base ntcreatex parms	*/	io.generic.level = RAW_OPEN_NTCREATEX;	io.ntcreatex.in.root_fid = 0;	io.ntcreatex.in.access_mask = SEC_RIGHTS_FILE_ALL;	io.ntcreatex.in.alloc_size = 0;	io.ntcreatex.in.file_attr = FILE_ATTRIBUTE_NORMAL;	io.ntcreatex.in.share_access = NTCREATEX_SHARE_ACCESS_NONE;	io.ntcreatex.in.open_disposition = NTCREATEX_DISP_OPEN_IF;	io.ntcreatex.in.create_options = 0;	io.ntcreatex.in.impersonation = NTCREATEX_IMPERSONATION_ANONYMOUS;	io.ntcreatex.in.security_flags = 0;	io.ntcreatex.in.fname = fname;	torture_comment(tctx, "EXCLUSIVE4: open with exclusive oplock\n");	ZERO_STRUCT(break_info);	smbcli_oplock_handler(cli1->transport, oplock_handler_ack_to_given, cli1->tree);	io.ntcreatex.in.flags = NTCREATEX_FLAGS_EXTENDED | NTCREATEX_FLAGS_REQUEST_OPLOCK;	status = smb_raw_open(cli1->tree, tctx, &io);	CHECK_STATUS(tctx, status, NT_STATUS_OK);	fnum = io.ntcreatex.out.file.fnum;	CHECK_VAL(io.ntcreatex.out.oplock_level, EXCLUSIVE_OPLOCK_RETURN);	ZERO_STRUCT(break_info);	torture_comment(tctx, "second open with attributes only shouldn't cause oplock break\n");	io.ntcreatex.in.flags = NTCREATEX_FLAGS_EXTENDED | NTCREATEX_FLAGS_REQUEST_OPLOCK;	io.ntcreatex.in.access_mask = SEC_FILE_READ_ATTRIBUTE|SEC_FILE_WRITE_ATTRIBUTE|SEC_STD_SYNCHRONIZE;	status = smb_raw_open(cli2->tree, tctx, &io);	CHECK_STATUS(tctx, status, NT_STATUS_OK);	fnum2 = io.ntcreatex.out.file.fnum;	CHECK_VAL(io.ntcreatex.out.oplock_level, NO_OPLOCK_RETURN);	CHECK_VAL(break_info.count, 0);	CHECK_VAL(break_info.failures, 0);	smbcli_close(cli1->tree, fnum);	smbcli_close(cli2->tree, fnum2);done:	smb_raw_exit(cli1->session);	smb_raw_exit(cli2->session);	smbcli_deltree(cli1->tree, BASEDIR);	return ret;}static bool test_raw_oplock_exclusive5(struct torture_context *tctx, struct smbcli_state *cli1, struct smbcli_state *cli2){	const char *fname = BASEDIR "\\test_exclusive5.dat";	NTSTATUS status;	bool ret = true;	union smb_open io;	uint16_t fnum=0, fnum2=0;	if (!torture_setup_dir(cli1, BASEDIR)) {		return false;	}	/* cleanup */	smbcli_unlink(cli1->tree, fname);	smbcli_oplock_handler(cli1->transport, oplock_handler_ack_to_given, cli1->tree);	smbcli_oplock_handler(cli2->transport, oplock_handler_ack_to_given, cli1->tree);	/*	  base ntcreatex parms	*/	io.generic.level = RAW_OPEN_NTCREATEX;	io.ntcreatex.in.root_fid = 0;	io.ntcreatex.in.access_mask = SEC_RIGHTS_FILE_ALL;	io.ntcreatex.in.alloc_size = 0;	io.ntcreatex.in.file_attr = FILE_ATTRIBUTE_NORMAL;	io.ntcreatex.in.share_access = NTCREATEX_SHARE_ACCESS_NONE;	io.ntcreatex.in.open_disposition = NTCREATEX_DISP_OPEN_IF;	io.ntcreatex.in.create_options = 0;	io.ntcreatex.in.impersonation = NTCREATEX_IMPERSONATION_ANONYMOUS;	io.ntcreatex.in.security_flags = 0;	io.ntcreatex.in.fname = fname;	torture_comment(tctx, "EXCLUSIVE5: open with exclusive oplock\n");	ZERO_STRUCT(break_info);	smbcli_oplock_handler(cli1->transport, oplock_handler_ack_to_given, cli1->tree);	io.ntcreatex.in.flags = NTCREATEX_FLAGS_EXTENDED | NTCREATEX_FLAGS_REQUEST_OPLOCK;	io.ntcreatex.in.share_access = NTCREATEX_SHARE_ACCESS_READ|		NTCREATEX_SHARE_ACCESS_WRITE|		NTCREATEX_SHARE_ACCESS_DELETE;	status = smb_raw_open(cli1->tree, tctx, &io);	CHECK_STATUS(tctx, status, NT_STATUS_OK);	fnum = io.ntcreatex.out.file.fnum;	CHECK_VAL(io.ntcreatex.out.oplock_level, EXCLUSIVE_OPLOCK_RETURN);	ZERO_STRUCT(break_info);	torture_comment(tctx, "second open with attributes only and NTCREATEX_DISP_OVERWRITE_IF dispostion causes oplock break\n");	io.ntcreatex.in.flags = NTCREATEX_FLAGS_EXTENDED | NTCREATEX_FLAGS_REQUEST_OPLOCK;	io.ntcreatex.in.access_mask = SEC_FILE_READ_ATTRIBUTE|SEC_FILE_WRITE_ATTRIBUTE|SEC_STD_SYNCHRONIZE;	io.ntcreatex.in.open_disposition = NTCREATEX_DISP_OVERWRITE_IF;	status = smb_raw_open(cli2->tree, tctx, &io);	CHECK_STATUS(tctx, status, NT_STATUS_OK);	fnum2 = io.ntcreatex.out.file.fnum;	CHECK_VAL(io.ntcreatex.out.oplock_level, LEVEL_II_OPLOCK_RETURN);	CHECK_VAL(break_info.count, 1);	CHECK_VAL(break_info.failures, 0);	smbcli_close(cli1->tree, fnum);	smbcli_close(cli2->tree, fnum2);done:	smb_raw_exit(cli1->session);	smb_raw_exit(cli2->session);	smbcli_deltree(cli1->tree, BASEDIR);	return ret;}static bool test_raw_oplock_exclusive6(struct torture_context *tctx, struct smbcli_state *cli1, struct smbcli_state *cli2){	const char *fname1 = BASEDIR "\\test_exclusive6_1.dat";	const char *fname2 = BASEDIR "\\test_exclusive6_2.dat";	NTSTATUS status;	bool ret = true;	union smb_open io;	union smb_rename rn;	uint16_t fnum=0;	if (!torture_setup_dir(cli1, BASEDIR)) {		return false;	}	/* cleanup */	smbcli_unlink(cli1->tree, fname1);	smbcli_unlink(cli1->tree, fname2);	smbcli_oplock_handler(cli1->transport, oplock_handler_ack_to_given, cli1->tree);	/*	  base ntcreatex parms	*/	io.generic.level = RAW_OPEN_NTCREATEX;	io.ntcreatex.in.root_fid = 0;	io.ntcreatex.in.access_mask = SEC_RIGHTS_FILE_ALL;	io.ntcreatex.in.alloc_size = 0;	io.ntcreatex.in.file_attr = FILE_ATTRIBUTE_NORMAL;	io.ntcreatex.in.share_access = NTCREATEX_SHARE_ACCESS_NONE;	io.ntcreatex.in.open_disposition = NTCREATEX_DISP_OPEN_IF;	io.ntcreatex.in.create_options = 0;	io.ntcreatex.in.impersonation = NTCREATEX_IMPERSONATION_ANONYMOUS;	io.ntcreatex.in.security_flags = 0;	io.ntcreatex.in.fname = fname1;	torture_comment(tctx, "EXCLUSIVE6: open a file with an exclusive oplock (share mode: none)\n");	ZERO_STRUCT(break_info);	io.ntcreatex.in.flags = NTCREATEX_FLAGS_EXTENDED | NTCREATEX_FLAGS_REQUEST_OPLOCK;	status = smb_raw_open(cli1->tree, tctx, &io);	CHECK_STATUS(tctx, status, NT_STATUS_OK);	fnum = io.ntcreatex.out.file.fnum;	CHECK_VAL(io.ntcreatex.out.oplock_level, EXCLUSIVE_OPLOCK_RETURN);	torture_comment(tctx, "rename should not generate a break but get a sharing violation\n");	ZERO_STRUCT(rn);	rn.generic.level = RAW_RENAME_RENAME;	rn.rename.in.pattern1 = fname1;	rn.rename.in.pattern2 = fname2;	rn.rename.in.attrib = 0;	printf("trying rename while first file open\n");	status = smb_raw_rename(cli2->tree, &rn);	CHECK_STATUS(tctx, status, NT_STATUS_SHARING_VIOLATION);	CHECK_VAL(break_info.count, 0);	CHECK_VAL(break_info.failures, 0);	smbcli_close(cli1->tree, fnum);done:	smb_raw_exit(cli1->session);	smb_raw_exit(cli2->session);	smbcli_deltree(cli1->tree, BASEDIR);	return ret;}static bool test_raw_oplock_batch1(struct torture_context *tctx, struct smbcli_state *cli1, struct smbcli_state *cli2){	const char *fname = BASEDIR "\\test_batch1.dat";	NTSTATUS status;	bool ret = true;	union smb_open io;	union smb_unlink unl;	uint16_t fnum=0;	char c = 0;	if (!torture_setup_dir(cli1, BASEDIR)) {		return false;	}	/* cleanup */	smbcli_unlink(cli1->tree, fname);	smbcli_oplock_handler(cli1->transport, oplock_handler_ack_to_given, cli1->tree);	/*	  base ntcreatex parms	*/	io.generic.level = RAW_OPEN_NTCREATEX;	io.ntcreatex.in.root_fid = 0;	io.ntcreatex.in.access_mask = SEC_RIGHTS_FILE_ALL;	io.ntcreatex.in.alloc_size = 0;	io.ntcreatex.in.file_attr = FILE_ATTRIBUTE_NORMAL;	io.ntcreatex.in.share_access = NTCREATEX_SHARE_ACCESS_NONE;	io.ntcreatex.in.open_disposition = NTCREATEX_DISP_OPEN_IF;	io.ntcreatex.in.create_options = 0;	io.ntcreatex.in.impersonation = NTCREATEX_IMPERSONATION_ANONYMOUS;	io.ntcreatex.in.security_flags = 0;	io.ntcreatex.in.fname = fname;	/*	  with a batch oplock we get a break	*/	torture_comment(tctx, "BATCH1: open with batch oplock\n");	ZERO_STRUCT(break_info);	io.ntcreatex.in.flags = NTCREATEX_FLAGS_EXTENDED | 		NTCREATEX_FLAGS_REQUEST_OPLOCK | 		NTCREATEX_FLAGS_REQUEST_BATCH_OPLOCK;	status = smb_raw_open(cli1->tree, tctx, &io);	CHECK_STATUS(tctx, status, NT_STATUS_OK);	fnum = io.ntcreatex.out.file.fnum;	CHECK_VAL(io.ntcreatex.out.oplock_level, BATCH_OPLOCK_RETURN);	torture_comment(tctx, "unlink should generate a break\n");	unl.unlink.in.pattern = fname;	unl.unlink.in.attrib = 0;	status = smb_raw_unlink(cli2->tree, &unl);	CHECK_STATUS(tctx, status, NT_STATUS_SHARING_VIOLATION);	CHECK_VAL(break_info.count, 1);	CHECK_VAL(break_info.fnum, fnum);	CHECK_VAL(break_info.level, OPLOCK_BREAK_TO_LEVEL_II);	CHECK_VAL(break_info.failures, 0);	torture_comment(tctx, "2nd unlink should not generate a break\n");	ZERO_STRUCT(break_info);	status = smb_raw_unlink(cli2->tree, &unl);	CHECK_STATUS(tctx, status, NT_STATUS_SHARING_VIOLATION);	CHECK_VAL(break_info.count, 0);	torture_comment(tctx, "writing should generate a self break to none\n");	smbcli_write(cli1->tree, fnum, 0, &c, 0, 1);	msleep(100);	smbcli_write(cli1->tree, fnum, 0, &c, 1, 1);	CHECK_VAL(break_info.count, 1);	CHECK_VAL(break_info.fnum, fnum);	CHECK_VAL(break_info.level, OPLOCK_BREAK_TO_NONE);	CHECK_VAL(break_info.failures, 0);	smbcli_close(cli1->tree, fnum);done:	smb_raw_exit(cli1->session);	smb_raw_exit(cli2->session);	smbcli_deltree(cli1->tree, BASEDIR);	return ret;}static bool test_raw_oplock_batch2(struct torture_context *tctx, struct smbcli_state *cli1, struct smbcli_state *cli2){	const char *fname = BASEDIR "\\test_batch2.dat";	NTSTATUS status;	bool ret = true;	union smb_open io;	union smb_unlink unl;	uint16_t fnum=0;	char c = 0;	if (!torture_setup_dir(cli1, BASEDIR)) {		return false;	}	/* cleanup */	smbcli_unlink(cli1->tree, fname);	smbcli_oplock_handler(cli1->transport, oplock_handler_ack_to_given, cli1->tree);	/*	  base ntcreatex parms	*/	io.generic.level = RAW_OPEN_NTCREATEX;	io.ntcreatex.in.root_fid = 0;	io.ntcreatex.in.access_mask = SEC_RIGHTS_FILE_ALL;	io.ntcreatex.in.alloc_size = 0;	io.ntcreatex.in.file_attr = FILE_ATTRIBUTE_NORMAL;	io.ntcreatex.in.share_access = NTCREATEX_SHARE_ACCESS_NONE;	io.ntcreatex.in.open_disposition = NTCREATEX_DISP_OPEN_IF;	io.ntcreatex.in.create_options = 0;	io.ntcreatex.in.impersonation = NTCREATEX_IMPERSONATION_ANONYMOUS;	io.ntcreatex.in.security_flags = 0;	io.ntcreatex.in.fname = fname;	torture_comment(tctx, "BATCH2: open with batch oplock\n");	ZERO_STRUCT(break_info);	io.ntcreatex.in.flags = NTCREATEX_FLAGS_EXTENDED | 		NTCREATEX_FLAGS_REQUEST_OPLOCK | 		NTCREATEX_FLAGS_REQUEST_BATCH_OPLOCK;	status = smb_raw_open(cli1->tree, tctx, &io);	CHECK_STATUS(tctx, status, NT_STATUS_OK);	fnum = io.ntcreatex.out.file.fnum;	CHECK_VAL(io.ntcreatex.out.oplock_level, BATCH_OPLOCK_RETURN);	torture_comment(tctx, "unlink should generate a break, which we ack as break to none\n");	smbcli_oplock_handler(cli1->transport, oplock_handler_ack_to_none, cli1->tree);	unl.unlink.in.pattern = fname;	unl.unlink.in.attrib = 0;	status = smb_raw_unlink(cli2->tree, &unl);	CHECK_STATUS(tctx, status, NT_STATUS_SHARING_VIOLATION);	CHECK_VAL(break_info.count, 1);	CHECK_VAL(break_info.fnum, fnum);	CHECK_VAL(break_info.level, OPLOCK_BREAK_TO_LEVEL_II);	CHECK_VAL(break_info.failures, 0);	torture_comment(tctx, "2nd unlink should not generate a break\n");	ZERO_STRUCT(break_info);	status = smb_raw_unlink(cli2->tree, &unl);	CHECK_STATUS(tctx, status, NT_STATUS_SHARING_VIOLATION);	CHECK_VAL(break_info.count, 0);	torture_comment(tctx, "writing should not generate a break\n");	smbcli_write(cli1->tree, fnum, 0, &c, 0, 1);	msleep(100);	smbcli_write(cli1->tree, fnum, 0, &c, 1, 1);	CHECK_VAL(break_info.count, 0);	smbcli_close(cli1->tree, fnum);done:	smb_raw_exit(cli1->session);	smb_raw_exit(cli2->session);	smbcli_deltree(cli1->tree, BASEDIR);	return ret;}static bool test_raw_oplock_batch3(struct torture_context *tctx, struct smbcli_state *cli1, struct smbcli_state *cli2){	const char *fname = BASEDIR "\\test_batch3.dat";	NTSTATUS status;	bool ret = true;	union smb_open io;	union smb_unlink unl;	uint16_t fnum=0;	if (!torture_setup_dir(cli1, BASEDIR)) {		return false;	}	/* cleanup */	smbcli_unlink(cli1->tree, fname);	smbcli_oplock_handler(cli1->transport, oplock_handler_ack_to_given, cli1->tree);	/*	  base ntcreatex parms	*/	io.generic.level = RAW_OPEN_NTCREATEX;	io.ntcreatex.in.root_fid = 0;	io.ntcreatex.in.access_mask = SEC_RIGHTS_FILE_ALL;	io.ntcreatex.in.alloc_size = 0;	io.ntcreatex.in.file_attr = FILE_ATTRIBUTE_NORMAL;	io.ntcreatex.in.share_access = NTCREATEX_SHARE_ACCESS_NONE;	io.ntcreatex.in.open_disposition = NTCREATEX_DISP_OPEN_IF;	io.ntcreatex.in.create_options = 0;	io.ntcreatex.in.impersonation = NTCREATEX_IMPERSONATION_ANONYMOUS;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -