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

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

?? 3w-xxxx.c

?? 講述linux的初始化過程
?? C
?? 第 1 頁 / 共 5 頁
字號:
/*    3w-xxxx.c -- 3ware Storage Controller device driver for Linux.   Written By: Adam Radford <linux@3ware.com>   Modifications By: Joel Jacobson <linux@3ware.com>   		     Arnaldo Carvalho de Melo <acme@conectiva.com.br>   Copyright (C) 1999-2000 3ware Inc.   Kernel compatablity By: 	Andre Hedrick <andre@suse.com>   Non-Copyright (C) 2000	Andre Hedrick <andre@suse.com>      Further tiny build fixes and trivial hoovering    Alan Cox   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; version 2 of the License.   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.                                 NO WARRANTY                                                                  THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR           CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT         LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT,         MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is       solely responsible for determining the appropriateness of using and          distributing the Program and assumes all risks associated with its           exercise of rights under this Agreement, including but not limited to        the risks and costs of program errors, damage to or loss of data,            programs or equipment, and unavailability or interruption of operations.     DISCLAIMER OF LIABILITY                                                      NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY      DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL           DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND      ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR        TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE       USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED     HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES                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    Bugs/Comments/Suggestions should be mailed to:                               linux@3ware.com   For more information, goto:   http://www.3ware.com   History   -------   0.1.000 -     Initial release.   0.4.000 -     Added support for Asynchronous Event Notification through                 ioctls for 3DM.   1.0.000 -     Added DPO & FUA bit support for WRITE_10 & WRITE_6 cdb                 to disable drive write-cache before writes.   1.1.000 -     Fixed performance bug with DPO & FUA not existing for WRITE_6.   1.2.000 -     Added support for clean shutdown notification/feature table.   1.02.00.001 - Added support for full command packet posts through ioctls                 for 3DM.                 Bug fix so hot spare drives don't show up.   1.02.00.002 - Fix bug with tw_setfeature() call that caused oops on some                 systems.   08/21/00    - release previously allocated resources on failure at                 tw_allocate_memory (acme)*/#include <linux/module.h>MODULE_AUTHOR ("3ware Inc.");MODULE_DESCRIPTION ("3ware Storage Controller Linux Driver");#include <linux/kernel.h>#include <linux/pci.h>#include <linux/time.h>#include <linux/proc_fs.h>#include <linux/sched.h>#include <linux/ioport.h>#include <linux/blk.h>#include <linux/hdreg.h>#include <linux/string.h>#include <linux/delay.h>#include <linux/smp.h>#include <linux/reboot.h>#include <linux/spinlock.h>#include <asm/errno.h>#include <asm/io.h>#include <asm/irq.h>#include <asm/uaccess.h>#define __3W_C			/* let 3w-xxxx.h know it is use */#include "sd.h"#include "scsi.h"#include "hosts.h"#include "3w-xxxx.h"static int tw_copy_info(TW_Info *info, char *fmt, ...);static void tw_copy_mem_info(TW_Info *info, char *data, int len);static void tw_interrupt(int irq, void *dev_instance, struct pt_regs *regs);static int tw_halt(struct notifier_block *nb, ulong event, void *buf);/* Notifier block to get a notify on system shutdown/halt/reboot */static struct notifier_block tw_notifier = {  tw_halt, NULL, 0};/* Globals */char *tw_driver_version="1.02.00.002";TW_Device_Extension *tw_device_extension_list[TW_MAX_SLOT];int tw_device_extension_count = 0;/* Functions *//* This function will complete an aen request from the isr */int tw_aen_complete(TW_Device_Extension *tw_dev, int request_id) {	TW_Param *param;	unsigned short aen, aen_code;	if (tw_dev->alignment_virtual_address[request_id] == NULL) {		printk(KERN_WARNING "3w-xxxx: tw_aen_complete(): Bad alignment virtual address.\n");		return 1;	}	param = (TW_Param *)tw_dev->alignment_virtual_address[request_id];	aen = *(unsigned short *)(param->data);	aen_code = (aen & 0x0ff);	dprintk(KERN_NOTICE "3w-xxxx: tw_aen_complete(): Queue'd code 0x%x\n", aen_code);	/* Now queue the code */	tw_dev->aen_queue[tw_dev->aen_tail] = aen_code;	if (tw_dev->aen_tail == TW_Q_LENGTH - 1) {		tw_dev->aen_tail = TW_Q_START;	} else {		tw_dev->aen_tail = tw_dev->aen_tail + 1;	}	if (tw_dev->aen_head == tw_dev->aen_tail) {		if (tw_dev->aen_head == TW_Q_LENGTH - 1) {			tw_dev->aen_head = TW_Q_START;		} else {			tw_dev->aen_head = tw_dev->aen_head + 1;		}	}	tw_dev->state[request_id] = TW_S_COMPLETED;	tw_state_request_finish(tw_dev, request_id);	return 0;} /* End tw_aen_complete() *//* This function will drain the aen queue after a soft reset */int tw_aen_drain_queue(TW_Device_Extension *tw_dev){	TW_Command *command_packet;	TW_Param *param;	int tries = 0;	int request_id = 0;	u32 command_que_value = 0, command_que_addr;	u32 status_reg_value = 0, status_reg_addr;	u32 param_value;	TW_Response_Queue response_queue;	u32 response_que_addr;	unsigned short aen;	unsigned short aen_code;	int finished = 0;	int first_reset = 0;	int queue = 0;	int imax, i;	int found = 0;	dprintk(KERN_NOTICE "3w-xxxx: tw_aen_drain_queue()\n");	command_que_addr = tw_dev->registers.command_que_addr;	status_reg_addr = tw_dev->registers.status_reg_addr;	response_que_addr = tw_dev->registers.response_que_addr;	if (tw_poll_status(tw_dev, TW_STATUS_ATTENTION_INTERRUPT, 15)) {		printk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): No attention interrupt for card %d\n", tw_dev->host->host_no);		return 1;	}	/* Initialize command packet */	if (tw_dev->command_packet_virtual_address[request_id] == NULL) {		printk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): Bad command packet virtual address.\n");		return 1;	}	command_packet = (TW_Command *)tw_dev->command_packet_virtual_address[request_id];	memset(command_packet, 0, sizeof(TW_Sector));	command_packet->byte0.opcode = TW_OP_GET_PARAM;	command_packet->byte0.sgl_offset = 2;	command_packet->size = 4;	command_packet->request_id = request_id;	command_packet->byte3.unit = 0;	command_packet->byte3.host_id = 0;	command_packet->status = 0;	command_packet->flags = 0;	command_packet->byte6.parameter_count = 1;	command_que_value = tw_dev->command_packet_physical_address[request_id];	if (command_que_value == 0) {		printk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): Bad command packet physical address.\n");		return 1;	}	/* Now setup the param */	if (tw_dev->alignment_virtual_address[request_id] == NULL) {		printk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): Bad alignment virtual address.\n");		return 1;	}	param = (TW_Param *)tw_dev->alignment_virtual_address[request_id];	memset(param, 0, sizeof(TW_Sector));	param->table_id = 0x401; /* AEN table */	param->parameter_id = 2; /* Unit code */	param->parameter_size_bytes = 2;	param_value = tw_dev->alignment_physical_address[request_id];	if (param_value == 0) {		printk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): Bad alignment physical address.\n");		return 1;	}	command_packet->byte8.param.sgl[0].address = param_value;	command_packet->byte8.param.sgl[0].length = sizeof(TW_Sector);	imax = TW_POLL_MAX_RETRIES;	/* Now drain the controller's aen queue */	do {		/* Post command packet */		outl(command_que_value, command_que_addr);    		/* Now poll for completion */		for (i=0;i<imax;i++) {			mdelay(10);			status_reg_value = inl(status_reg_addr);			if (tw_check_bits(status_reg_value)) {				printk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): Unexpected bits.\n");				return 1;			}			if ((status_reg_value & TW_STATUS_RESPONSE_QUEUE_EMPTY) == 0) {				response_queue.value = inl(response_que_addr);				request_id = (unsigned char)response_queue.u.response_id;    				if (request_id != 0) {					/* Unexpected request id */					printk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): Unexpected request id.\n");					return 1;				}					if (command_packet->status != 0) {					if (command_packet->flags != TW_AEN_TABLE_UNDEFINED) {						/* Bad response */						printk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): Bad response, status = 0x%x, flags = 0x%x.\n", command_packet->status, command_packet->flags);						return 1;					} else {						/* We know this is a 3w-1x00, and doesn't support aen's */						return 0;					}				}				/* Now check the aen */				aen = *(unsigned short *)(param->data);				aen_code = (aen & 0x0ff);				queue = 0;				switch (aen_code) {					case TW_AEN_QUEUE_EMPTY:						dprintk(KERN_NOTICE "3w-xxxx: tw_aen_drain_queue(): Found TW_AEN_QUEUE_EMPTY.\n");						if (first_reset != 1) {							continue;						} else {							finished = 1;						}						break;					case TW_AEN_SOFT_RESET:						dprintk(KERN_NOTICE "3w-xxxx: tw_aen_drain_queue(): Found TW_AEN_SOFT_RESET.\n");						if (first_reset == 0) {							first_reset = 1;						} else {							queue = 1;						}						break;					case TW_AEN_DEGRADED_MIRROR:						dprintk(KERN_NOTICE "3w-xxxx: tw_aen_drain_queue(): Found TW_AEN_DEGRADED_MIRROR.\n");						queue = 1;						break;					case TW_AEN_CONTROLLER_ERROR:						dprintk(KERN_NOTICE "3w-xxxx: tw_aen_drain_queue(): Found TW_AEN_CONTROLLER_ERROR.\n");						queue = 1;						break;					case TW_AEN_REBUILD_FAIL:						dprintk(KERN_NOTICE "3w-xxxx: tw_aen_drain_queue(): Found TW_AEN_REBUILD_FAIL.\n");						queue = 1;						break;					case TW_AEN_REBUILD_DONE:						dprintk(KERN_NOTICE "3w-xxxx: tw_aen_drain_queue(): Found TW_AEN_REBUILD_DONE.\n");						queue = 1;						break;					case TW_AEN_QUEUE_FULL:						dprintk(KERN_NOTICE "3w-xxxx: tw_aen_drain_queue(): Found TW_AEN_QUEUE_FULL.\n");						queue = 1;						break;					default:						dprintk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): Unknown AEN code 0x%x.\n", aen_code);						queue = 1;				}				/* Now put the aen on the aen_queue */				if (queue == 1) {					tw_dev->aen_queue[tw_dev->aen_tail] = aen_code;					if (tw_dev->aen_tail == TW_Q_LENGTH - 1) {						tw_dev->aen_tail = TW_Q_START;					} else {						tw_dev->aen_tail = tw_dev->aen_tail + 1;					}					if (tw_dev->aen_head == tw_dev->aen_tail) {						if (tw_dev->aen_head == TW_Q_LENGTH - 1) {							tw_dev->aen_head = TW_Q_START;						} else {							tw_dev->aen_head = tw_dev->aen_head + 1;						}					}				}				found = 1;				break;			}		}		if (found == 0) {			printk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): Response never received.\n");			return 1;		}		tries++;	} while ((tries < TW_MAX_AEN_TRIES) && (finished == 0));	if (tries >=TW_MAX_AEN_TRIES) {		printk(KERN_WARNING "3w-xxxx: tw_aen_drain_queue(): Aen queue error.\n");		return 1;	}	return 0;} /* End tw_aen_drain_queue() *//* This function will read the aen queue from the isr */int tw_aen_read_queue(TW_Device_Extension *tw_dev, int request_id) {	TW_Command *command_packet;	TW_Param *param;	u32 command_que_value = 0, command_que_addr;	u32 status_reg_value = 0, status_reg_addr;	u32 param_value = 0;	dprintk(KERN_NOTICE "3w-xxxx: tw_aen_read_queue()\n");	command_que_addr = tw_dev->registers.command_que_addr;	status_reg_addr = tw_dev->registers.status_reg_addr;	status_reg_value = inl(status_reg_addr);	if (tw_check_bits(status_reg_value)) {		printk(KERN_WARNING "3w-xxxx: tw_aen_read_queue(): Unexpected bits.\n");		return 1;	}	if (tw_dev->command_packet_virtual_address[request_id] == NULL) {		printk(KERN_WARNING "3w-xxxx: tw_aen_read_queue(): Bad command packet virtual address.\n");		return 1;	}	command_packet = (TW_Command *)tw_dev->command_packet_virtual_address[request_id];	memset(command_packet, 0, sizeof(TW_Sector));	command_packet->byte0.opcode = TW_OP_GET_PARAM;	command_packet->byte0.sgl_offset = 2;	command_packet->size = 4;	command_packet->request_id = request_id;	command_packet->byte3.unit = 0;	command_packet->byte3.host_id = 0;	command_packet->status = 0;	command_packet->flags = 0;	command_packet->byte6.parameter_count = 1;	command_que_value = tw_dev->command_packet_physical_address[request_id];	if (command_que_value == 0) {		printk(KERN_WARNING "3w-xxxx: tw_aen_read_queue(): Bad command packet physical address.\n");		return 1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产免费视频| 亚洲日本电影在线| 久久影视一区二区| 亚洲欧美一区二区三区久本道91| 亚洲影院理伦片| 东方aⅴ免费观看久久av| 欧美群妇大交群的观看方式| 国产精品美女久久久久aⅴ| 久久福利视频一区二区| 欧美私人免费视频| 亚洲欧洲精品天堂一级 | 日本在线观看不卡视频| 91在线视频免费观看| 精品国产sm最大网站| 日韩专区一卡二卡| 欧美午夜精品电影| 亚洲精选在线视频| 97久久精品人人澡人人爽| 久久综合成人精品亚洲另类欧美| 日韩国产精品久久| 欧美视频一区二区| 一级特黄大欧美久久久| 不卡视频在线看| 国产亚洲精品bt天堂精选| 久久精品久久99精品久久| 欧美日韩不卡一区| 亚洲综合视频在线观看| 日本国产一区二区| 亚洲精品免费电影| 成人av影院在线| 国产精品久久一级| 99免费精品在线观看| 国产精品你懂的| 99久久精品久久久久久清纯| 日韩一区在线免费观看| 91麻豆精东视频| 一区二区不卡在线播放 | 国产一区二区在线视频| 日韩女优av电影| 国产一区视频在线看| 久久日一线二线三线suv| 久国产精品韩国三级视频| 欧美刺激午夜性久久久久久久| 蜜臀精品久久久久久蜜臀 | 色婷婷综合久久久中文字幕| 亚洲女爱视频在线| 欧美在线播放高清精品| 日韩精品免费视频人成| 制服丝袜中文字幕一区| 久久精品国产999大香线蕉| 久久一留热品黄| 成人av免费网站| 一区二区三区四区蜜桃| 欧美日韩午夜在线视频| 美女www一区二区| 国产欧美久久久精品影院| 99久久综合国产精品| 亚洲一区二区不卡免费| 欧美一区二区私人影院日本| 成人精品视频网站| 亚洲免费高清视频在线| 欧美高清一级片在线| 国精品**一区二区三区在线蜜桃| 国产欧美在线观看一区| 欧美亚洲日本一区| 国产毛片一区二区| 一区二区三区在线不卡| 日韩欧美区一区二| 91视频在线观看| 七七婷婷婷婷精品国产| 国产精品国产三级国产aⅴ无密码| 在线一区二区视频| 国产一区二区伦理| 五月天欧美精品| 国产精品国产三级国产专播品爱网 | 日韩国产在线观看一区| 欧美韩国日本综合| 欧美日韩国产在线观看| 国产成人精品免费| 日日夜夜精品视频天天综合网| 国产女人18毛片水真多成人如厕 | 色播五月激情综合网| 精品一二三四在线| 一区二区在线免费| 久久奇米777| 欧美一级日韩免费不卡| 色网站国产精品| 国产二区国产一区在线观看| 日本不卡一二三区黄网| 一区二区三区四区在线| 国产精品免费网站在线观看| 欧美v亚洲v综合ⅴ国产v| 欧美撒尿777hd撒尿| 成人av网址在线| 国产老肥熟一区二区三区| 视频一区中文字幕国产| 亚洲卡通欧美制服中文| 自拍偷拍欧美激情| 国产性天天综合网| 久久品道一品道久久精品| 日韩一级高清毛片| 欧美精品视频www在线观看| 91免费精品国自产拍在线不卡 | 欧美bbbbb| 日韩精品国产欧美| 亚洲成人免费在线观看| 一区二区三区视频在线看| 国产精品国模大尺度视频| 国产精品丝袜久久久久久app| 精品国产免费视频| 精品国产伦理网| 日韩女优制服丝袜电影| 欧美一级二级在线观看| 欧美一卡2卡3卡4卡| 日韩视频一区二区三区在线播放| 欧美三级乱人伦电影| 在线一区二区视频| 欧美日韩亚洲高清一区二区| 欧美日韩一区二区在线观看| 欧美挠脚心视频网站| 欧美精品精品一区| 91麻豆精品国产91久久久使用方法| 欧美色图片你懂的| 制服丝袜日韩国产| 91麻豆精品国产91久久久久久久久 | 天使萌一区二区三区免费观看| 亚洲成人午夜影院| 免费人成精品欧美精品| 久久精品国产99国产| 国产99久久久精品| www.亚洲激情.com| 91国偷自产一区二区三区观看 | 日韩欧美国产电影| 精品国产免费人成在线观看| 欧美国产一区在线| 亚洲毛片av在线| 日本欧美韩国一区三区| 国产精品一区三区| 91麻豆免费看| 日韩欧美在线一区二区三区| 久久久综合激的五月天| 日韩毛片在线免费观看| 三级一区在线视频先锋| 国产主播一区二区| 色乱码一区二区三区88| 日韩欧美亚洲国产精品字幕久久久| 国产亚洲污的网站| 亚洲一区二三区| 国产精品自拍在线| 91啦中文在线观看| 欧美tickling挠脚心丨vk| 中文字幕亚洲区| 免费观看91视频大全| www.欧美精品一二区| 5858s免费视频成人| 欧美国产日韩a欧美在线观看| 亚洲午夜在线视频| 粉嫩欧美一区二区三区高清影视| 欧美综合天天夜夜久久| 久久久久久久久久久久久女国产乱| 中文字幕日本不卡| 久久激情综合网| 欧美三级中文字| 国产精品久久久久久久第一福利| 视频一区在线播放| av亚洲精华国产精华| 日韩欧美二区三区| 亚洲一区在线观看网站| 国产91精品久久久久久久网曝门| 欧美日本视频在线| 亚洲欧美日韩系列| 国产一区二区三区高清播放| 欧美午夜不卡视频| 亚洲欧洲日韩综合一区二区| 国产综合成人久久大片91| 欧美日本不卡视频| 一区二区三区四区高清精品免费观看| 国产综合久久久久久鬼色| 9191国产精品| 亚洲观看高清完整版在线观看| 成人黄色在线视频| 久久免费国产精品| 久久99久久久欧美国产| 91.com视频| 天堂影院一区二区| 精品视频1区2区3区| 一区二区三区美女视频| 91香蕉视频黄| 亚洲日穴在线视频| eeuss鲁一区二区三区| 国产日韩亚洲欧美综合| 国产精品一区二区无线| 久久久91精品国产一区二区三区| 久久国产福利国产秒拍| 精品日韩一区二区三区| 久久国产精品99久久人人澡| 欧美刺激脚交jootjob| 久久66热re国产| 26uuu另类欧美| 国产一区二区三区四|