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

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

?? soc.c

?? linux和2410結合開發 用他可以生成2410所需的zImage文件
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* soc.c: Sparc SUNW,soc (Serial Optical Channel) Fibre Channel Sbus adapter support. * * Copyright (C) 1996,1997,1999 Jakub Jelinek (jj@ultra.linux.cz) * Copyright (C) 1997,1998 Jirka Hanika (geo@ff.cuni.cz) * * Sources: *	Fibre Channel Physical & Signaling Interface (FC-PH), dpANS, 1994 *	dpANS Fibre Channel Protocol for SCSI (X3.269-199X), Rev. 012, 1995 * * Supported hardware: *      Tested on SOC sbus card bought with SS1000 in Linux running on SS5 and Ultra1.  *      For SOC sbus cards, you have to make sure your FCode is 1.52 or later. *      If you have older FCode, you should try to upgrade or get SOC microcode from Sun *      (the microcode is present in Solaris soc driver as well). In that case you need *      to #define HAVE_SOC_UCODE and format the microcode into soc_asm.c. For the exact *      format mail me and I will tell you. I cannot offer you the actual microcode though, *      unless Sun confirms they don't mind. */static char *version =        "soc.c:v1.3 9/Feb/99 Jakub Jelinek (jj@ultra.linux.cz), Jirka Hanika (geo@ff.cuni.cz)\n";#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/slab.h>#include <linux/string.h>#include <linux/init.h>#include <asm/bitops.h>#include <asm/io.h>#include <asm/dma.h>#include <linux/errno.h>#include <asm/byteorder.h>#include <asm/openprom.h>#include <asm/oplib.h>#include <asm/auxio.h>#include <asm/pgtable.h>#include <asm/irq.h>/* #define SOCDEBUG *//* #define HAVE_SOC_UCODE */#include "fcp_impl.h"#include "soc.h"#ifdef HAVE_SOC_UCODE#include "soc_asm.h"#endif#define soc_printk printk ("soc%d: ", s->soc_no); printk #ifdef SOCDEBUG#define SOD(x)  soc_printk x;#else#define SOD(x)#endif#define for_each_soc(s) for (s = socs; s; s = s->next)struct soc *socs = NULL;static inline void soc_disable(struct soc *s){	sbus_writel(0, s->regs + IMASK);	sbus_writel(SOC_CMD_SOFT_RESET, s->regs + CMD);}static inline void soc_enable(struct soc *s){	SOD(("enable %08x\n", s->cfg))	sbus_writel(0, s->regs + SAE);	sbus_writel(s->cfg, s->regs + CFG);	sbus_writel(SOC_CMD_RSP_QALL, s->regs + CMD);	SOC_SETIMASK(s, SOC_IMASK_RSP_QALL | SOC_IMASK_SAE);	SOD(("imask %08lx %08lx\n", s->imask, sbus_readl(s->regs + IMAK)));}static void soc_reset(fc_channel *fc){	soc_port *port = (soc_port *)fc;	struct soc *s = port->s;		/* FIXME */	soc_disable(s);	s->req[0].seqno = 1;	s->req[1].seqno = 1;	s->rsp[0].seqno = 1;	s->rsp[1].seqno = 1;	s->req[0].in = 0;	s->req[1].in = 0;	s->rsp[0].in = 0;	s->rsp[1].in = 0;	s->req[0].out = 0;	s->req[1].out = 0;	s->rsp[0].out = 0;	s->rsp[1].out = 0;	/* FIXME */	soc_enable(s);}static void inline soc_solicited (struct soc *s){	fc_hdr fchdr;	soc_rsp *hwrsp;	soc_cq *sw_cq;	int token;	int status;	fc_channel *fc;	sw_cq = &s->rsp[SOC_SOLICITED_RSP_Q];	if (sw_cq->pool == NULL)		sw_cq->pool = (soc_req *)			(s->xram + xram_get_32low ((xram_p)&sw_cq->hw_cq->address));	sw_cq->in = xram_get_8 ((xram_p)&sw_cq->hw_cq->in);	SOD (("soc_solicited, %d pkts arrived\n", (sw_cq->in-sw_cq->out) & sw_cq->last))	for (;;) {		hwrsp = (soc_rsp *)sw_cq->pool + sw_cq->out;		token = xram_get_32low ((xram_p)&hwrsp->shdr.token);		status = xram_get_32low ((xram_p)&hwrsp->status);		fc = (fc_channel *)(&s->port[(token >> 11) & 1]);				if (status == SOC_OK) {			fcp_receive_solicited(fc, token >> 12,					      token & ((1 << 11) - 1),					      FC_STATUS_OK, NULL);		} else {			xram_copy_from(&fchdr, (xram_p)&hwrsp->fchdr, sizeof(fchdr));			/* We have intentionally defined FC_STATUS_* constants			 * to match SOC_* constants, otherwise we'd have to			 * translate status.			 */			fcp_receive_solicited(fc, token >> 12,					      token & ((1 << 11) - 1),					      status, &fchdr);		}					if (++sw_cq->out > sw_cq->last) {			sw_cq->seqno++;			sw_cq->out = 0;		}				if (sw_cq->out == sw_cq->in) {			sw_cq->in = xram_get_8 ((xram_p)&sw_cq->hw_cq->in);			if (sw_cq->out == sw_cq->in) {				/* Tell the hardware about it */				sbus_writel((sw_cq->out << 24) |					    (SOC_CMD_RSP_QALL &					     ~(SOC_CMD_RSP_Q0 << SOC_SOLICITED_RSP_Q)),					    s->regs + CMD);				/* Read it, so that we're sure it has been updated */				sbus_readl(s->regs + CMD);				sw_cq->in = xram_get_8 ((xram_p)&sw_cq->hw_cq->in);				if (sw_cq->out == sw_cq->in)					break;			}		}	}}static void inline soc_request (struct soc *s, u32 cmd){	SOC_SETIMASK(s, s->imask & ~(cmd & SOC_CMD_REQ_QALL));	SOD(("imask %08lx %08lx\n", s->imask, sbus_readl(s->regs + IMASK)));	SOD(("Queues available %08x OUT %X %X\n", cmd,	     xram_get_8((xram_p)&s->req[0].hw_cq->out),	     xram_get_8((xram_p)&s->req[0].hw_cq->out)))	if (s->port[s->curr_port].fc.state != FC_STATE_OFFLINE) {		fcp_queue_empty ((fc_channel *)&(s->port[s->curr_port]));		if (((s->req[1].in + 1) & s->req[1].last) != (s->req[1].out))			fcp_queue_empty ((fc_channel *)&(s->port[1 - s->curr_port]));	} else {		fcp_queue_empty ((fc_channel *)&(s->port[1 - s->curr_port]));	}	if (s->port[1 - s->curr_port].fc.state != FC_STATE_OFFLINE)		s->curr_port ^= 1;}static void inline soc_unsolicited (struct soc *s){	soc_rsp *hwrsp, *hwrspc;	soc_cq *sw_cq;	int count;	int status;	int flags;	fc_channel *fc;	sw_cq = &s->rsp[SOC_UNSOLICITED_RSP_Q];	if (sw_cq->pool == NULL)		sw_cq->pool = (soc_req *)			(s->xram + (xram_get_32low ((xram_p)&sw_cq->hw_cq->address)));	sw_cq->in = xram_get_8 ((xram_p)&sw_cq->hw_cq->in);	SOD (("soc_unsolicited, %d packets arrived\n", (sw_cq->in - sw_cq->out) & sw_cq->last))	while (sw_cq->in != sw_cq->out) {		/* ...real work per entry here... */		hwrsp = (soc_rsp *)sw_cq->pool + sw_cq->out;		hwrspc = NULL;		flags = xram_get_16 ((xram_p)&hwrsp->shdr.flags);		count = xram_get_8 ((xram_p)&hwrsp->count);		fc = (fc_channel *)&s->port[flags & SOC_PORT_B];		SOD(("FC %08lx fcp_state_change %08lx\n",		     (long)fc, (long)fc->fcp_state_change))				if (count != 1) {			/* Ugh, continuation entries */			u8 in;			if (count != 2) {				printk("%s: Too many continuations entries %d\n",				       fc->name, count);				goto update_out;			}						in = sw_cq->in;			if (in < sw_cq->out) in += sw_cq->last + 1;			if (in < sw_cq->out + 2) {				/* Ask the hardware if they haven't arrived yet. */				sbus_writel((sw_cq->out << 24) |					    (SOC_CMD_RSP_QALL &					     ~(SOC_CMD_RSP_Q0 << SOC_UNSOLICITED_RSP_Q)),					    s->regs + CMD);				/* Read it, so that we're sure it has been updated */				sbus_readl(s->regs + CMD);				sw_cq->in = xram_get_8 ((xram_p)&sw_cq->hw_cq->in);				in = sw_cq->in;				if (in < sw_cq->out)					in += sw_cq->last + 1;				if (in < sw_cq->out + 2) /* Nothing came, let us wait */					return;			}			if (sw_cq->out == sw_cq->last)				hwrspc = (soc_rsp *)sw_cq->pool;			else				hwrspc = hwrsp + 1;		}				switch (flags & ~SOC_PORT_B) {		case SOC_STATUS:			status = xram_get_32low ((xram_p)&hwrsp->status);			switch (status) {			case SOC_ONLINE:				SOD(("State change to ONLINE\n"));				fcp_state_change(fc, FC_STATE_ONLINE);				break;			case SOC_OFFLINE:				SOD(("State change to OFFLINE\n"));				fcp_state_change(fc, FC_STATE_OFFLINE);				break;			default:				printk ("%s: Unknown STATUS no %d\n",					fc->name, status);				break;			}			break;		case (SOC_UNSOLICITED|SOC_FC_HDR):			{				int r_ctl = xram_get_8 ((xram_p)&hwrsp->fchdr);				unsigned len;				char buf[64];								if ((r_ctl & 0xf0) == R_CTL_EXTENDED_SVC) {					len = xram_get_32 ((xram_p)&hwrsp->shdr.bytecnt);					if (len < 4 || !hwrspc) {						printk ("%s: Invalid R_CTL %02x "							"continuation entries\n",							fc->name, r_ctl);					} else {						if (len > 60)							len = 60;						xram_copy_from (buf, (xram_p)hwrspc,								(len + 3) & ~3);						if (*(u32 *)buf == LS_DISPLAY) {							int i;														for (i = 4; i < len; i++)								if (buf[i] == '\n')									buf[i] = ' ';							buf[len] = 0;							printk ("%s message: %s\n",								fc->name, buf + 4);						} else {							printk ("%s: Unknown LS_CMD "								"%02x\n", fc->name,								buf[0]);						}					}				} else {					printk ("%s: Unsolicited R_CTL %02x "						"not handled\n", fc->name, r_ctl);				}			}			break;		default:			printk ("%s: Unexpected flags %08x\n", fc->name, flags);			break;		};update_out:		if (++sw_cq->out > sw_cq->last) {			sw_cq->seqno++;			sw_cq->out = 0;		}				if (hwrspc) {			if (++sw_cq->out > sw_cq->last) {				sw_cq->seqno++;				sw_cq->out = 0;			}		}				if (sw_cq->out == sw_cq->in) {			sw_cq->in = xram_get_8 ((xram_p)&sw_cq->hw_cq->in);			if (sw_cq->out == sw_cq->in) {				/* Tell the hardware about it */				sbus_writel((sw_cq->out << 24) |					    (SOC_CMD_RSP_QALL &					     ~(SOC_CMD_RSP_Q0 << SOC_UNSOLICITED_RSP_Q)),					    s->regs + CMD);				/* Read it, so that we're sure it has been updated */				sbus_readl(s->regs + CMD);				sw_cq->in = xram_get_8 ((xram_p)&sw_cq->hw_cq->in);			}		}	}}static void soc_intr(int irq, void *dev_id, struct pt_regs *regs){	u32 cmd;	unsigned long flags;	register struct soc *s = (struct soc *)dev_id;	spin_lock_irqsave(&io_request_lock, flags);	cmd = sbus_readl(s->regs + CMD);	for (; (cmd = SOC_INTR (s, cmd)); cmd = sbus_readl(s->regs + CMD)) {		if (cmd & SOC_CMD_RSP_Q1) soc_unsolicited (s);		if (cmd & SOC_CMD_RSP_Q0) soc_solicited (s);		if (cmd & SOC_CMD_REQ_QALL) soc_request (s, cmd);	}	spin_unlock_irqrestore(&io_request_lock, flags);}#define TOKEN(proto, port, token) (((proto)<<12)|(token)|(port))static int soc_hw_enque (fc_channel *fc, fcp_cmnd *fcmd){	soc_port *port = (soc_port *)fc;	struct soc *s = port->s;	int qno;	soc_cq *sw_cq;	int cq_next_in;	soc_req *request;	fc_hdr *fch;	int i;	if (fcmd->proto == TYPE_SCSI_FCP)		qno = 1;	else		qno = 0;	SOD(("Putting a FCP packet type %d into hw queue %d\n", fcmd->proto, qno))	if (s->imask & (SOC_IMASK_REQ_Q0 << qno)) {		SOD(("EIO %08x\n", s->imask))		return -EIO;	}	sw_cq = s->req + qno;	cq_next_in = (sw_cq->in + 1) & sw_cq->last;		if (cq_next_in == sw_cq->out &&	    cq_next_in == (sw_cq->out = xram_get_8((xram_p)&sw_cq->hw_cq->out))) {		SOD(("%d IN %d OUT %d LAST %d\n", qno, sw_cq->in, sw_cq->out, sw_cq->last))		SOC_SETIMASK(s, s->imask | (SOC_IMASK_REQ_Q0 << qno));		SOD(("imask %08lx %08lx\n", s->imask, sbus_readl(s->regs + IMASK)));		/* If queue is full, just say NO */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99久久99小草精品免视看| 国产欧美日韩不卡免费| 欧美日韩精品是欧美日韩精品| 91国偷自产一区二区三区观看| 成人深夜在线观看| 欧美日韩国产系列| 亚洲视频电影在线| 成年人国产精品| 久久精品欧美日韩| 日本亚洲一区二区| 欧美成人一级视频| 亚洲另类色综合网站| 蜜桃一区二区三区四区| 精品国免费一区二区三区| 老司机一区二区| 亚洲欧洲日产国产综合网| 欧美专区日韩专区| 偷拍日韩校园综合在线| 一区二区三区视频在线看| 717成人午夜免费福利电影| 国产精品一二三四| 国产精品亚洲成人| 欧美色图第一页| 欧美成人国产一区二区| 欧美性生活大片视频| 国产99久久久国产精品免费看| 91精品欧美福利在线观看| 国内久久婷婷综合| 蜜桃视频在线观看一区| 91搞黄在线观看| 日韩欧美黄色影院| 精品视频在线看| 亚洲成av人影院| 欧美影视一区在线| 婷婷一区二区三区| 欧美高清一级片在线| 国产在线日韩欧美| 欧美成人a∨高清免费观看| 一区二区三区丝袜| 一区二区三区欧美亚洲| 久久久99精品免费观看不卡| 日韩一区二区精品| 欧美mv日韩mv亚洲| 欧美日韩极品在线观看一区| 欧美中文字幕一二三区视频| 日韩一二在线观看| 欧美日韩午夜在线视频| 日韩精品资源二区在线| 日本成人超碰在线观看| 欧美一区二区三区电影| 蜜臀av性久久久久蜜臀aⅴ | 国产69精品久久99不卡| 久久这里只有精品首页| 国产二区国产一区在线观看| 最新热久久免费视频| 欧美日韩一级视频| 91在线观看一区二区| 国产精品久久久久7777按摩| 欧美经典一区二区三区| 成人晚上爱看视频| 国产精品传媒视频| 欧美日韩午夜精品| 久久国内精品视频| 国产欧美日韩视频在线观看| 粉嫩一区二区三区在线看| 一区二区三区四区蜜桃| 在线成人免费视频| 毛片av一区二区| 久久精品视频在线免费观看| 波波电影院一区二区三区| 亚洲综合激情网| 久久综合久久99| 日本高清不卡在线观看| 毛片av中文字幕一区二区| 亚洲人成在线观看一区二区| 欧美日韩国产天堂| 成人av影院在线| 日本美女视频一区二区| 日本一区二区成人| 欧美成人猛片aaaaaaa| 91捆绑美女网站| 国产成人精品一区二区三区四区 | 亚洲精品免费在线观看| 91精品国产免费| 欧美色手机在线观看| 91在线小视频| 成人a区在线观看| 成人精品视频一区二区三区| 久热成人在线视频| 免费在线成人网| 日韩av电影天堂| 日本亚洲电影天堂| 日本特黄久久久高潮| 午夜一区二区三区视频| 国产精品女上位| 福利电影一区二区三区| 国产人伦精品一区二区| 国产精品自拍网站| 国产精品无遮挡| 91亚洲国产成人精品一区二三| 奇米色777欧美一区二区| 欧美精品 日韩| 亚洲精品成人精品456| 日韩免费看网站| 在线综合亚洲欧美在线视频| 色香色香欲天天天影视综合网| 国产成人午夜精品5599 | 激情深爱一区二区| 欧美一区二区三区日韩视频| 国产精品美女久久久久久| 精品久久久久久久久久久久久久久久久 | 加勒比av一区二区| 美女一区二区视频| 日日夜夜免费精品| 日日夜夜精品视频免费| 亚洲成av人影院在线观看网| 亚洲人xxxx| 成人欧美一区二区三区小说| 国产欧美精品一区二区三区四区 | 91美女视频网站| 色系网站成人免费| 99re热这里只有精品视频| www.99精品| 91国产福利在线| 欧美性受xxxx黑人xyx性爽| 在线视频欧美精品| 色综合一区二区| 在线精品亚洲一区二区不卡| 欧美在线免费播放| 欧美精品在线一区二区三区| 宅男噜噜噜66一区二区66| 欧美成人在线直播| 久久午夜色播影院免费高清| 久久久久久久久97黄色工厂| 久久精品亚洲精品国产欧美| 国产精品久久久久国产精品日日| ...xxx性欧美| 亚洲国产精品天堂| 久久99精品久久久久久动态图| 韩国精品主播一区二区在线观看| 成人在线综合网站| 在线观看日韩高清av| 7878成人国产在线观看| 久久久国产午夜精品| 综合精品久久久| 日韩电影在线看| 国产91精品一区二区| 色美美综合视频| 日韩一区二区免费高清| 国产精品免费视频网站| 亚洲成在人线在线播放| 国产精品综合在线视频| 欧美在线你懂的| 欧美精品一区男女天堂| 国产精品超碰97尤物18| 日韩av电影天堂| 91麻豆国产精品久久| 欧美一区二区在线免费观看| 国产欧美1区2区3区| 亚洲国产成人av网| 国产福利一区二区三区视频在线 | 在线电影欧美成精品| 国产婷婷精品av在线| 亚洲国产成人va在线观看天堂| 精品一区二区三区影院在线午夜 | 成人激情校园春色| 精品少妇一区二区三区视频免付费| 久久精品视频网| 亚洲444eee在线观看| 懂色av中文一区二区三区| 欧美疯狂性受xxxxx喷水图片| 国产日产精品1区| 美女视频黄a大片欧美| 一本色道久久综合亚洲aⅴ蜜桃 | 欧美精品一二三区| 中文字幕一区二区三区视频| 九色综合狠狠综合久久| 欧美午夜不卡在线观看免费| 国产欧美一区二区精品秋霞影院 | 欧美一区二区美女| 一区二区三区中文在线| 国产+成+人+亚洲欧洲自线| 日韩午夜电影在线观看| 偷拍日韩校园综合在线| 日本乱人伦一区| 欧美高清在线视频| 经典一区二区三区| 欧美大片一区二区| 麻豆精品蜜桃视频网站| 91精品啪在线观看国产60岁| 亚洲午夜久久久| 欧美午夜理伦三级在线观看| 亚洲欧美色图小说| 99视频国产精品| 亚洲三级免费观看| 99精品偷自拍| 一区在线观看免费| 91蜜桃婷婷狠狠久久综合9色| 国产精品久久久久精k8 | 欧美另类高清zo欧美|