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

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

?? aha1740.c

?? 內核是系統的心臟
?? C
字號:
/*  $Id$
 *  1993/03/31
 *  linux/kernel/aha1740.c
 *
 *  Based loosely on aha1542.c which is
 *  Copyright (C) 1992  Tommy Thorn and
 *  Modified by Eric Youngdale
 *
 *  This file is aha1740.c, written and
 *  Copyright (C) 1992,1993  Brad McLean
 *  
 *  Modifications to makecode and queuecommand
 *  for proper handling of multiple devices courteously
 *  provided by Michael Weller, March, 1993
 *
 * aha1740_makecode may still need even more work
 * if it doesn't work for your devices, take a look.
 */

#include <linux/kernel.h>
#include <linux/head.h>
#include <linux/types.h>
#include <linux/string.h>
#include <linux/ioport.h>

#include <linux/sched.h>
#include <asm/dma.h>

#include <asm/system.h>
#include <asm/io.h>
#include "../block/blk.h"
#include "scsi.h"
#include "hosts.h"

#include "aha1740.h"

/* IF YOU ARE HAVING PROBLEMS WITH THIS DRIVER, AND WANT TO WATCH
   IT WORK, THEN:
#define DEBUG
*/
#ifdef DEBUG
#define DEB(x) x
#else
#define DEB(x)
#endif

/*
static const char RCSid[] = "$Header: /usr/src/linux/kernel/blk_drv/scsi/RCS/aha1740.c,v 1.1 1992/07/24 06:27:38 root Exp root $";
*/

static unsigned int slot, base;
static unsigned char irq_level;

static struct ecb ecb[AHA1740_ECBS];	/* One for each queued operation */

static int aha1740_last_ecb_used  = 0;	/* optimization */

int aha1740_makecode(unchar *sense, unchar *status)
{
    struct statusword
    {
	ushort	don:1,	/* Command Done - No Error */
		du:1,	/* Data underrun */
	:1,	qf:1,	/* Queue full */
		sc:1,	/* Specification Check */
		dor:1,	/* Data overrun */
		ch:1,	/* Chaining Halted */
		intr:1,	/* Interrupt issued */
		asa:1,	/* Additional Status Available */
		sns:1,	/* Sense information Stored */
	:1,	ini:1,	/* Initialization Required */
		me:1,	/* Major error or exception */
	:1,	eca:1,  /* Extended Contingent alliance */
	:1;
    } status_word;
    int retval = DID_OK;

    status_word = * (struct statusword *) status;
#ifdef DEBUG
printk("makecode from %x,%x,%x,%x %x,%x,%x,%x",status[0],status[1],status[2],status[3],
sense[0],sense[1],sense[2],sense[3]);
#endif
    if (!status_word.don) /* Anything abnormal was detected */
    {
	if ( (status[1]&0x18) || status_word.sc ) /*Additional info available*/
	{
	    /* Use the supplied info for futher diagnostics */
	    switch ( status[2] )
	    {
	    case 0x12:
		if ( status_word.dor )
		    retval=DID_ERROR;	/* It's an Overrun */
		/* If not overrun, assume underrun and ignore it! */
	    case 0x00: /* No info, assume no error, should not occur */
		break;
	    case 0x11:
	    case 0x21:
		retval=DID_TIME_OUT;
		break;
	    case 0x0a:
		retval=DID_BAD_TARGET;
		break;
	    case 0x04:
	    case 0x05:
		retval=DID_ABORT; /* Either by this driver or the AHA1740
					 itself */
		break;
	    default:
		retval=DID_ERROR; /* No further diagnostics possible */
	    } 
	}
	else
	{ /* Michael suggests, and Brad concurs: */
	    if ( status_word.qf )
	    {
		retval = DID_TIME_OUT; /* forces a redo */
		/* I think this specific one should not happen -Brad */
		printk("aha1740.c: WARNING: AHA1740 queue overflow!\n");
	    }
	    else if ( status[0]&0x60 )
	    {
		retval = DID_ERROR; /* Didn't found a better error */
	    }
	    /* In any other case return DID_OK so for example
               CONDITION_CHECKS make it through to the appropriate
	       device driver */
	}
    }
    /* Under all circumstances supply the target status -Michael */
    return status[3] | retval << 16;
}

