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

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

?? rhel3_diskdump.patch

?? 最新的Megaraid SAS卡驅動源代碼
?? PATCH
字號:
diff -uprN rhel3/megaraid_sas.c rhel3_dump/megaraid_sas.c--- rhel3/megaraid_sas.c	2007-10-15 00:36:01.000000000 -0700+++ rhel3_dump/megaraid_sas.c	2007-10-15 00:44:09.000000000 -0700@@ -43,6 +43,7 @@ #include <linux/proc_fs.h> #include <linux/blk.h> #include <linux/notifier.h>+#include <linux/diskdump.h>  #if defined (__x86_64__) #include <asm/ioctl32.h>@@ -51,6 +52,7 @@ #include "scsi.h" #include "hosts.h" #include "sd.h"+#include "scsi_dump.h"  #include "megaraid_sas.h" @@ -66,7 +68,8 @@ static unsigned int fast_load = 0; module_param(fast_load, int, 0); MODULE_PARM_DESC(fast_load,-	"megasas: Faster loading of the driver, skips physical devices!  (default=0)");+	"megasas: Faster loading of the driver, skips physical devices! \+	 (default=0)");  /*  * Number of sectors per IO command@@ -85,6 +88,7 @@ module_param(cmd_per_lun, int, 0); MODULE_PARM_DESC(cmd_per_lun, 	"Maximum number of commands per logical unit (default=128)"); + MODULE_LICENSE("GPL"); #ifdef MODULE_VERSION MODULE_VERSION(MEGASAS_VERSION);@@ -99,6 +103,12 @@ static void megasas_complete_cmd(struct megasas_instance *instance, struct megasas_cmd *cmd, 		     u8 alt_status); +static void+megasas_deplete_reply_queue(struct megasas_instance *instance, u8 alt_status);+static irqreturn_t megasas_isr(int irq, void *devp, struct pt_regs *regs);+static void megasas_flush_cache(struct megasas_instance *instance);+static int megasas_issue_polled(struct megasas_instance *instance, struct megasas_cmd *cmd);+ /*  * PCI ID table for all supported controllers  */@@ -167,6 +177,14 @@ static inline unsigned long msecs_to_jif  static void msleep(unsigned long msecs) {+#if defined(CONFIG_DISKDUMP) || defined(CONFIG_DISKDUMP_MODULE)+	if (unlikely(crashdump_mode())) {+		for (; msecs > 1000; msecs -= 1000)+			udelay(1000);+		udelay(msecs);+		return;+	}+#endif 	set_current_state(TASK_UNINTERRUPTIBLE); 	schedule_timeout(msecs_to_jiffies(msecs) + 1); }@@ -259,8 +277,9 @@ static void megasas_create_proc_entry(st 			       megasas_proc_show_bus_devfn, instance);  	create_proc_read_entry("max_sector", S_IRUSR | S_IFREG,-			       instance->hba_proc_dir,-			       megasas_proc_show_max_sectors, NULL);+			   instance->hba_proc_dir,+			   megasas_proc_show_max_sectors, NULL);+  } @@ -748,7 +767,7 @@ u32 megasas_get_frame_count(u8 sge_count 		frame_count = 8; 	return frame_count; }-+		 /**  * megasas_build_dcdb -	Prepares a direct cdb (DCDB) command  * @instance:		Adapter soft state@@ -1064,14 +1083,13 @@ megasas_queue_command(struct scsi_cmnd * 	switch (scmd->cmnd[0]) { 		case SYNCHRONIZE_CACHE: #if defined(CONFIG_DISKDUMP) || defined(CONFIG_DISKDUMP_MODULE)-			if (crashdump_mode())+			if (!crashdump_mode()) #endif 			{ 				scmd->result = DID_OK << 16; 				goto out_done; 			} 	}- 	/* If FW is busy donot accept any more cmds */ 	if(instance->is_busy){ 		sec = (jiffies - instance->last_time) / HZ;@@ -1091,13 +1109,29 @@ megasas_queue_command(struct scsi_cmnd * 	cmd = megasas_get_cmd(instance); 	if (!cmd) 		return SCSI_MLQUEUE_HOST_BUSY;+#if defined(CONFIG_DISKDUMP) || defined(CONFIG_DISKDUMP_MODULE)+	if (MEGASAS_IS_LOGICAL(scmd)){+		switch (scmd->cmnd[0]) {+			case SYNCHRONIZE_CACHE:+				if (crashdump_mode()) +					megasas_flush_cache(instance);+			case REQUEST_SENSE:+			case MODE_SELECT:+			case MODE_SENSE:+				if (crashdump_mode()) {+					scmd->result = (DID_OK << 16);+					goto out_done;+				}+		}+	}+#endif  	/* 	 * Logical drive command 	 */ 	if (megasas_is_ldio(scmd)) 		frame_count = megasas_build_ldio(instance, scmd, cmd);-	else +	else 		frame_count = megasas_build_dcdb(instance, scmd, cmd);  	if (!frame_count)@@ -1184,6 +1218,14 @@ static int megasas_wait_for_outstanding( 			 */ 			megasas_complete_cmd_q(instance, DID_OK); 		}+#if defined(CONFIG_DISKDUMP) || defined(CONFIG_DISKDUMP_MODULE)+		/*+		* In crash dump mode cannot complete cmds in interrupt context  +		* Complete cmds from here+		*/+		if(crashdump_mode())+			megasas_deplete_reply_queue(instance, DID_OK);+#endif  		msleep(1000); 	}@@ -1296,6 +1338,63 @@ megasas_service_aen(struct megasas_insta 	megasas_return_cmd(instance, cmd); } +#if defined(CONFIG_DISKDUMP) || defined(CONFIG_DISKDUMP_MODULE)+static int+megasas_diskdump_sanity_check(struct scsi_device *device)+{+        struct megasas_instance *instance;++	instance = (struct megasas_instance *)device->host->hostdata;++        if (!instance)+                return -ENXIO;++        if (spin_is_locked(&instance->cmd_pool_lock))+                return -EBUSY;+        return 0;+}++static void+megasas_diskdump_poll(struct scsi_device *device)+{+        struct megasas_instance *instance;++	instance = (struct megasas_instance *)device->host->hostdata;++        if (!instance)+                return ;++	megasas_isr(0,instance, NULL);+}+static struct scsi_dump_ops megasas_dump_ops = {+	.sanity_check	= megasas_diskdump_sanity_check,+	.poll		= megasas_diskdump_poll,+	.no_write_cache_enable = 1+};+/*+ * Scsi host template for megaraid_sas driver (diskdump)+ */+static Scsi_Host_Template_dump megasas_template_dump = {++	.hostt = {						+		.name = "MegaRAID SAS",+		.proc_name = "megaraid_sas",+		.info = megasas_info,+		.queuecommand = megasas_queue_command,+		.eh_device_reset_handler = megasas_reset_device,+		.eh_bus_reset_handler = megasas_reset_bus_host,+		.eh_host_reset_handler = megasas_reset_bus_host,+		.use_clustering = ENABLE_CLUSTERING,+		.use_new_eh_code = 1,+		.highmem_io = 1,+		.vary_io = 1,+		.disk_dump = 1,		+		},							+	.dump_ops = &megasas_dump_ops,+};+#define megasas_template		(megasas_template_dump.hostt)++#else /*  * Scsi host template for megaraid_sas driver  */@@ -1314,6 +1413,8 @@ static Scsi_Host_Template megasas_templa 	.vary_io = 1, }; +#endif+ /**  * megasas_complete_int_cmd -	Completes an internal command  * @instance:			Adapter soft state@@ -1554,12 +1655,12 @@ megasas_complete_cmd(struct megasas_inst  * 					SCSI mid-layer instead of the status  * 					returned by the FW  */-static inline void+static void megasas_deplete_reply_queue(struct megasas_instance *instance, u8 alt_status) { 	/* 	 * Check if it is our interrupt-	 * Clear the interrupt +	 * Clear the interrupt 	 */ 	if (instance->instancet->clear_intr(instance->reg_set)) 		return IRQ_NONE;@@ -2362,9 +2463,9 @@ static int megasas_init_mfi(struct megas 		tmp_sectors = (max_sectors_1 < max_sectors_2) 		    ? max_sectors_1 : max_sectors_2; 	}- + 	instance->max_sectors_per_req = instance->max_num_sge *-		    PAGE_SIZE / 512;+ 		    PAGE_SIZE / 512; 	if (tmp_sectors && (instance->max_sectors_per_req > tmp_sectors)) 		instance->max_sectors_per_req = tmp_sectors; @@ -2644,9 +2745,10 @@ static int megasas_io_attach(struct mega 		instance->max_sectors_per_req = max_sector; 	else { 		if (max_sector)-			printk(KERN_INFO "megasas: max_sectors should be > 0 and"+			printk(KERN_INFO "megasas: max_sector should be > 0 and" 			 	"<= %d\n",instance->max_sectors_per_req); 	}+ 	max_sector = instance->max_sectors_per_req; 	host->max_sectors = instance->max_sectors_per_req; @@ -2659,10 +2761,11 @@ static int megasas_io_attach(struct mega 	else 		printk(KERN_INFO "megasas: cmd_per_lun should be > 0 and" 			 	"<= %d\n",MEGASAS_DEFAULT_CMD_PER_LUN);-	cmd_per_lun = instance->cmd_per_lun;	+		+	cmd_per_lun = instance->cmd_per_lun; 	host->cmd_per_lun = instance->cmd_per_lun; -	printk(KERN_DEBUG "megasas: max_sectors : 0x%x, cmd_per_lun : 0x%x\n",+	printk(KERN_DEBUG "megasas: max_sector : 0x%x, cmd_per_lun : 0x%x\n", 			instance->max_sectors_per_req, instance->cmd_per_lun); 	 	host->max_channel = MEGASAS_MAX_CHANNELS - 1;@@ -2683,6 +2786,7 @@ static int megasas_io_attach(struct mega 	 */ 	scsi_scan_host(host); 	return 0;+ }  /**@@ -2876,7 +2980,7 @@ megasas_probe_one(struct pci_dev *pdev,        fail_init_mfi:       fail_alloc_dma_buf: 	/* Free the ioctl mem pool */-	megasas_free_ioctl_mem_pools(instance); +	megasas_free_ioctl_mem_pools(instance); /* for-ioctl: free the mem pool */ 	if (instance->evt_detail) 		pci_free_consistent(pdev, sizeof(struct megasas_evt_detail), 				    instance->evt_detail,@@ -2924,7 +3028,14 @@ static void megasas_flush_cache(struct m 	dcmd->opcode = MR_DCMD_CTRL_CACHE_FLUSH; 	dcmd->mbox.b[0] = MR_FLUSH_CTRL_CACHE | MR_FLUSH_DISK_CACHE; -	megasas_issue_blocked_cmd(instance, cmd);+#if defined(CONFIG_DISKDUMP) || defined(CONFIG_DISKDUMP_MODULE)+	if (crashdump_mode())+		megasas_issue_polled(instance, cmd);+	else+		megasas_issue_blocked_cmd(instance, cmd);+#else+ 	megasas_issue_blocked_cmd(instance, cmd);+#endif  	megasas_return_cmd(instance, cmd); @@ -3038,9 +3149,9 @@ static void megasas_detach_one(struct pc 	free_irq(instance->pdev->irq, instance);  	megasas_release_mfi(instance);-+	 	/* Free IOCTL mem pool */-	megasas_free_ioctl_mem_pools(instance); +	megasas_free_ioctl_mem_pools(instance);  	pci_free_consistent(pdev, sizeof(struct megasas_evt_detail), 			    instance->evt_detail, instance->evt_detail_h);@@ -3178,6 +3289,7 @@ megasas_mgmt_fw_ioctl(struct megasas_ins 	 * For each user buffer, create a mirror buffer and copy in 	 */ 	for (i = 0; i < ioc->sge_count; i++) {+ 		if (from_pool) { 			kbuff_arr[i] = cmd->ioctl_mem[i]->vaddr; 			buf_handle = cmd->ioctl_mem[i]->buf_handle;@@ -3251,6 +3363,7 @@ megasas_mgmt_fw_ioctl(struct megasas_ins 		 * sense_buff points to the location that has the user 		 * sense buffer address 		 */+                 sense_buff = (unsigned long *) ((unsigned long)ioc->frame.raw + 					ioc->sense_off); 		sense_ptr = (u32 *) ((unsigned long)ioc->frame.raw +@@ -3281,7 +3394,6 @@ megasas_mgmt_fw_ioctl(struct megasas_ins 	} 	 	for (i = 0; i < ioc->sge_count && kbuff_arr[i]; i++) {- 		if (from_pool) { 			/* Return to the mem pool */ 			if ((struct megasas_ioctl_mm *)cmd->ioctl_mem[i]) {@@ -3426,7 +3538,6 @@ megasas_convert_compat_iocpacket(struct  	} } - static int  megasas_mgmt_compat_ioctl_fw(struct file *file, unsigned long arg) {@@ -3577,6 +3688,7 @@ static int __init megasas_init(void) 					   megasas_proc_show_dbg_lvl, 					   megasas_proc_get_dbg_lvl); + 		megasas_proc_hba_map = proc_mkdir("hba_map", megasas_proc_root); 	} #endifdiff -uprN rhel3/megaraid_sas.h rhel3_dump/megaraid_sas.h--- rhel3/megaraid_sas.h	2007-10-13 20:39:15.000000000 -0700+++ rhel3_dump/megaraid_sas.h	2007-10-13 20:41:00.000000000 -0700@@ -75,7 +75,7 @@ typedef void irqreturn_t;  * "message frames"  */ -/*+/**  * FW posts its state in upper 4 bits of outbound_msg_0 register  */ #define MFI_STATE_MASK				0xF0000000@@ -541,7 +541,7 @@ struct megasas_ctrl_info { 	/* 	 * Define ECC single-bit-error bucket information 	 */-+	 	u8 ecc_bucket_count; 	u8 reserved_2[11]; @@ -577,8 +577,8 @@ struct megasas_ctrl_info { #define MEGASAS_DBG_LVL				1  /* - * For ioctl memory manager- */+* For memory manager+*/  #define MAX_IOCTL_MEM_POOL			3 #define MEGASAS_INIT_IOCTL_MEM_SIZE		4096

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩福利电影在线| 一卡二卡三卡日韩欧美| 国产成人在线网站| 国产亚洲婷婷免费| 成人av影院在线| 亚洲欧美视频在线观看| 在线观看三级视频欧美| 天天操天天色综合| 日韩视频免费观看高清完整版| 美女网站一区二区| 欧美激情中文不卡| 欧美性色黄大片| 麻豆国产精品官网| 国产精品免费av| 欧美日韩免费视频| 国产精品自在在线| 国产精品麻豆视频| 欧美日韩精品免费| 国产在线精品免费| 亚洲日穴在线视频| 欧美一级夜夜爽| 岛国精品在线观看| 亚洲mv大片欧洲mv大片精品| 精品国产人成亚洲区| 91视频一区二区| 蜜臀a∨国产成人精品| 国产精品污网站| 欧美另类z0zxhd电影| 国产美女在线精品| 亚洲一区二区视频在线| 久久久综合视频| 欧美理论在线播放| 97精品电影院| 另类调教123区| 亚洲黄色小视频| 久久婷婷综合激情| 精品视频一区 二区 三区| 国产成人久久精品77777最新版本| 亚洲小说春色综合另类电影| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美色综合网站| gogo大胆日本视频一区| 国内欧美视频一区二区 | 色av一区二区| 国产一区福利在线| 亚洲超碰精品一区二区| 最近中文字幕一区二区三区| 久久综合九色综合久久久精品综合 | 国产片一区二区| 欧美一区二区三区四区高清| 91香蕉视频黄| 不卡的av中国片| 国产一区啦啦啦在线观看| 天堂成人免费av电影一区| 亚洲色图欧洲色图婷婷| 欧美极品aⅴ影院| 26uuu欧美日本| 欧美一区二视频| 欧美午夜视频网站| 色综合天天天天做夜夜夜夜做| 国产激情91久久精品导航| 久久精品国产77777蜜臀| 午夜av电影一区| 偷拍日韩校园综合在线| 亚洲一级二级三级在线免费观看| 日韩成人一级大片| 亚洲国产aⅴ天堂久久| 一区二区三区视频在线观看| 综合激情成人伊人| 成人免费视频在线观看| 中文字幕中文乱码欧美一区二区| 国产欧美一区二区三区网站| 国产香蕉久久精品综合网| www国产亚洲精品久久麻豆| 欧美tickle裸体挠脚心vk| 精品免费99久久| 欧美成人精品高清在线播放| 亚洲精品一区二区精华| 精品国一区二区三区| 精品久久久久久亚洲综合网| 日韩欧美视频在线| 久久综合五月天婷婷伊人| 26uuu精品一区二区在线观看| 久久久欧美精品sm网站| 久久精品视频在线看| 亚洲国产精品ⅴa在线观看| 综合网在线视频| 一区二区三区欧美在线观看| 亚洲高清免费在线| 久久99日本精品| 成人午夜在线视频| 色综合久久综合| 欧美日韩国产免费| 精品久久人人做人人爱| 国产精品久久久久一区二区三区共| 国产女同互慰高潮91漫画| 成人欧美一区二区三区在线播放| 亚洲精品久久嫩草网站秘色| 亚洲成人在线免费| 精品一区二区在线观看| www.亚洲色图.com| 欧美视频在线不卡| 欧美videos大乳护士334| 欧美激情在线看| 亚洲国产乱码最新视频| 国内精品免费在线观看| 99国产精品久久| 欧美美女黄视频| 国产三级精品在线| 亚洲国产精品久久人人爱蜜臀| 日本免费新一区视频| 国产夫妻精品视频| 欧亚洲嫩模精品一区三区| 欧美电影免费观看完整版| 国产精品伦一区| 美女视频一区二区三区| 91亚洲精华国产精华精华液| 777奇米四色成人影色区| 欧美激情艳妇裸体舞| 亚洲va韩国va欧美va精品| 国产mv日韩mv欧美| 777a∨成人精品桃花网| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲成人先锋电影| 成人avav在线| 精品国产污污免费网站入口| 亚洲国产另类av| 99视频有精品| 精品国产91久久久久久久妲己| 亚洲综合一二三区| 国产aⅴ综合色| 欧美一卡在线观看| 亚洲一二三专区| proumb性欧美在线观看| 精品av综合导航| 五月天亚洲婷婷| 一本久道中文字幕精品亚洲嫩| 一个色妞综合视频在线观看| 国产一区欧美一区| 在线播放中文字幕一区| 一区二区三区免费在线观看| 国产成人亚洲综合色影视| 欧美一区二区三区四区视频| 一区二区三区在线免费观看| 成人综合在线观看| 精品成人一区二区| 蜜臀国产一区二区三区在线播放 | 69p69国产精品| 中文字幕亚洲精品在线观看| 国产成人免费视| 欧美mv日韩mv国产网站app| 亚洲h在线观看| 欧美午夜片在线看| 亚洲综合在线观看视频| 91社区在线播放| 亚洲欧洲性图库| 成人精品高清在线| 国产亲近乱来精品视频 | 精品综合久久久久久8888| 欧美日韩国产乱码电影| 亚洲国产精品久久久久婷婷884| 91在线你懂得| 亚洲精品日韩一| 91丨九色丨尤物| 亚洲男人的天堂在线aⅴ视频| 91免费观看在线| 亚洲码国产岛国毛片在线| 99re免费视频精品全部| 亚洲私人影院在线观看| 色欧美乱欧美15图片| 亚洲综合精品久久| 欧美精选一区二区| 麻豆精品一区二区av白丝在线| 亚洲精品一区二区在线观看| 国产一区二区精品久久91| 日本一区二区视频在线观看| 成人午夜精品在线| 亚洲男人的天堂在线观看| 欧美在线小视频| 免费在线一区观看| 欧美成人vr18sexvr| 国产一区二区三区在线观看免费| 欧美国产日韩亚洲一区| 色先锋久久av资源部| 亚洲电影中文字幕在线观看| 69堂精品视频| 国产一区二区三区四区在线观看| 国产亚洲成aⅴ人片在线观看| 91日韩一区二区三区| 午夜免费久久看| 26uuu成人网一区二区三区| 不卡视频免费播放| 午夜亚洲福利老司机| 日韩精品一区二区三区蜜臀 | 91麻豆精品久久久久蜜臀| 久久精品二区亚洲w码| 亚洲国产成人午夜在线一区| 91在线云播放| 轻轻草成人在线| 亚洲欧洲www|