亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
麻豆精品国产传媒mv男同| 国产午夜亚洲精品理论片色戒 | 久久影视一区二区| 日韩一区精品字幕| 91精品国产高清一区二区三区蜜臀| 亚洲欧洲美洲综合色网| 一本久久a久久精品亚洲| 一区二区三区日韩在线观看| 欧美日韩另类一区| 日本网站在线观看一区二区三区 | 美女www一区二区| www国产精品av| 国产一区二区三区黄视频 | 精品美女被调教视频大全网站| 国模一区二区三区白浆| 国产精品国产自产拍高清av| 一本色道a无线码一区v| 亚洲h精品动漫在线观看| 日韩精品一区二区在线观看| 国产999精品久久| 一区二区三区四区激情| 日韩一区二区免费在线观看| 国产精品原创巨作av| 亚洲你懂的在线视频| 欧美精品三级在线观看| 国产麻豆视频一区二区| 亚洲欧美日韩中文字幕一区二区三区 | 亚洲网友自拍偷拍| 欧美电影免费观看完整版| 粉嫩欧美一区二区三区高清影视| 一区二区三区四区av| 久久这里只有精品6| 在线观看免费一区| 国产一区二区三区蝌蚪| 一区二区三区精品在线| 精品国产免费久久| 99热这里都是精品| 麻豆成人免费电影| 一区二区三区视频在线观看| 久久午夜色播影院免费高清| 欧美色涩在线第一页| 国产一区二区三区免费播放| 亚洲一区在线视频| 国产精品国产三级国产普通话蜜臀| 91精品国产综合久久小美女| 成人动漫在线一区| 美女被吸乳得到大胸91| 一区二区三区在线观看动漫| 国产欧美一区二区精品性色超碰 | 成人精品免费看| 奇米四色…亚洲| 亚洲已满18点击进入久久| 国产亚洲欧美一级| 日韩欧美中文一区二区| 欧美性视频一区二区三区| 成+人+亚洲+综合天堂| 国产乱子伦视频一区二区三区 | 色播五月激情综合网| 国产成人啪午夜精品网站男同| 视频一区视频二区在线观看| 夜夜夜精品看看| 亚洲伦在线观看| 成人免费一区二区三区在线观看| 国产婷婷精品av在线| 亚洲精品一区二区三区福利| 日韩欧美国产一区二区三区 | 极品少妇xxxx精品少妇| 成人av在线网站| 国产一区日韩二区欧美三区| 久久成人久久鬼色| 蜜臀av性久久久久蜜臀aⅴ四虎 | 欧美日本一区二区三区| 91精彩视频在线| 色噜噜狠狠成人中文综合| 成人动漫一区二区三区| 成人小视频免费观看| 国产九色sp调教91| 国产乱子伦视频一区二区三区 | 99久久99久久精品免费观看| 99re在线视频这里只有精品| 亚洲欧美一区二区三区孕妇| 51久久夜色精品国产麻豆| 欧美午夜免费电影| 欧美裸体一区二区三区| 制服丝袜激情欧洲亚洲| 7777精品伊人久久久大香线蕉| 欧美色图12p| 91麻豆精品国产91久久久久久 | 国产精品影视天天线| 国产91在线|亚洲| www.在线欧美| 色吊一区二区三区| 欧美日韩高清影院| 欧美变态tickling挠脚心| 久久亚洲一区二区三区明星换脸| 久久久久久久网| 中文字幕的久久| 亚洲卡通动漫在线| 日韩av中文在线观看| 狠狠色丁香九九婷婷综合五月| 国产一区二区在线影院| 成人白浆超碰人人人人| 91福利国产精品| 日韩美女在线视频| 国产精品久久久久影院亚瑟| 亚洲码国产岛国毛片在线| 日韩中文字幕不卡| 久久99热狠狠色一区二区| 国产91综合一区在线观看| 欧美在线影院一区二区| 欧美成人精品1314www| 中文字幕不卡在线观看| 五月婷婷综合在线| 国产一区二区三区四区五区入口| 成人动漫av在线| 欧美一区二区三区在线| 中文字幕一区二区视频| 天天做天天摸天天爽国产一区| 国产综合成人久久大片91| 一本到高清视频免费精品| 精品999久久久| 亚洲一级二级三级| 国产91精品露脸国语对白| 欧美视频一区二区三区| 国产午夜亚洲精品不卡| 日日夜夜一区二区| 日韩一区二区三区观看| 欧美激情一区二区三区蜜桃视频 | 日本成人超碰在线观看| www.av精品| 久久综合狠狠综合久久综合88| 一区二区三区色| 成人免费电影视频| 欧美一区二区不卡视频| 亚洲欧美激情在线| 国产真实乱子伦精品视频| 欧美群妇大交群中文字幕| 中文字幕一区二| 国产成人一区二区精品非洲| 91精品国产综合久久福利| 亚洲日本在线视频观看| 国产福利一区二区三区视频在线 | 99久久99精品久久久久久| 久久伊人蜜桃av一区二区| 日韩av一区二| 欧美影片第一页| 亚洲欧美在线另类| 成人性生交大片免费看中文网站| 日韩三级在线观看| 五月婷婷久久丁香| 91福利视频网站| 亚洲免费在线视频一区 二区| 丰满少妇久久久久久久| 久久女同性恋中文字幕| 热久久久久久久| 欧美日韩你懂得| 亚洲午夜久久久久中文字幕久| 91蜜桃视频在线| |精品福利一区二区三区| 国产凹凸在线观看一区二区| 国产日韩av一区| 国产中文字幕一区| 国产午夜精品一区二区三区视频 | 天天爽夜夜爽夜夜爽精品视频| 91麻豆国产福利精品| 中文字幕亚洲精品在线观看 | 国内精品久久久久影院薰衣草 | 亚洲国产成人一区二区三区| 国产精品2024| 国产欧美日韩另类视频免费观看 | 精品一区二区三区影院在线午夜| 欧美丰满美乳xxx高潮www| 亚洲成av人**亚洲成av**| 欧美日韩一区二区在线观看视频 | 久久成人久久爱| 久久综合网色—综合色88| 国产美女精品在线| 中文字幕成人在线观看| 99re亚洲国产精品| 一区二区三区四区不卡视频| 欧美日韩你懂的| 蜜桃91丨九色丨蝌蚪91桃色| 久久久久久久网| 99久久亚洲一区二区三区青草| 亚洲综合免费观看高清完整版在线 | 国产在线精品免费av| 久久综合久久综合九色| 大尺度一区二区| 亚洲综合视频网| 日韩欧美成人激情| 国产成人午夜99999| 亚洲欧美一区二区不卡| 欧美日韩国产精品自在自线| 免费观看30秒视频久久| 中日韩av电影| 欧美日韩一本到| 国内偷窥港台综合视频在线播放| 中文字幕一区免费在线观看| 欧美日韩免费观看一区三区| 激情av综合网|