int aha1740_test_port(void)
{
    char    name[4],tmp;

    /* Okay, look for the EISA ID's */
    name[0]= 'A' -1 + ((tmp = inb(HID0)) >> 2); /* First character */
    name[1]= 'A' -1 + ((tmp & 3) << 3);
    name[1]+= ((tmp = inb(HID1)) >> 5)&0x7;	/* Second Character */
    name[2]= 'A' -1 + (tmp & 0x1f);		/* Third Character */
    name[3]=0;
    tmp = inb(HID2);
    if ( strcmp ( name, HID_MFG ) || inb(HID2) != HID_PRD )
	return 0;   /* Not an Adaptec 174x */

/*  if ( inb(HID3) != HID_REV )
	printk("aha1740: Warning; board revision of %d; expected %d\n",
	    inb(HID3),HID_REV); */

    if ( inb(EBCNTRL) != EBCNTRL_VALUE )
    {
	printk("aha1740: Board detected, but EBCNTRL = %x, so disabled it.\n",
	    inb(EBCNTRL));
	return 0;
    }

    if ( inb(PORTADR) & PORTADDR_ENH )
	return 1;   /* Okay, we're all set */
	
    printk("aha1740: Board detected, but not in enhanced mode, so disabled it.\n");
    return 0;
}

const char *aha1740_info(void)
{
    static char buffer[] = "Adaptec 174x (EISA)";
    return buffer;
}

/* A "high" level interrupt handler */
void aha1740_intr_handle(int foo)
{
    void (*my_done)(Scsi_Cmnd *);
    int errstatus, adapstat;
    int number_serviced;
    struct ecb *ecbptr;
    Scsi_Cmnd *SCtmp;

    number_serviced = 0;

    while(inb(G2STAT) & G2STAT_INTPEND)
    {
	DEB(printk("aha1740_intr top of loop.\n"));
	adapstat = inb(G2INTST);
	outb(G2CNTRL_IRST,G2CNTRL); /* interrupt reset */
      
        switch ( adapstat & G2INTST_MASK )
	{
	case	G2INTST_CCBRETRY:
	case	G2INTST_CCBERROR:
	case	G2INTST_CCBGOOD:
	    ecbptr = (struct ecb *) (	((ulong) inb(MBOXIN0)) +
					((ulong) inb(MBOXIN1) <<8) +
					((ulong) inb(MBOXIN2) <<16) +
					((ulong) inb(MBOXIN3) <<24) );
	    outb(G2CNTRL_HRDY,G2CNTRL); /* Host Ready -> Mailbox in complete */
	    SCtmp = ecbptr->SCpnt;
	    if (SCtmp->host_scribble)
		scsi_free(SCtmp->host_scribble, 512);
	  /* Fetch the sense data, and tuck it away, in the required slot.  The
	     Adaptec automatically fetches it, and there is no guarantee that
	     we will still have it in the cdb when we come back */
	    if ( (adapstat & G2INTST_MASK) == G2INTST_CCBERROR )
	      {
		memcpy(SCtmp->sense_buffer, ecbptr->sense, 
		       sizeof(SCtmp->sense_buffer));
		errstatus = aha1740_makecode(ecbptr->sense,ecbptr->status);
	      }
	    else
		errstatus = 0;
	    DEB(if (errstatus) printk("aha1740_intr_handle: returning %6x\n", errstatus));
	    SCtmp->result = errstatus;
	    my_done = ecbptr->done;
	    memset(ecbptr,0,sizeof(struct ecb)); 
	    if ( my_done )
		my_done(SCtmp);
	    break;
	case	G2INTST_HARDFAIL:
	    printk("aha1740 hardware failure!\n");
	    panic("aha1740.c");	/* Goodbye */
	case	G2INTST_ASNEVENT:
	    printk("aha1740 asynchronous event: %02x %02x %02x %02x %02x\n",adapstat,
		inb(MBOXIN0),inb(MBOXIN1),inb(MBOXIN2),inb(MBOXIN3)); /* Say What? */
	    outb(G2CNTRL_HRDY,G2CNTRL); /* Host Ready -> Mailbox in complete */
	    break;
	case	G2INTST_CMDGOOD:
	    /* set immediate command success flag here: */
	    break;
	case	G2INTST_CMDERROR:
	    /* Set immediate command failure flag here: */
	    break;
	}
      number_serviced++;
    };
}

