亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? iscsi_target.c

?? iscsi源代碼 UNH的progect 有initiator端和target端的源碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
/*	target/iscsi_target.c	vi: set autoindent tabstop=4 shiftwidth=4 : 	This is the iscsi target front-end which interfaces with the STML.	The front-end has been written to the specifications of Draft 20 of the	iSCSI spec.*//*	Copyright (C) 2001-2004 InterOperability Lab (IOL)							University of New Hampshier (UNH)							Durham, NH 03824	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 2, 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, write to the Free Software	Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,	USA.	The name IOL and/or UNH may not be used to endorse or promote products	derived from this software without specific prior written permission.*/#if !defined(MANGLE_INQUIRY_DATA)#define MANGLE_INQUIRY_DATA#endif#include "iscsi_target.h"#include "target_error_rec.h"#include <net/sock.h>#include <linux/netdevice.h>#include <linux/inetdevice.h>#include <net/if_inet6.h>#include <net/ipv6.h>#include <net/addrconf.h>/* added by RDR when rcu_read_lock(), rcu_read_ulock() came in with 2.6.10 * These macros define it the way it was in 2.4 and in earlier versions of 2.6 */#ifndef rcu_read_lock#define rcu_read_lock()	read_lock(&inetdev_lock)#endif#ifndef rcu_read_unlock#define rcu_read_unlock()	read_unlock(&inetdev_lock)#endifstatic void clean_bad_stuff(void);static int iscsi_release_connection(struct iscsi_conn *conn);static int handle_login(struct iscsi_conn *conn, __u8 *buffer);static int handle_text_request(struct iscsi_conn *conn,							   struct iscsi_session *session,							   __u8 *buffer);static int handle_logout(struct iscsi_conn *conn,						 struct iscsi_session *session,						 __u8 *buffer);static int handle_nopout(struct iscsi_conn *conn,						 struct iscsi_session *session,						 __u8 *buffer);static int handle_cmnd(struct iscsi_conn *conn,					   struct iscsi_session *session,					   __u8 *buffer);static int handle_task_mgt_command(struct iscsi_conn *conn,								   struct iscsi_session *session,								   __u8 *buffer);static int handle_data(struct iscsi_conn *conn,					   struct iscsi_session *session,					   __u8 *buffer);static int send_unsolicited_data(struct iscsi_cmnd *cmnd,								 struct iscsi_conn *conn,								 struct iscsi_session *session);static void check_queued_cmnd(struct iscsi_session *session);static void free_data_list(struct iscsi_cmnd *cmnd);static struct iscsi_cmnd * __attribute__ ((no_instrument_function))search_iscsi_cmnd(Target_Scsi_Cmnd * cmnd, struct iscsi_session **result_sess);static struct iscsi_cmnd *search_task_mgt_command(Target_Scsi_Message *												  message);static struct iscsi_cmnd * __attribute__ ((no_instrument_function))search_tags(struct iscsi_conn *conn, __u32 init_task_tag,									 __u32 target_xfer_tag,									 int dumpall);static int handle_discovery_rsp(struct iscsi_cmnd *cmnd,								struct iscsi_conn *conn,								struct iscsi_session *session);static int ask_for_more_text(struct iscsi_cmnd *cmnd,							 struct iscsi_conn *conn,							 struct iscsi_session *session);static int handle_logout_rsp(struct iscsi_cmnd *cmnd,							 struct iscsi_conn *conn,							 struct iscsi_session *session);static int handle_nopin(struct iscsi_cmnd *cmnd,						struct iscsi_conn *conn,						struct iscsi_session *session);static int generate_nopin(struct iscsi_conn *conn,						  struct iscsi_session *session);static int handle_iscsi_done(struct iscsi_cmnd *cmnd,							 struct iscsi_conn *conn,							 struct iscsi_session *session);static int handle_iscsi_mgt_fn_done(struct iscsi_cmnd *cmnd,									struct iscsi_conn *conn,									struct iscsi_session *session);static void iscsi_dequeue(struct iscsi_cmnd *cmnd, struct iscsi_conn *conn);static int iscsi_tx_login_reject(struct iscsi_conn *conn,								 struct iscsi_init_login_cmnd *pdu,								 __u8 status_class,								 __u8 status_detail);static int iscsi_tx_r2t(struct iscsi_cmnd *cmnd,						struct iscsi_conn *conn,						struct iscsi_session *session);static intdequeue_reject(struct iscsi_conn *conn, int sendit);/* Added for handling SNACK requests - SAI */static int handle_snack(struct iscsi_conn *conn,						struct iscsi_session *session,						__u8 *buffer);static int send_iscsi_response(struct iscsi_cmnd *cmnd,							   struct iscsi_conn *conn,							   struct iscsi_session *session);/* Daren Hayward, darenh@4bridgeworks.com */#if defined(MANGLE_INQUIRY_DATA)static intmangle_inquiry_data(struct iscsi_cmnd *iscsi_command, struct iovec *iov,					int start_iov, int limit_iov);#endifstruct iscsi_global *devdata;/*  * initialize stuff in devdata. */static intinit_target(struct iscsi_global *devdata){	memset(devdata, 0, sizeof(struct iscsi_global));	INIT_LIST_HEAD(&devdata->session_list);	INIT_LIST_HEAD(&devdata->bad_session_list);	init_MUTEX(&devdata->session_sem);	init_MUTEX(&devdata->session_read_mutex);	init_MUTEX_LOCKED(&devdata->server_sem);	devdata->param_tbl = my_kmalloc(MAX_CONFIG_PARAMS							* sizeof(struct parameter_type), "param_tbl");	if (!(devdata->param_tbl)) {		return -1;	}	/* Copy the default parameters */	param_tbl_init(*devdata->param_tbl);	/* chap and srp support - CHONG */	devdata->auth_parameter.chap_local_ctx = CHAP_InitializeContext();	devdata->auth_parameter.chap_peer_ctx = CHAP_InitializeContext();	devdata->auth_parameter.srp_ctx = SRP_InitializeContext();	return 0;}voidbring_down_portals( void ){	int i;	struct portal_group *ptr;	for (i = 0, ptr = iscsi_portal_groups; i < MAX_PORTAL; i++, ptr++) {		if (ptr->in_use == 0)			continue;			if (devdata->server_thr[i]) {			/*  Mike Christie mikenc@us.ibm.com */			send_sig(ISCSI_SHUTDOWN_SIGNAL, devdata->server_thr[i], 1);			down_interruptible(&devdata->server_sem);		}			if (devdata->server_socket[i]) {			sock_release(devdata->server_socket[i]);			devdata->server_socket[i] = NULL;		}		my_kfree((void **)&ptr->ip_address, "ip_address");		if (ptr->in_use == 2)		{			my_kfree((void **)&ptr->ip_string, "ip_string");			my_kfree((void **)&ptr->port_string, "port_string");		}				ptr->in_use = 0;	}	if (devdata->param_tbl) {		param_tbl_uncpy(*devdata->param_tbl);		my_kfree((void**)&devdata->param_tbl, "param_tbl");	}	/* chap and srp support - CHONG */	CHAP_FinalizeContext(devdata->auth_parameter.chap_local_ctx);	CHAP_FinalizeContext(devdata->auth_parameter.chap_peer_ctx);	SRP_FinalizeContext(devdata->auth_parameter.srp_ctx);	my_kfree((void **)&devdata, "devdata");	/* check for any unfreed memory */	my_kempty();}int stop_server_thread (char *ip_string, char *port_string){	int i;		for (i = 0; i < MAX_PORTAL; i++)	{		if (iscsi_portal_groups[i].in_use == 0)			continue;			if ((strcmp(iscsi_portal_groups[i].ip_string, ip_string) == 0)			&& (strcmp(iscsi_portal_groups[i].port_string, port_string) == 0))		{			if (devdata->server_thr[i]) {				/*  Mike Christie mikenc@us.ibm.com */				send_sig(ISCSI_SHUTDOWN_SIGNAL, devdata->server_thr[i], 1);				down_interruptible(&devdata->server_sem);			}				if (devdata->server_socket[i]) {				sock_release(devdata->server_socket[i]);				devdata->server_socket[i] = NULL;			}			my_kfree((void **)&iscsi_portal_groups[i].ip_address, "ip_address");			if (iscsi_portal_groups[i].in_use == 2)			{				my_kfree((void **)&iscsi_portal_groups[i].ip_string, "ip_string");				my_kfree((void **)&iscsi_portal_groups[i].port_string, "port_string");			}			iscsi_portal_groups[i].in_use = 0;			return 0;		}	}	TRACE_ERROR("%s Can't find match with ip %s, port %s\n", current->comm,				ip_string, port_string);	return -1;}/* returns 0 on success, -1 on failure */intbring_up_portal( struct portal_group *ptr ){	int backlog = 5;	struct socket *sockptr;	TRACE(TRACE_DEBUG, "start_server_thread: ip_string %s, port_string %s\n",									ptr->ip_string,									ptr->port_string);		ptr->family = cnv_string_to_inet(									ptr->ip_string,									ptr->port_string,									&ptr->ip_address,									&ptr->ip_length);	if (ptr->family < 0) {		goto out;	}	/* create a socket */#ifdef FC2	if (sock_create(ptr->family, SOCK_STREAM, 0, &sockptr, 0) < 0) {#else	if (sock_create(ptr->family, SOCK_STREAM, 0, &sockptr) < 0) {#endif		TRACE_ERROR("%s Could not create socket on %s:%s\n", current->comm,					ptr->ip_string, ptr->port_string);		goto out1;	}	TRACE(TRACE_NET, "Socket %p created\n", sockptr);	/* bind */	if (sockptr->ops->bind(sockptr, ptr->ip_address, ptr->ip_length)) {		TRACE_ERROR("%s Could not bind socket on %s:%s\n", current->comm,					ptr->ip_string, ptr->port_string);		goto out2;	}	TRACE(TRACE_NET, "Socket %p bound\n", sockptr);	/*  turn on the option to reuse this socket's port quickly */	tcp_reuse_port(sockptr);	/* listen */	if ((sockptr->ops->listen(sockptr, backlog))) {		TRACE_ERROR("%s Could not listen with socket on %s:%s\n", current->comm,					ptr->ip_string, ptr->port_string);		goto out2;	}	devdata->server_socket[ptr - iscsi_portal_groups] = sockptr;	/* create a server_thread that can accept connections */	if (kernel_thread(iscsi_server_thread, (void *)ptr, 0) < 0) {		TRACE_ERROR("%s Unable to create server thread\n", current->comm);		devdata->server_socket[ptr - iscsi_portal_groups] = NULL;		goto out2;	}	TRACE(TRACE_NET, "Server_thread spawned for socket %p\n", sockptr);	/* wait for that server_thread to come up before continuing */	if (!down_interruptible(&devdata->server_sem))		return 0;	out2:	sock_release(sockptr);out1:	my_kfree((void **)&ptr->ip_address, "ip_address");out:	return -1;}int start_server_thread (char *ip_string, char *port_string, int tag){	int i;	struct portal_group *ptr;	if (!devdata) {		TRACE_ERROR("%s No device available\n", current->comm);		goto out;	}	for (i = 0, ptr = iscsi_portal_groups; i < MAX_PORTAL; i++, ptr++)	{		if (!ptr->in_use)			break;	}	if (i >= MAX_PORTAL)	{		TRACE_ERROR("%s No more portals permitted\n", current->comm);		goto out;	}	/* mark this portal in use with dynamic ip strings */	ptr->in_use = 2;		ptr->ip_string = (char *)my_kmalloc(strlen(ip_string)+1, "ip_string");	if (ptr->ip_string == NULL) {		goto out0;	}	strcpy(ptr->ip_string, ip_string);	ptr->port_string = (char *)my_kmalloc(strlen(port_string)+1,"port_string");	if (ptr->port_string == NULL) {		goto out1;	}	strcpy(ptr->port_string, port_string);	ptr->tag = tag;		if (bring_up_portal(ptr)) {		goto out2;	}	return 0;out2:	my_kfree((void **)&ptr->port_string, "port_string");out1:	my_kfree((void **)&ptr->ip_string, "ip_string");out0:	ptr->in_use = 0;out:	return -1;}/* * iscsi_detect: this function sets up the server so that it can accept  * multiple connections. */intiscsi_detect(Scsi_Target_Template * tmpt){	long i;	struct portal_group *ptr;	TRACE(TRACE_DEBUG, "Entering iSCSI detect\n");	devdata = (struct iscsi_global *)my_kmalloc(sizeof(struct iscsi_global),						     					"devdata");	if (!devdata) {		return -1;	}	/* Initialize devdata */	if (init_target(devdata) < 0) {		TRACE_ERROR("%s Initialize devdata failed\n", current->comm);		my_kfree((void **)&devdata, "devdata");		return -1;	}	/* setup the security key hash table */	setup_security_hash_table();	TRACE(TRACE_DEBUG, "iSCSI initialization completed\n");	for (i = 0, ptr = iscsi_portal_groups; i < MAX_PORTAL && ptr->tag != 0;																i++, ptr++) {		ptr->in_use = 1;		if (bring_up_portal(ptr)) {			ptr->in_use = 0;			goto out;		}	}	/* register the front end now */	devdata->device = register_target_front_end(tmpt);	if (!devdata->device) {		TRACE_ERROR("%s Device registration failed\n", current->comm);		goto out;	}	devdata->device->dev_specific = (void *) devdata;	TRACE(TRACE_DEBUG, "Registration complete\n");	return 1;					/* one device detected */out:	bring_down_portals();	return -2;}/* * iscsi_release: function to release the iSCSI device as required by * the Mid-Level */intiscsi_release(Scsi_Target_Device * device){	struct iscsi_session *session;	struct list_head *list_ptr, *list_temp;	int err = 0;	TRACE(TRACE_ENTER_LEAVE, "Enter iscsi_release\n");	if ((struct iscsi_global *) device->dev_specific != devdata) {		TRACE_ERROR("%s This is not an iscsi device\n", current->comm);		err = -1;		goto out;	}	/* destructive access to session lists */	if (!down_interruptible(&devdata->session_sem)) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本一区二区三区在线观看| www.久久久久久久久| 国产精品一级在线| 成人免费视频caoporn| 99久久er热在这里只有精品15| 日本电影亚洲天堂一区| 欧美群妇大交群的观看方式| 久久亚洲精品国产精品紫薇| 国产精品国产自产拍高清av| 亚洲国产视频直播| 激情欧美日韩一区二区| 99精品热视频| 69堂成人精品免费视频| 国产精品丝袜黑色高跟| 亚洲成人777| 国产白丝精品91爽爽久久| 欧美视频一区在线| 久久久www免费人成精品| 亚洲综合在线电影| 久久精品99久久久| 91亚洲大成网污www| 精品日产卡一卡二卡麻豆| 成人免费在线播放视频| 麻豆极品一区二区三区| av在线不卡电影| 日韩欧美成人一区二区| 国产精品国产馆在线真实露脸| 天天av天天翘天天综合网 | 制服丝袜亚洲色图| 国产欧美综合在线| 午夜日韩在线电影| 成人高清视频在线观看| 日韩欧美的一区二区| 国产成人综合网站| 欧美精品黑人性xxxx| 成人av电影免费观看| 日韩情涩欧美日韩视频| 亚洲免费高清视频在线| 国产一区激情在线| 日韩欧美一区二区在线视频| 亚洲精品国产精品乱码不99| 国产69精品久久久久777| 欧美一区二区三区不卡| 亚洲精品欧美激情| 成人午夜激情在线| 精品国产a毛片| 五月婷婷综合在线| 色婷婷狠狠综合| 国产精品久久久久婷婷二区次| 精品制服美女久久| 欧美视频在线一区| 中文久久乱码一区二区| 国产一区二区在线影院| 91精品国产综合久久久久久| 亚洲宅男天堂在线观看无病毒| 成人97人人超碰人人99| 久久久国产精品午夜一区ai换脸| 麻豆成人久久精品二区三区小说| 欧美日韩一二三| 日本怡春院一区二区| 欧美自拍偷拍一区| 懂色av一区二区三区免费看| 成人动漫中文字幕| 在线免费av一区| 综合色中文字幕| 成人av免费观看| 中文字幕高清一区| 成人中文字幕在线| 91豆麻精品91久久久久久| 九九视频精品免费| 欧美一区二区视频在线观看2022 | 在线看国产一区二区| 国产精品美女www爽爽爽| 国产精品一区二区久久精品爱涩| 日韩精品一区二区在线| 久久99热99| 亚洲精品在线免费观看视频| 久久69国产一区二区蜜臀| 精品精品国产高清a毛片牛牛 | 欧美精品一区二区久久婷婷| 久99久精品视频免费观看| 欧美国产亚洲另类动漫| 中文字幕 久热精品 视频在线| 婷婷六月综合亚洲| 欧美精品久久一区| 男女男精品视频| 日韩美女一区二区三区四区| 美女久久久精品| 亚洲精品一区在线观看| 国产精品一二三四五| 久久精品视频在线看| 国产老肥熟一区二区三区| 国产区在线观看成人精品| av一区二区三区四区| 欧美日韩性生活| 99re66热这里只有精品3直播| 日本伊人午夜精品| 亚洲色欲色欲www| 精品少妇一区二区三区视频免付费 | 激情综合色播激情啊| 亚洲成人中文在线| 国产精品区一区二区三区| 色悠久久久久综合欧美99| 老鸭窝一区二区久久精品| 国产精品资源在线看| 琪琪一区二区三区| 亚洲愉拍自拍另类高清精品| 国产午夜精品理论片a级大结局| 色就色 综合激情| 欧美伊人久久久久久久久影院| 91蜜桃传媒精品久久久一区二区| 精品一区免费av| 久久九九国产精品| 91极品美女在线| 色综合婷婷久久| 97久久超碰国产精品电影| 欧美日韩国产成人在线免费| 亚洲天堂中文字幕| 美脚の诱脚舐め脚责91| 亚洲男人电影天堂| 久久免费国产精品| 日本一区二区成人| 日韩女优毛片在线| 日韩一区二区三区视频在线观看| 亚洲午夜私人影院| 91精品国产入口在线| 国产精品一区一区三区| 一区二区高清免费观看影视大全| 日韩欧美黄色影院| 99久久精品情趣| 麻豆精品视频在线观看免费| 亚洲婷婷国产精品电影人久久| 日韩一区二区三区视频| av电影在线不卡| 老司机免费视频一区二区 | 另类小说色综合网站| 最好看的中文字幕久久| 欧美大片免费久久精品三p| 91片黄在线观看| 国产乱码精品一区二区三区忘忧草| 尤物视频一区二区| 精品久久久三级丝袜| 在线免费不卡电影| 国产99久久久久久免费看农村| 日本午夜精品视频在线观看| 亚洲柠檬福利资源导航| 日本一区二区三区国色天香 | 日本午夜精品视频在线观看| 欧美一区欧美二区| 成人一级片在线观看| 麻豆成人综合网| 首页综合国产亚洲丝袜| 最新高清无码专区| 天天做天天摸天天爽国产一区| 国产精品视频你懂的| 欧美一区二区在线观看| aaa欧美日韩| 国产自产视频一区二区三区| 亚洲一区二区四区蜜桃| 精品国产电影一区二区| 色综合久久六月婷婷中文字幕| 久久精品国产澳门| 亚洲综合一二区| 国产亚洲短视频| 在线成人免费视频| 欧美三级欧美一级| av色综合久久天堂av综合| 国内精品伊人久久久久av影院| 亚洲国产日日夜夜| 亚洲免费在线观看视频| 精品少妇一区二区三区免费观看 | 欧美高清视频www夜色资源网| 成人短视频下载| 精品亚洲成a人| 免费xxxx性欧美18vr| 亚洲成av人片一区二区梦乃| 亚洲黄色小说网站| 亚洲女与黑人做爰| 亚洲欧洲日韩女同| 国产色产综合色产在线视频| 这里只有精品电影| 69堂精品视频| 欧美网站大全在线观看| 91丨porny丨中文| 色婷婷综合久久久久中文一区二区| 国产福利精品导航| 国产在线视视频有精品| 亚洲a一区二区| 日韩国产在线观看| 午夜久久久久久| 午夜视频一区二区| 久久精品国产在热久久| 麻豆精品蜜桃视频网站| 美女网站在线免费欧美精品| 看国产成人h片视频| 麻豆成人av在线| 国内精品国产成人国产三级粉色| 美女一区二区三区在线观看| 国产精品自拍网站| 激情综合色播激情啊|