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

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

?? fc.c

?? Linux內核源代碼 為壓縮文件 是<<Linux內核>>一書中的源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* fc.c: Generic Fibre Channel and FC4 SCSI driver. * * Copyright (C) 1997,1998,1999 Jakub Jelinek (jj@ultra.linux.cz) * Copyright (C) 1997,1998 Jirka Hanika (geo@ff.cuni.cz) * * There are two kinds of Fibre Channel adapters used in Linux. Either * the adapter is "smart" and does all FC bookkeeping by itself and * just presents a standard SCSI interface to the operating system * (that's e.g. the case with Qlogic FC cards), or leaves most of the FC * bookkeeping to the OS (e.g. soc, socal). Drivers for the former adapters * will look like normal SCSI drivers (with the exception of max_id will be * usually 127), the latter on the other side allows SCSI, IP over FC and other * protocols. This driver tree is for the latter adapters. * * This file should support both Point-to-Point and Arbitrated Loop topologies. * * Sources: *	Fibre Channel Physical & Signaling Interface (FC-PH), dpANS, 1994 *	dpANS Fibre Channel Protocol for SCSI (X3.269-199X), Rev. 012, 1995 *	Fibre Channel Arbitrated Loop (FC-AL), Rev. 4.5, 1995 *	Fibre Channel Private Loop SCSI Direct Attach (FC-PLDA), Rev. 2.1, 1997 */#include <linux/module.h>#include <linux/kernel.h>#include <linux/sched.h>#include <linux/types.h>#include <linux/fcntl.h>#include <linux/interrupt.h>#include <linux/ptrace.h>#include <linux/ioport.h>#include <linux/in.h>#include <linux/malloc.h>#include <linux/string.h>#include <linux/init.h>#include <linux/blk.h>#include <asm/pgtable.h>#include <asm/irq.h>#include <asm/semaphore.h>#include "fcp_impl.h"#include "../scsi/hosts.h"/* #define FCDEBUG */#define fc_printk printk ("%s: ", fc->name); printk #ifdef FCDEBUG#define FCD(x)  fc_printk x;#define FCND(x)	printk ("FC: "); printk x;#else#define FCD(x)#define FCND(x)#endif#ifdef __sparc__#define dma_alloc_consistent(d,s,p) sbus_alloc_consistent(d,s,p)#define dma_free_consistent(d,s,v,h) sbus_free_consistent(d,s,v,h)#define dma_map_single(d,v,s,dir) sbus_map_single(d,v,s,dir)#define dma_unmap_single(d,h,s,dir) sbus_unmap_single(d,h,s,dir)#define dma_map_sg(d,s,n,dir) sbus_map_sg(d,s,n,dir)#define dma_unmap_sg(d,s,n,dir) sbus_unmap_sg(d,s,n,dir)#define scsi_to_fc_dma_dir(dir)	scsi_to_sbus_dma_dir(dir)#define FC_DMA_BIDIRECTIONAL	SBUS_DMA_BIDIRECTIONAL#else#define dma_alloc_consistent(d,s,p) pci_alloc_consistent(d,s,p)#define dma_free_consistent(d,s,v,h) pci_free_consistent(d,s,v,h)#define dma_map_single(d,v,s,dir) pci_map_single(d,v,s,dir)#define dma_unmap_single(d,h,s,dir) pci_unmap_single(d,h,s,dir)#define dma_map_sg(d,s,n,dir) pci_map_sg(d,s,n,dir)#define dma_unmap_sg(d,s,n,dir) pci_unmap_sg(d,s,n,dir)#define scsi_to_fc_dma_dir(dir)	scsi_to_pci_dma_dir(dir)#define FC_DMA_BIDIRECTIONAL	PCI_DMA_BIDIRECTIONAL#endif							       #define FCP_CMND(SCpnt) ((fcp_cmnd *)&(SCpnt->SCp))#define FC_SCMND(SCpnt) ((fc_channel *)(SCpnt->host->hostdata[0]))#define SC_FCMND(fcmnd) ((Scsi_Cmnd *)((long)fcmnd - (long)&(((Scsi_Cmnd *)0)->SCp)))static int fcp_scsi_queue_it(fc_channel *, Scsi_Cmnd *, fcp_cmnd *, int);void fcp_queue_empty(fc_channel *);static void fcp_scsi_insert_queue (fc_channel *fc, fcp_cmnd *fcmd){	if (!fc->scsi_que) {		fc->scsi_que = fcmd;		fcmd->next = fcmd;		fcmd->prev = fcmd;	} else {		fc->scsi_que->prev->next = fcmd;		fcmd->prev = fc->scsi_que->prev;		fc->scsi_que->prev = fcmd;		fcmd->next = fc->scsi_que;	}}static void fcp_scsi_remove_queue (fc_channel *fc, fcp_cmnd *fcmd){	if (fcmd == fcmd->next) {		fc->scsi_que = NULL;		return;	}	if (fcmd == fc->scsi_que)		fc->scsi_que = fcmd->next;	fcmd->prev->next = fcmd->next;	fcmd->next->prev = fcmd->prev;}fc_channel *fc_channels = NULL;#define LSMAGIC	620829043typedef struct {	/* Must be first */	struct semaphore sem;	int magic;	int count;	logi *logi;	fcp_cmnd *fcmds;	atomic_t todo;	struct timer_list timer;	unsigned char grace[0];} ls;#define LSOMAGIC 654907799typedef struct {	/* Must be first */	struct semaphore sem;	int magic;	int count;	fcp_cmnd *fcmds;	atomic_t todo;	struct timer_list timer;} lso;#define LSEMAGIC 84482456typedef struct {	/* Must be first */	struct semaphore sem;	int magic;	int status;	struct timer_list timer;} lse;static void fcp_login_timeout(unsigned long data){	ls *l = (ls *)data;	FCND(("Login timeout\n"))	up(&l->sem);}static void fcp_login_done(fc_channel *fc, int i, int status){	fcp_cmnd *fcmd;	logi *plogi;	fc_hdr *fch;	ls *l = (ls *)fc->ls;		FCD(("Login done %d %d\n", i, status))	if (i < l->count) {		if (fc->state == FC_STATE_FPORT_OK) {			FCD(("Additional FPORT_OK received with status %d\n", status))			return;		}		switch (status) {		case FC_STATUS_OK: /* Oh, we found a fabric */		case FC_STATUS_P_RJT: /* Oh, we haven't found any */			fc->state = FC_STATE_FPORT_OK;			fcmd = l->fcmds + i;			plogi = l->logi + 3 * i;			dma_unmap_single (fc->dev, fcmd->cmd, 3 * sizeof(logi),					  FC_DMA_BIDIRECTIONAL);			plogi->code = LS_PLOGI;			memcpy (&plogi->nport_wwn, &fc->wwn_nport, sizeof(fc_wwn));			memcpy (&plogi->node_wwn, &fc->wwn_node, sizeof(fc_wwn));			memcpy (&plogi->common, fc->common_svc, sizeof(common_svc_parm));			memcpy (&plogi->class1, fc->class_svcs, 3*sizeof(svc_parm));			fch = &fcmd->fch;			fcmd->token += l->count;			FILL_FCHDR_RCTL_DID(fch, R_CTL_ELS_REQ, fc->did);			FILL_FCHDR_SID(fch, fc->sid);#ifdef FCDEBUG			{				int i;				unsigned *x = (unsigned *)plogi;				printk ("logi: ");				for (i = 0; i < 21; i++)					printk ("%08x ", x[i]);				printk ("\n");			}#endif						fcmd->cmd = dma_map_single (fc->dev, plogi, 3 * sizeof(logi),						    FC_DMA_BIDIRECTIONAL);			fcmd->rsp = fcmd->cmd + 2 * sizeof(logi);			if (fc->hw_enque (fc, fcmd))				printk ("FC: Cannot enque PLOGI packet on %s\n", fc->name);			break;		case FC_STATUS_ERR_OFFLINE:			fc->state = FC_STATE_MAYBEOFFLINE;			FCD (("FC is offline %d\n", l->grace[i]))			break;		default:			printk ("FLOGI failed for %s with status %d\n", fc->name, status);			/* Do some sort of error recovery here */			break;		}	} else {		i -= l->count;		if (fc->state != FC_STATE_FPORT_OK) {			FCD(("Unexpected N-PORT rsp received"))			return;		}		switch (status) {		case FC_STATUS_OK:			plogi = l->logi + 3 * i;			dma_unmap_single (fc->dev, l->fcmds[i].cmd, 3 * sizeof(logi),					  FC_DMA_BIDIRECTIONAL);			if (!fc->wwn_dest.lo && !fc->wwn_dest.hi) {				memcpy (&fc->wwn_dest, &plogi[1].node_wwn, sizeof(fc_wwn)); 				FCD(("Dest WWN %08x%08x\n", *(u32 *)&fc->wwn_dest, fc->wwn_dest.lo))			} else if (fc->wwn_dest.lo != plogi[1].node_wwn.lo ||				   fc->wwn_dest.hi != plogi[1].node_wwn.hi) {				printk ("%s: mismatch in wwns. Got %08x%08x, expected %08x%08x\n",					fc->name,					*(u32 *)&plogi[1].node_wwn, plogi[1].node_wwn.lo,					*(u32 *)&fc->wwn_dest, fc->wwn_dest.lo);			}			fc->state = FC_STATE_ONLINE;			printk ("%s: ONLINE\n", fc->name);			if (atomic_dec_and_test (&l->todo))				up(&l->sem);			break;		case FC_STATUS_ERR_OFFLINE:			fc->state = FC_STATE_OFFLINE;			dma_unmap_single (fc->dev, l->fcmds[i].cmd, 3 * sizeof(logi),					  FC_DMA_BIDIRECTIONAL);			printk ("%s: FC is offline\n", fc->name);			if (atomic_dec_and_test (&l->todo))				up(&l->sem);			break;		default:			printk ("PLOGI failed for %s with status %d\n", fc->name, status);			/* Do some sort of error recovery here */			break;		}	}}static void fcp_report_map_done(fc_channel *fc, int i, int status){	fcp_cmnd *fcmd;	fc_hdr *fch;	unsigned char j;	ls *l = (ls *)fc->ls;	fc_al_posmap *p;		FCD(("Report map done %d %d\n", i, status))	switch (status) {	case FC_STATUS_OK: /* Ok, let's have a fun on a loop */		dma_unmap_single (fc->dev, l->fcmds[i].cmd, 3 * sizeof(logi),				  FC_DMA_BIDIRECTIONAL);		p = (fc_al_posmap *)(l->logi + 3 * i);#ifdef FCDEBUG		{		u32 *u = (u32 *)p;		FCD(("%08x\n", u[0]))		u ++;		FCD(("%08x.%08x.%08x.%08x.%08x.%08x.%08x.%08x\n", u[0],u[1],u[2],u[3],u[4],u[5],u[6],u[7]))		}#endif				if ((p->magic & 0xffff0000) != FC_AL_LILP || !p->len) {			printk ("FC: Bad magic from REPORT_AL_MAP on %s - %08x\n", fc->name, p->magic);			fc->state = FC_STATE_OFFLINE;		} else {			fc->posmap = (fcp_posmap *)kmalloc(sizeof(fcp_posmap)+p->len, GFP_KERNEL);			if (!fc->posmap) {				printk("FC: Not enough memory, offlining channel\n");				fc->state = FC_STATE_OFFLINE;			} else {				int k;				memset(fc->posmap, 0, sizeof(fcp_posmap)+p->len);				/* FIXME: This is where SOCAL transfers our AL-PA.				   Keep it here till we found out what other cards do... */				fc->sid = (p->magic & 0xff);				for (i = 0; i < p->len; i++)					if (p->alpa[i] == fc->sid)						break;				k = p->len;				if (i == p->len)					i = 0;				else {					p->len--;					i++;				}				fc->posmap->len = p->len;				for (j = 0; j < p->len; j++) {					if (i == k) i = 0;					fc->posmap->list[j] = p->alpa[i++];				}				fc->state = FC_STATE_ONLINE;			}		}		printk ("%s: ONLINE\n", fc->name);		if (atomic_dec_and_test (&l->todo))			up(&l->sem);		break;	case FC_STATUS_POINTTOPOINT: /* We're Point-to-Point, no AL... */		FCD(("SID %d DID %d\n", fc->sid, fc->did))		fcmd = l->fcmds + i;		dma_unmap_single(fc->dev, fcmd->cmd, 3 * sizeof(logi),				 FC_DMA_BIDIRECTIONAL);		fch = &fcmd->fch;		memset(l->logi + 3 * i, 0, 3 * sizeof(logi));		FILL_FCHDR_RCTL_DID(fch, R_CTL_ELS_REQ, FS_FABRIC_F_PORT);		FILL_FCHDR_SID(fch, 0);		FILL_FCHDR_TYPE_FCTL(fch, TYPE_EXTENDED_LS, F_CTL_FIRST_SEQ | F_CTL_SEQ_INITIATIVE);		FILL_FCHDR_SEQ_DF_SEQ(fch, 0, 0, 0);		FILL_FCHDR_OXRX(fch, 0xffff, 0xffff);		fch->param = 0;		l->logi [3 * i].code = LS_FLOGI;		fcmd->cmd = dma_map_single (fc->dev, l->logi + 3 * i, 3 * sizeof(logi),					    FC_DMA_BIDIRECTIONAL);		fcmd->rsp = fcmd->cmd + sizeof(logi);		fcmd->cmdlen = sizeof(logi);		fcmd->rsplen = sizeof(logi);		fcmd->data = (dma_addr_t)NULL;		fcmd->class = FC_CLASS_SIMPLE;		fcmd->proto = TYPE_EXTENDED_LS;		if (fc->hw_enque (fc, fcmd))			printk ("FC: Cannot enque FLOGI packet on %s\n", fc->name);		break;	case FC_STATUS_ERR_OFFLINE:		fc->state = FC_STATE_MAYBEOFFLINE;		FCD (("FC is offline %d\n", l->grace[i]))		break;	default:		printk ("FLOGI failed for %s with status %d\n", fc->name, status);		/* Do some sort of error recovery here */		break;	}}void fcp_register(fc_channel *fc, u8 type, int unregister){	int size, i;	int slots = (fc->can_queue * 3) >> 1;	FCND(("Going to %sregister\n", unregister ? "un" : ""))	if (type == TYPE_SCSI_FCP) {		if (!unregister) {			fc->scsi_cmd_pool = (fcp_cmd *)				dma_alloc_consistent (fc->dev,						      slots * (sizeof (fcp_cmd) + fc->rsp_size),						      &fc->dma_scsi_cmd);			fc->scsi_rsp_pool = (char *)(fc->scsi_cmd_pool + slots);			fc->dma_scsi_rsp = fc->dma_scsi_cmd + slots * sizeof (fcp_cmd);			fc->scsi_bitmap_end = (slots + 63) & ~63;			size = fc->scsi_bitmap_end / 8;			fc->scsi_bitmap = kmalloc (size, GFP_KERNEL);			memset (fc->scsi_bitmap, 0, size);			set_bit (0, fc->scsi_bitmap);			for (i = fc->can_queue; i < fc->scsi_bitmap_end; i++)				set_bit (i, fc->scsi_bitmap);			fc->scsi_free = fc->can_queue;			fc->cmd_slots = (fcp_cmnd **)kmalloc(slots * sizeof(fcp_cmnd*), GFP_KERNEL);			memset(fc->cmd_slots, 0, slots * sizeof(fcp_cmnd*));			fc->abort_count = 0;		} else {			fc->scsi_name[0] = 0;			kfree (fc->scsi_bitmap);			kfree (fc->cmd_slots);			FCND(("Unregistering\n"));			if (fc->rst_pkt) {				if (fc->rst_pkt->eh_state == SCSI_STATE_UNUSED)					kfree(fc->rst_pkt);				else {					/* Can't happen. Some memory would be lost. */					printk("FC: Reset in progress. Now?!");				}			}			FCND(("Unregistered\n"));		}	} else		printk ("FC: %segistering unknown type %02x\n", unregister ? "Unr" : "R", type);}static void fcp_scsi_done(Scsi_Cmnd *SCpnt);static inline void fcp_scsi_receive(fc_channel *fc, int token, int status, fc_hdr *fch){

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久影院| 亚洲人精品午夜| 一区二区三区四区在线播放| 青青草一区二区三区| www.一区二区| 精品成a人在线观看| 一区二区三区**美女毛片| 国产成人在线免费观看| 欧美一级在线观看| 亚洲午夜一区二区三区| a级高清视频欧美日韩| 久久综合色婷婷| 日日摸夜夜添夜夜添国产精品| 波多野结衣中文字幕一区| 精品国产乱码久久久久久浪潮| 天天综合色天天| 欧美日韩国产首页在线观看| 国产精品久久久久久户外露出| 男人的天堂久久精品| 欧美色精品在线视频| 亚洲男人的天堂网| av激情综合网| 国产清纯白嫩初高生在线观看91 | 亚洲国产经典视频| 久久99精品久久久久久国产越南 | 欧美美女直播网站| 夜夜嗨av一区二区三区网页| 99久精品国产| 亚洲欧美一区二区三区国产精品| 国产成人自拍网| 国产精品久久久久影院老司| 国产成人午夜99999| 精品国产三级a在线观看| 日本不卡在线视频| 日韩写真欧美这视频| 免费三级欧美电影| 精品国产1区2区3区| 91久久国产最好的精华液| 亚洲国产精品激情在线观看| 成人av资源网站| 亚洲老司机在线| 欧美老肥妇做.爰bbww| 日韩高清不卡一区二区三区| 日韩精品一区二区三区四区| 韩日av一区二区| 欧美高清在线一区二区| av在线不卡网| 亚洲一区二区在线免费看| 7777女厕盗摄久久久| 麻豆一区二区三| 亚洲国产成人在线| 91福利小视频| 免费看日韩a级影片| 久久麻豆一区二区| 97国产一区二区| 午夜久久久影院| 国产无人区一区二区三区| 99国产精品国产精品久久| 午夜精品久久久久久不卡8050| 日韩三级高清在线| av在线不卡观看免费观看| 日韩中文字幕亚洲一区二区va在线 | 天天做天天摸天天爽国产一区| 欧美成人乱码一区二区三区| 国产v日产∨综合v精品视频| 一区二区三区av电影| 久久免费午夜影院| 91国模大尺度私拍在线视频| 麻豆国产欧美日韩综合精品二区| 国产精品视频免费| 在线综合+亚洲+欧美中文字幕| 国产成人精品www牛牛影视| 一区二区三区精品在线| 精品久久久久久综合日本欧美| 92国产精品观看| 国内成+人亚洲+欧美+综合在线 | 欧美色精品天天在线观看视频| 狠狠色丁香九九婷婷综合五月| 一区二区三区不卡在线观看| 亚洲精品一区二区三区精华液 | 91在线精品一区二区| 麻豆国产91在线播放| 亚洲欧美一区二区三区极速播放| 久久一夜天堂av一区二区三区| 欧美性视频一区二区三区| 国产91精品一区二区麻豆网站| 男男视频亚洲欧美| 亚洲欧美成人一区二区三区| 欧美精品一区二区久久久| 欧美日韩免费不卡视频一区二区三区| 国产成人8x视频一区二区| 美女诱惑一区二区| 午夜av一区二区三区| 亚洲人成网站精品片在线观看| 国产日韩欧美精品综合| 日韩欧美激情在线| 欧美区在线观看| 欧美日韩免费高清一区色橹橹 | 91在线视频网址| 成人成人成人在线视频| 国产成人综合精品三级| 国内精品伊人久久久久av影院 | 色婷婷av一区二区三区大白胸| 成人av在线影院| 成人午夜私人影院| 国产一区在线视频| 另类调教123区| 久久国产精品99久久人人澡| 日韩专区欧美专区| 日韩电影在线观看电影| 日本亚洲电影天堂| 蜜臀精品一区二区三区在线观看 | av高清久久久| 欧美一区二区三区白人| 欧美一区二区三级| 精品卡一卡二卡三卡四在线| 欧美大片一区二区三区| 精品久久久久久久久久久久久久久久久| 欧美日韩精品福利| 欧美精品丝袜久久久中文字幕| 欧美军同video69gay| 日韩三级电影网址| 久久综合九色综合97婷婷| 久久久不卡影院| 国产精品人妖ts系列视频| 亚洲三级在线看| 亚洲国产你懂的| 日韩va亚洲va欧美va久久| 美国十次综合导航| 国产精品性做久久久久久| av在线播放不卡| 欧亚洲嫩模精品一区三区| 欧美日韩成人综合在线一区二区| 欧美一级午夜免费电影| 国产视频一区不卡| 亚洲女子a中天字幕| 日韩成人免费看| 国产精品亚洲第一| 91国偷自产一区二区三区观看 | 久久99精品国产.久久久久| 国产精品自在欧美一区| 91丨porny丨国产| 欧美一区二区三区四区久久| 精品国产乱码久久久久久蜜臀| 中文字幕一区二区三| 婷婷国产在线综合| 狠狠色2019综合网| 色8久久人人97超碰香蕉987| 日韩欧美在线不卡| 亚洲欧洲在线观看av| 麻豆久久一区二区| 99视频在线精品| 日韩精品一区二区三区视频播放| 国产精品久久久久久妇女6080| 天天做天天摸天天爽国产一区| 国产a精品视频| 91精品在线观看入口| 国产精品国产三级国产aⅴ原创| 亚洲成人精品在线观看| 国产精品一品视频| 欧美人妖巨大在线| 国产精品久久久久久久久动漫 | 福利一区二区在线观看| 欧美视频在线观看一区二区| 国产女人aaa级久久久级| 五月婷婷激情综合网| 97国产一区二区| 国产三级三级三级精品8ⅰ区| 亚洲高清免费在线| av午夜一区麻豆| 久久伊人蜜桃av一区二区| 天天色图综合网| 一本久久a久久精品亚洲| 久久亚区不卡日本| 午夜欧美大尺度福利影院在线看| 波多野结衣亚洲| 久久久www成人免费毛片麻豆| 日韩电影在线一区二区三区| 一本大道久久a久久综合| 中文字幕成人av| 国产成人av影院| 欧美精品一区二区久久久 | 亚洲福利视频一区二区| 成人av在线看| 国产偷国产偷亚洲高清人白洁| 蜜臀a∨国产成人精品| 这里只有精品视频在线观看| 亚洲国产婷婷综合在线精品| 欧美性生活影院| 亚洲成年人网站在线观看| 色爱区综合激月婷婷| 亚洲免费av观看| 91九色最新地址| 亚洲福利视频一区二区| 欧美在线免费播放| 亚洲永久精品国产| 欧美日韩亚洲另类| 日本中文在线一区| 制服丝袜日韩国产| 精品一区二区三区的国产在线播放|