int aha1740_queuecommand(Scsi_Cmnd * SCpnt, void (*done)(Scsi_Cmnd *))
{
    unchar direction;
    unchar *cmd = (unchar *) SCpnt->cmnd;
    unchar target = SCpnt->target;
    void *buff = SCpnt->request_buffer;
    int bufflen = SCpnt->request_bufflen;
    int ecbno;
    DEB(int i);

    
    if(*cmd == REQUEST_SENSE)
    {
        if (bufflen != sizeof(SCpnt->sense_buffer))
	{
	    printk("Wrong buffer length supplied for request sense (%d)\n",bufflen);
	    panic("aha1740.c");
        }
        SCpnt->result = 0;
        done(SCpnt); 
        return 0;
    }

#ifdef DEBUG
    if (*cmd == READ_10 || *cmd == WRITE_10)
        i = xscsi2int(cmd+2);
    else if (*cmd == READ_6 || *cmd == WRITE_6)
        i = scsi2int(cmd+2);
    else
        i = -1;
    printk("aha1740_queuecommand: dev %d cmd %02x pos %d len %d ", target, *cmd, i, bufflen);
    printk("scsi cmd:");
    for (i = 0; i < (COMMAND_SIZE(*cmd)); i++) printk("%02x ", cmd[i]);
    printk("\n");
#endif

    /* locate an available ecb */

    cli();
    ecbno = aha1740_last_ecb_used + 1;		/* An optimization */
    if (ecbno >= AHA1740_ECBS) ecbno = 0;

    do{
      if( ! ecb[ecbno].cmdw )
	break;
      ecbno++;
      if (ecbno >= AHA1740_ECBS ) ecbno = 0;
    } while (ecbno != aha1740_last_ecb_used);

    if( ecb[ecbno].cmdw )
      panic("Unable to find empty ecb for aha1740.\n");

    ecb[ecbno].cmdw = AHA1740CMD_INIT;	/* SCSI Initiator Command doubles as reserved flag */

    aha1740_last_ecb_used = ecbno;    
    sti();

#ifdef DEBUG
    printk("Sending command (%d %x)...",ecbno, done);
#endif

    ecb[ecbno].cdblen = COMMAND_SIZE(*cmd);	/* SCSI Command Descriptor Block Length */

    direction = 0;
    if (*cmd == READ_10 || *cmd == READ_6)
	direction = 1;
    else if (*cmd == WRITE_10 || *cmd == WRITE_6)
	direction = 0;

    memcpy(ecb[ecbno].cdb, cmd, ecb[ecbno].cdblen);

    if (SCpnt->use_sg)
    {
        struct scatterlist * sgpnt;
        struct aha1740_chain * cptr;
        int i;
#ifdef DEBUG
        unsigned char * ptr;
#endif
        ecb[ecbno].sg = 1;	  /* SCSI Initiator Command  w/scatter-gather*/
        SCpnt->host_scribble = (unsigned char *) scsi_malloc(512);
        sgpnt = (struct scatterlist *) SCpnt->request_buffer;
        cptr = (struct aha1740_chain *) SCpnt->host_scribble; 
        if (cptr == NULL) panic("aha1740.c: unable to allocate DMA memory\n");
        for(i=0; i<SCpnt->use_sg; i++)
	{
	    cptr[i].dataptr = (long) sgpnt[i].address;
	    cptr[i].datalen = sgpnt[i].length;
        }
        ecb[ecbno].datalen = SCpnt->use_sg * sizeof(struct aha1740_chain);
        ecb[ecbno].dataptr = (long) cptr;
#ifdef DEBUG
        printk("cptr %x: ",cptr);
        ptr = (unsigned char *) cptr;
        for(i=0;i<24;i++) printk("%02x ", ptr[i]);
#endif
    }
    else
    {
        SCpnt->host_scribble = NULL;
        ecb[ecbno].datalen = bufflen;
        ecb[ecbno].dataptr = (long) buff;
    }
    ecb[ecbno].lun = SCpnt->lun;
    ecb[ecbno].ses = 1;	/* Suppress underrun errors */
    ecb[ecbno].dir= direction;
    ecb[ecbno].ars=1;  /* Yes, get the sense on an error */
    ecb[ecbno].senselen = 12;
    ecb[ecbno].senseptr = (long) ecb[ecbno].sense;
    ecb[ecbno].statusptr = (long) ecb[ecbno].status;
    ecb[ecbno].done = done;
    ecb[ecbno].SCpnt = SCpnt;
#ifdef DEBUG
    {
	int i;
        printk("aha1740_command: sending.. ");
        for (i = 0; i < sizeof(ecb[ecbno])-10; i++)
            printk("%02x ", ((unchar *)&ecb[ecbno])[i]);
    }
    printk("\n");
#endif
    if (done)
    { /*  You may question the code below, which contains potentially
	  non-terminating while loops with interrupts disabled.  So did
	  I when I wrote it, but the Adaptec Spec says the card is so fast,
	  that this problem virtually never occurs so I've kept it.  We
          do printk a warning first, so that you'll know if it happens.
	  In practive the only time we've seen this message is when some-
	  thing else is in the driver was broken, like _makecode(), or
	  when a scsi device hung the scsi bus.  Even under these conditions,
	  The loop actually only cycled < 3 times (we instrumented it). */
        ulong adrs;

	DEB(printk("aha1740[%d] critical section\n",ecbno));
	cli();
	if ( ! (inb(G2STAT) & G2STAT_MBXOUT) )
	{
	    printk("aha1740[%d]_mbxout wait!\n",ecbno);
	    cli(); /* printk may have done a sti()! */
	}
	while ( ! (inb(G2STAT) & G2STAT_MBXOUT) );	/* Oh Well. */
	adrs = (ulong) &(ecb[ecbno]);			/* Spit the command */
	outb((char) (adrs&0xff), MBOXOUT0);		/* out, note this set */
	outb((char) ((adrs>>8)&0xff), MBOXOUT1);	/* of outb's must be */
	outb((char) ((adrs>>16)&0xff), MBOXOUT2);	/* atomic */
	outb((char) ((adrs>>24)&0xff), MBOXOUT3);
	if ( inb(G2STAT) & G2STAT_BUSY )
	{
	    printk("aha1740[%d]_attn wait!\n",ecbno);
	    cli();
	}
	while ( inb(G2STAT) & G2STAT_BUSY );		/* And Again! */
	outb(ATTN_START | (target & 7), ATTN);	/* Start it up */
	sti();
	DEB(printk("aha1740[%d] request queued.\n",ecbno));
    }
    else
      printk("aha1740_queuecommand: done can't be NULL\n");
    
    return 0;
}

static volatile int internal_done_flag = 0;
static volatile int internal_done_errcode = 0;

static void internal_done(Scsi_Cmnd * SCpnt)
{
    internal_done_errcode = SCpnt->result;
    ++internal_done_flag;
}

int aha1740_command(Scsi_Cmnd * SCpnt)
{
    aha1740_queuecommand(SCpnt, internal_done);

    while (!internal_done_flag);
    internal_done_flag = 0;
    return internal_done_errcode;
}

/* Query the board for its irq_level.  Nothing else matters
   in enhanced mode on an EISA bus. */

void aha1740_getconfig(void)
{
  static int intab[] = { 9,10,11,12,0,14,15,0 };

  irq_level = intab [ inb(INTDEF)&0x7 ];
}

int aha1740_detect(int hostnum)
{
    memset(&ecb, 0, sizeof(struct ecb));
    DEB(printk("aha1740_detect: \n"));
    
    for ( slot=MINEISA; slot <= MAXEISA; slot++ )
    {
	base = SLOTBASE(slot);

	/* The ioports for eisa boards are generally beyond that used in the
	   check,snarf_region code, but this may change at some point, so we
	   go through the motions. */

	if(check_region(base, 0x5c)) continue;  /* See if in use */
	if ( aha1740_test_port())  break;
    }
    if ( slot > MAXEISA )
	return 0;

    aha1740_getconfig();

    if ( (inb(G2STAT) & (G2STAT_MBXOUT | G2STAT_BUSY) ) != G2STAT_MBXOUT )
    {	/* If the card isn't ready, hard reset it */
        outb(G2CNTRL_HRST,G2CNTRL);
        outb(0,G2CNTRL);    
    }

    printk("Configuring Adaptec at IO:%x, IRQ %d\n",base,
	   irq_level);

    DEB(printk("aha1740_detect: enable interrupt channel %d\n", irq_level));

    if (request_irq(irq_level,aha1740_intr_handle))
    {
        printk("Unable to allocate IRQ for adaptec controller.\n");
        return 0;
    }
    snarf_region(base, 0x5c);  /* Reserve the space that we need to use */
    return 1;
}

/* Note:  They following two functions do not apply very well to the Adaptec,
which basically manages its own affairs quite well without our interference,
so I haven't put anything into them.  I can faintly imagine someone with a
*very* badly behaved SCSI target (perhaps an old tape?) wanting the abort(),
but it hasn't happened yet, and doing aborts brings the Adaptec to its
knees.  I cannot (at this moment in time) think of any reason to reset the
card once it's running.  So there. */

int aha1740_abort(Scsi_Cmnd * SCpnt, int i)
{
    DEB(printk("aha1740_abort called\n"));
    return 0;
}

/* We do not implement a reset function here, but the upper level code assumes
   that it will get some kind of response for the command in SCpnt.  We must
   oblige, or the command will hang the scsi system */

int aha1740_reset(Scsi_Cmnd * SCpnt)
{
    DEB(printk("aha1740_reset called\n"));
    if (SCpnt) SCpnt->flags |= NEEDS_JUMPSTART;
    return 0;
}

int aha1740_biosparam(int size, int dev, int* ip)
{
DEB(printk("aha1740_biosparam\n"));
  ip[0] = 64;
  ip[1] = 32;
  ip[2] = size >> 11;
/*  if (ip[2] >= 1024) ip[2] = 1024; */
  return 0;
}

/* Okay, you made it all the way through.  As of this writing, 3/31/93, I'm
brad@saturn.gaylord.com or brad@bradpc.gaylord.com.  I'll try to help as time
permits if you have any trouble with this driver.  Happy Linuxing! */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
26uuu另类欧美亚洲曰本| 美腿丝袜亚洲三区| 色综合天天综合网天天狠天天 | 国产精品一区二区视频| 国产欧美1区2区3区| 成人国产精品免费观看动漫| 国产精品卡一卡二卡三| 色综合中文字幕国产| 亚洲欧美日韩在线播放| 欧美在线免费观看视频| 麻豆91在线播放免费| 久久久精品天堂| 91色.com| 美脚の诱脚舐め脚责91| 国产女主播一区| 欧美天天综合网| 美洲天堂一区二卡三卡四卡视频| 国产日韩欧美精品一区| 91国产视频在线观看| 麻豆一区二区在线| 国产精品久久久久久久久久久免费看 | 婷婷国产v国产偷v亚洲高清| 日韩久久久久久| aaa亚洲精品一二三区| 日韩精品电影在线观看| 精品日产卡一卡二卡麻豆| 成人福利视频网站| 五月综合激情网| 精品国内片67194| 色天使久久综合网天天| 久久99国产乱子伦精品免费| 国产精品电影一区二区三区| 日韩欧美在线观看一区二区三区| 成人小视频免费观看| 奇米一区二区三区av| 一区二区欧美国产| 久久久精品免费观看| 欧美男生操女生| www.爱久久.com| 国产一区二区在线看| 婷婷久久综合九色综合伊人色| 国产精品久久久久婷婷| 欧美电影免费观看高清完整版在线 | 国产欧美一区二区精品久导航| 北条麻妃一区二区三区| 日韩av一区二区三区四区| 中文字幕一区二区在线观看| 日韩欧美资源站| 欧美午夜寂寞影院| 91欧美一区二区| 丁香激情综合国产| 极品尤物av久久免费看| 午夜日韩在线观看| 一区二区三区四区国产精品| 久久精品一区蜜桃臀影院| 日韩视频中午一区| 欧美一区二区三区在线视频| 欧美午夜理伦三级在线观看| 91麻豆文化传媒在线观看| 丁香激情综合国产| 国产成人在线观看| 国产一区二区三区av电影| 日本亚洲天堂网| 午夜精品视频一区| 午夜影院在线观看欧美| 亚洲制服丝袜av| 亚洲品质自拍视频网站| 中文字幕亚洲在| 日本一区二区不卡视频| 日本一区二区三区免费乱视频| 欧美大片在线观看| 日韩欧美123| 精品国产伦一区二区三区观看方式 | 亚洲一二三区在线观看| 亚洲精品午夜久久久| 一区二区三区精品在线| 一区二区三区欧美激情| 亚洲九九爱视频| 亚洲一区二区三区小说| 亚洲成人自拍一区| 日本午夜一区二区| 国产一区二区三区精品欧美日韩一区二区三区 | 亚洲日本韩国一区| 成人欧美一区二区三区| 亚洲视频一区在线| 亚洲综合一二三区| 性感美女久久精品| 国产自产2019最新不卡| 国产精品99久| 91成人国产精品| 欧美精选午夜久久久乱码6080| 欧美一三区三区四区免费在线看 | 91女厕偷拍女厕偷拍高清| 97国产精品videossex| 欧美伊人久久大香线蕉综合69| 欧美日韩成人在线| 欧美不卡一区二区| 国产精品嫩草99a| 亚洲一区二区三区四区的| 免费三级欧美电影| 国产成人综合在线观看| 91麻豆精品一区二区三区| 欧美日韩亚洲国产综合| 欧美不卡一二三| 亚洲欧美偷拍另类a∨色屁股| 午夜精品久久久久久久久久| 国产一区二区三区在线观看免费 | 欧美日韩极品在线观看一区| 日韩免费看网站| 亚洲人成在线播放网站岛国 | 日韩视频永久免费| 18欧美亚洲精品| 青草av.久久免费一区| 成人爱爱电影网址| 欧美日本一区二区三区| 国产亚洲精品中文字幕| 亚洲一区在线播放| 丁香啪啪综合成人亚洲小说 | 国产色一区二区| 性做久久久久久免费观看欧美| 国产一区日韩二区欧美三区| 欧洲中文字幕精品| 国产精品欧美精品| 麻豆国产精品一区二区三区| 99精品久久99久久久久| xvideos.蜜桃一区二区| 夜夜嗨av一区二区三区网页| 国产精品一区二区不卡| 欧美一级久久久| 亚洲一区二区不卡免费| 高清国产午夜精品久久久久久| 91精品久久久久久蜜臀| 亚洲另类色综合网站| 丁香五精品蜜臀久久久久99网站 | youjizz国产精品| 日韩欧美中文字幕一区| 一级女性全黄久久生活片免费| 成人黄色av电影| 久久九九影视网| 九一久久久久久| 日韩无一区二区| 日本欧美在线看| 欧美日韩不卡一区二区| 亚洲综合视频网| 一本久久精品一区二区| 国产精品天天看| 国产风韵犹存在线视精品| 欧美mv和日韩mv国产网站| 一区二区三区色| 国产在线精品视频| 日韩欧美国产一区在线观看| 亚洲国产一二三| 欧美亚洲一区三区| 中文字幕av一区 二区| 老司机精品视频一区二区三区| 精品婷婷伊人一区三区三| 亚洲欧美偷拍卡通变态| 99久久精品国产麻豆演员表| 欧美激情在线观看视频免费| 国产剧情一区二区三区| 久久久噜噜噜久久中文字幕色伊伊| 免费在线观看成人| 精品久久久久99| 国产精品 欧美精品| 国产欧美一区二区精品久导航 | 日韩一区二区三区在线观看| 亚洲chinese男男1069| 欧美精品日日鲁夜夜添| 天天操天天综合网| 欧美一区二区三区播放老司机| 日韩成人伦理电影在线观看| 欧美国产综合一区二区| 男女男精品网站| 日韩视频在线一区二区| 精品在线观看免费| 久久久久久久综合狠狠综合| 国产不卡免费视频| 国产精品精品国产色婷婷| 91网站在线观看视频| 亚洲自拍与偷拍| 6080午夜不卡| 精品一区二区三区影院在线午夜| 久久品道一品道久久精品| 成人晚上爱看视频| 亚洲视频图片小说| 欧美美女网站色| 国产呦萝稀缺另类资源| 国产精品国产精品国产专区不片| 色综合 综合色| 天堂一区二区在线免费观看| 欧美www视频| 99精品视频免费在线观看| 视频在线观看91| 国产欧美精品一区二区色综合 | 中文字幕一区二区5566日韩| 在线观看91精品国产入口| 免费在线观看一区| 国产精品成人免费在线| 欧美精品在线一区二区三区| 国产一区二区三区四|