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

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

?? articias_pci.c

?? u-boot1.3.0的原碼,從配了網絡驅動和FLASH的驅動,并該用ESC竟如
?? C
字號:
/* * (C) Copyright 2002 * Hyperion Entertainment, Hans-JoergF@hyperion-entertainment.com * * See file CREDITS for list of people who contributed to this * project. * * 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; either version 2 of * the License, or (at your option) any later version. * * 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. * * 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 */#include <common.h>#include <pci.h>#include "memio.h"#include "articiaS.h"DECLARE_GLOBAL_DATA_PTR;#undef ARTICIA_PCI_DEBUG#ifdef  ARTICIA_PCI_DEBUG#define PRINTF(fmt,args...)     printf (fmt ,##args)#else#define PRINTF(fmt,args...)#endifstruct pci_controller articiaS_hose;long irq_alloc(long wanted);static pci_dev_t pci_hose_find_class(struct pci_controller *hose, int bus, short find_class, int index);static int articiaS_init_vga(void);static void pci_cfgfunc_dummy(struct pci_controller *host, pci_dev_t dev, struct pci_config_table *table);unsigned char pci_irq_alloc(void);extern void via_cfgfunc_via686(struct pci_controller * host, pci_dev_t dev, struct pci_config_table *table);extern void via_cfgfunc_ide_init(struct pci_controller *host, pci_dev_t dev, struct pci_config_table *table);extern void via_init_irq_routing(uint8 []);extern void via_init_afterscan(void);#define cfgfunc_via686      1#define cfgfunc_dummy  2#define cfgfunc_ide_init    3static struct pci_config_table config_table[] ={    {	0x1106, PCI_ANY_ID, PCI_CLASS_BRIDGE_ISA, PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID,	(void *)cfgfunc_via686, {0, 0, 0}    },    {	0x1106, PCI_ANY_ID, PCI_ANY_ID, 0,7,4,	(void *)cfgfunc_dummy, {0,0,0}    },    {	0x1106, 0x3068, PCI_ANY_ID, 0, 7, PCI_ANY_ID,	(void *)cfgfunc_dummy, {0,0,0}    },    {	0x1106, PCI_ANY_ID, PCI_ANY_ID, 0,7,1,	(void *)cfgfunc_ide_init, {0,0,0}    },    {	0,    }};void pci_cfgfunc_dummy(struct pci_controller *host, pci_dev_t dev, struct pci_config_table *table){}unsigned long irq_penalties[16] ={    1000,    /* 0:timer */    1000,    /* 1:keyboard */    1000,    /* 2:cascade */    50,      /* 3:serial (COM2) */    50,      /* 4:serial (COM1) */    4,       /* 5:USB2 */    100,     /* 6:floppy */    3,       /* 7:parallel */    50,      /* 8:AC97/MC97 */    0,       /* 9: */    3,       /* 10:: */    0,       /* 11: */    3,       /* 12: USB1 */    0,       /* 13: */    100,     /* 14: ide0 */    100,     /* 15: ide1 */};/* * The following defines a hard-coded interrupt mapping for the * know devices on the board. * If a device isn't found here, assumed to be a device that's * plugged into a PCI or AGP slot * NOTE: This table is machine dependant. */struct pci_irq_fixup_table{    uint8   bus;             /* Bus number */    uint8   device;          /* Device number */    uint8   func;            /* Function number */    uint8   interrupt;       /* Interrupt to use (0xff to disable) */};struct pci_irq_fixup_table fixuptab [] ={    { 0, 0, 0, 0xff},        /* Articia S host bridge */    { 0, 1, 0, 0xff},        /* Articia S AGP bridge *//*    { 0, 6, 0, 0x05},        /###* 3COM ethernet */    { 0, 7, 0, 0xff},        /* VIA southbridge */    { 0, 7, 1, 0x0e},        /* IDE controller in legacy mode *//*    { 0, 7, 2, 0x05},        /###* First USB controller *//*    { 0, 7, 3, 0x0c},        /###* Second USB controller (shares interrupt with ethernet) */    { 0, 7, 4, 0xff},        /* ACPI Power Management *//*    { 0, 7, 5, 0x08},        /###* AC97 *//*    { 0, 7, 6, 0x08},        /###* MC97 */    { 0xff, 0xff, 0xff, 0xff}};/* * This table maps IRQ's to PCI interrupts */uint8 pci_intmap[4] = {0, 0, 0, 0};/* * Map PCI slots to interrupt routings * This table lists the device number assigned to a card inserted * into the slot, along with a permutation for the slot's IRQ routing. * NOTE: This table is machine dependant. */struct pci_slot_irq_routing{    uint8 bus;    uint8 device;    uint8 ints[4];};struct pci_slot_irq_routing amigaone_pci_routing[] ={    {0,  8,   {0, 1, 2, 3}},       /* Slot 1 (left of riser slot) */    {0,  9,   {1, 2, 3, 0}},       /* Slot 2 (middle slot) */    {0, 10,   {2, 3, 0, 1}},       /* Slot 3 (leftmost slot) */    {1,  0,   {1, 0, 2, 3}},       /* AGP slot (only IRQA and IRQB) */    {1,  1,   {1, 2, 3, 0}},       /* PCI slot on AGP bus */    {0,  6,   {3, 3, 3, 3}},       /* On board ethernet */    {0,  7,   {0, 1, 2, 3}},       /* Southbridge */    {0xff, 0, {0, 0, 0, 0}}};void articiaS_pci_irq_init(void){    char *s;    s = getenv("pci_irqa");    if (s)	pci_intmap[0] = simple_strtoul (s, NULL, 10);    else	pci_intmap[0] = pci_irq_alloc();    s = getenv("pci_irqb");    if (s)	pci_intmap[1] = simple_strtoul (s, NULL, 10);    else	pci_intmap[1] = pci_irq_alloc();    s = getenv("pci_irqc");    if (s)	pci_intmap[2] = simple_strtoul (s, NULL, 10);    else	pci_intmap[2] = pci_irq_alloc();    s = getenv("pci_irqd");    if (s)	pci_intmap[3] = simple_strtoul (s, NULL, 10);    else	pci_intmap[3] = pci_irq_alloc();}unsigned char pci_irq_alloc(void){    int i;    int interrupt = 10;    unsigned long min_penalty = 1000;    /* Search for the minimal penalty, favoring interrupts at the end */    for (i = 0; i < 16; i++)    {	if (irq_penalties[i] <= min_penalty)	{	    interrupt = i;	    min_penalty = irq_penalties[i];	}    }    PRINTF("pci_irq_alloc: Minimal penalty is %ld for %d\n", min_penalty, interrupt);    irq_penalties[interrupt]++;    return interrupt;}void articiaS_pci_fixup_irq(struct pci_controller *hose, pci_dev_t dev){    int8 bus, device, func, pin, line;    int i;    bus = PCI_BUS(dev);    device = PCI_DEV(dev);    func = PCI_FUNC(dev);    PRINTF("Fixup irq of %d:%d.%d\n", bus, device, func);    /* Search for the device in the table */    for (i = 0; fixuptab[i].bus != 0xff; i++)    {	if (bus == fixuptab[i].bus && device == fixuptab[i].device && func == fixuptab[i].func)	{	    /* If the device needs an interrupt, write it */	    if (fixuptab[i].interrupt != 0xff)	    {		PRINTF("Assigning IRQ %d (fixed)\n", fixuptab[i].interrupt);		pci_write_config_byte(dev, PCI_INTERRUPT_LINE, fixuptab[i].interrupt);	    }	    else	    {		/* Otherwise, see if it wants an interrupt, and disable it if needed */		pci_read_config_byte(dev, PCI_INTERRUPT_PIN, &pin);		if (pin)		{		    PRINTF("Disabling IRQ\n");		    pci_write_config_byte(dev, PCI_INTERRUPT_LINE, 0xff);		}	    }	    return;	}    }    /* If we get here, we have another PCI device in a slot... find the appropriate IRQ */    /* Find matching pin */    pci_read_config_byte(dev, PCI_INTERRUPT_PIN, &pin);    pin--;    /* Search for it's map */    for (i = 0; amigaone_pci_routing[i].bus != 0xff; i++)    {	if (bus == amigaone_pci_routing[i].bus && device == amigaone_pci_routing[i].device)	{	    line = pci_intmap[amigaone_pci_routing[i].ints[pin]];	    PRINTF("Assigning IRQ %d (pin %d)\n", line, pin);	    pci_write_config_byte(dev, PCI_INTERRUPT_LINE, line);	    return;	}    }    PRINTF("Unkonwn PCI device found\n");}void articiaS_pci_init (void){    int i;    char *s;    PRINTF("atriciaS_pci_init\n");    /* Why aren't these relocated?? */    for (i=0; config_table[i].config_device; i++)    {	switch((int)config_table[i].config_device)	{	case cfgfunc_via686:     config_table[i].config_device = via_cfgfunc_via686;      break;	case cfgfunc_dummy:      config_table[i].config_device = pci_cfgfunc_dummy;       break;	case cfgfunc_ide_init:   config_table[i].config_device = via_cfgfunc_ide_init;    break;	default: PRINTF("Error: Unknown constant\n");	}    }    articiaS_hose.first_busno = 0;    articiaS_hose.last_busno = 0xff;    articiaS_hose.config_table = config_table;    articiaS_hose.fixup_irq = articiaS_pci_fixup_irq;    articiaS_pci_irq_init();    /* System memory */    pci_set_region(articiaS_hose.regions + 0,		   ARTICIAS_SYS_BUS,		   ARTICIAS_SYS_PHYS,		   ARTICIAS_SYS_MAXSIZE,		   PCI_REGION_MEM | PCI_REGION_MEMORY);    /* PCI memory space */    pci_set_region(articiaS_hose.regions + 1,		   ARTICIAS_PCI_BUS,		   ARTICIAS_PCI_PHYS,		   ARTICIAS_PCI_MAXSIZE,		   PCI_REGION_MEM);    /* PCI io space */    pci_set_region(articiaS_hose.regions + 2,		   ARTICIAS_PCIIO_BUS,		   ARTICIAS_PCIIO_PHYS,		   ARTICIAS_PCIIO_MAXSIZE,		   PCI_REGION_IO);    /* PCI/ISA io space */    pci_set_region(articiaS_hose.regions + 3,		   ARTICIAS_ISAIO_BUS,		   ARTICIAS_ISAIO_PHYS,		   ARTICIAS_ISAIO_MAXSIZE,		   PCI_REGION_IO);    articiaS_hose.region_count = 4;    pci_setup_indirect(&articiaS_hose, ARTICIAS_PCI_CFGADDR, ARTICIAS_PCI_CFGDATA);    PRINTF("Registering articia hose...\n");    pci_register_hose(&articiaS_hose);    PRINTF("Enabling AGP...\n");    pci_write_config_byte(PCI_BDF(0,0,0), 0x58, 0x01);    PRINTF("Scanning bus...\n");    articiaS_hose.last_busno = pci_hose_scan(&articiaS_hose);    via_init_irq_routing(pci_intmap);    PRINTF("After-Scan results:\n");    PRINTF("Bus range: %d - %d\n", articiaS_hose.first_busno , articiaS_hose.last_busno);    via_init_afterscan();    pci_write_config_byte(PCI_BDF(0,1,0), PCI_INTERRUPT_LINE, 0xFF);    s = getenv("as_irq");    if (s)    {	pci_write_config_byte(PCI_BDF(0,0,0), PCI_INTERRUPT_LINE, simple_strtoul (s, NULL, 10));    }    s = getenv("x86_run_bios");    if (!s || (s && strcmp(s, "on")==0))    {	if (articiaS_init_vga() == -1)	{	    /* If the VGA didn't init and we have stdout set to VGA, reset to serial *//*	    s = getenv("stdout"); *//*	    if (s && strcmp(s, "vga") == 0) *//*	    { *//*		setenv("stdout", "serial"); *//*	    } */	}    }    pci_write_config_byte(PCI_BDF(0,1,0), PCI_INTERRUPT_LINE, 0xFF);}pci_dev_t pci_hose_find_class(struct pci_controller *hose, int bus, short find_class, int index){    unsigned int sub_bus, found_multi=0;    unsigned short vendor, class;    unsigned char header_type;    pci_dev_t dev;    u8 c1, c2;    sub_bus = bus;    for (dev =  PCI_BDF(bus,0,0);	 dev <  PCI_BDF(bus,PCI_MAX_PCI_DEVICES-1,PCI_MAX_PCI_FUNCTIONS-1);	 dev += PCI_BDF(0,0,1))    {	if ( dev == PCI_BDF(hose->first_busno,0,0) )	    continue;	if (PCI_FUNC(dev) && !found_multi)	    continue;	pci_hose_read_config_byte(hose, dev, PCI_HEADER_TYPE, &header_type);	pci_hose_read_config_word(hose, dev, PCI_VENDOR_ID, &vendor);	if (vendor != 0xffff && vendor != 0x0000)	{	    if (!PCI_FUNC(dev))		found_multi = header_type & 0x80;	    pci_hose_read_config_byte(hose, dev, 0x0B, &c1);	    pci_hose_read_config_byte(hose, dev, 0x0A, &c2);	    class = c1<<8 | c2;	    /*printf("At %02x:%02x:%02x: class %x\n", */	    /*	   PCI_BUS(dev), PCI_DEV(dev), PCI_FUNC(dev), class); */	    if (class == find_class)	    {		if (index == 0)		    return dev;		else index--;	    }	}    }    return ~0;}/* * For a given bus number, find the bridge on this hose that provides this * bus number. The function scans for bridges and peeks config space offset * 0x19 (PCI_SECONDARY_BUS). */pci_dev_t pci_find_bridge_for_bus(struct pci_controller *hose, int busnr){    pci_dev_t dev;    int bus;    unsigned int found_multi=0;    unsigned char header_type;    unsigned short vendor;    unsigned char secondary_bus;    if (hose == NULL) hose = &articiaS_hose;    if (busnr < hose->first_busno || busnr > hose->last_busno) return PCI_ANY_ID; /* Not in range */    /*     * The bridge must be on a lower bus number     */    for (bus = hose->first_busno; bus < busnr; bus++)    {	for (dev =  PCI_BDF(bus,0,0);	     dev <  PCI_BDF(bus,PCI_MAX_PCI_DEVICES-1,PCI_MAX_PCI_FUNCTIONS-1);	     dev += PCI_BDF(0,0,1))	{	    if ( dev == PCI_BDF(hose->first_busno,0,0) )		continue;	    if (PCI_FUNC(dev) && !found_multi)		continue;	    pci_hose_read_config_byte(hose, dev, PCI_HEADER_TYPE, &header_type);	    pci_hose_read_config_word(hose, dev, PCI_VENDOR_ID, &vendor);	    if (vendor != 0xffff && vendor != 0x0000)	    {		if (!PCI_FUNC(dev))		    found_multi = header_type & 0x80;		if (header_type == 1) /* Bridge device header */		{		    pci_hose_read_config_byte(hose, dev, PCI_SECONDARY_BUS, &secondary_bus);		    if ((int)secondary_bus == busnr) return dev;		}	    }	}    }    return PCI_ANY_ID;}static short classes[] ={    PCI_CLASS_DISPLAY_VGA,    PCI_CLASS_DISPLAY_XGA,    PCI_CLASS_DISPLAY_3D,    PCI_CLASS_DISPLAY_OTHER,    ~0};extern int execute_bios(pci_dev_t gr_dev, void *);pci_dev_t video_dev;int articiaS_init_vga (void){    extern void shutdown_bios(void);    pci_dev_t dev = ~0;    int busnr = 0;    int classnr = 0;    video_dev = PCI_ANY_ID;    printf("VGA:   ");    PRINTF("Trying to initialize x86 VGA Card(s)\n");    while (dev == ~0)    {	PRINTF("Searching for class 0x%x on bus %d\n", classes[classnr], busnr);	/* Find the first of this class on this bus */	dev = pci_hose_find_class(&articiaS_hose, busnr, classes[classnr], 0);	if (dev != ~0)	{	    PRINTF("Found VGA Card at %02x:%02x:%02x\n", PCI_BUS(dev), PCI_DEV(dev), PCI_FUNC(dev));	    break;	}	busnr++;	if (busnr > articiaS_hose.last_busno)	{	    busnr = 0;	    classnr ++;	    if (classes[classnr] == ~0)	    {		printf("NOT PRESENT\n");		return -1;	    }	}    }    /*     * If we get here we have found the first graphics card.     * If the bus number is not 0, then it is probably behind a bridge, and the     * bridge needs to be told to forward VGA access.     */    if (PCI_BUS(dev) != 0)    {	pci_dev_t bridge;	PRINTF("Behind bridge, looking for bridge\n");	bridge = pci_find_bridge_for_bus(&articiaS_hose, PCI_BUS(dev));	if (dev != PCI_ANY_ID)	{	    unsigned char agp_control_0;	    PRINTF("Got the bridge at %02x:%02x:%02x\n",		   PCI_BUS(bridge), PCI_DEV(bridge), PCI_FUNC(bridge));	    pci_hose_read_config_byte(&articiaS_hose, bridge, 0x3E, &agp_control_0);	    agp_control_0 |= 0x18;	    pci_hose_write_config_byte(&articiaS_hose, bridge, 0x3E, agp_control_0);	    PRINTF("Configured for VGA forwarding\n");	}    }    /*     * Now try to run the bios     */    PRINTF("Trying to run bios now\n");    if (execute_bios(dev, gd->relocaddr))    {	printf("OK\n");	video_dev = dev;    }    else    {	printf("ERROR\n");    }    PRINTF("Done scanning.\n");    shutdown_bios();    if (dev == PCI_ANY_ID) return -1;    else return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲视频一区在线| 久久久久高清精品| 在线视频你懂得一区| 成人的网站免费观看| 成人开心网精品视频| eeuss鲁片一区二区三区在线观看| 国产精品99久久久久久久女警 | 国产成人综合在线观看| 奇米888四色在线精品| 男人的j进女人的j一区| 另类小说欧美激情| 国产成人超碰人人澡人人澡| 成人免费精品视频| 色狠狠av一区二区三区| 欧美精品一二三四| 久久久精品影视| 国产精品免费视频一区| 亚洲综合色自拍一区| 天天综合日日夜夜精品| 国产在线播放一区三区四| 成人在线视频一区二区| 91免费看视频| 日韩一区二区三区四区| 国产午夜精品一区二区三区嫩草 | 亚洲黄网站在线观看| 亚洲成在线观看| 国产一区二区三区综合| 99re这里只有精品视频首页| 欧美日本国产一区| 精品国产一区久久| 一区二区国产盗摄色噜噜| 秋霞电影网一区二区| 国产精品91一区二区| 91免费视频网| 久久久久久久性| 亚洲一区二区不卡免费| 国产高清亚洲一区| 欧美日本国产视频| 中文字幕在线不卡| 国精产品一区一区三区mba桃花| 成人av电影在线网| 日韩免费看的电影| 亚洲一区二区三区美女| 国产精品影视网| 欧美日韩一区二区三区在线| 亚洲精品一区二区在线观看| 亚洲精品中文在线影院| 国产福利91精品一区| 欧美日韩高清不卡| 亚洲日本在线a| 国产成人在线视频网址| 88在线观看91蜜桃国自产| 国产精品日韩精品欧美在线| 秋霞成人午夜伦在线观看| 色婷婷国产精品| 国产欧美中文在线| 久久99九九99精品| 欧美一区在线视频| 丝袜a∨在线一区二区三区不卡| 成人黄色综合网站| 国产欧美一区二区三区网站| 男男视频亚洲欧美| 日韩一二三区视频| 同产精品九九九| 在线看国产一区| 亚洲图片激情小说| 99国产精品99久久久久久| 国产亚洲女人久久久久毛片| 久久99精品国产91久久来源| 正在播放一区二区| 天天射综合影视| 69p69国产精品| 日韩电影在线免费| 日韩一区二区高清| 狠狠色2019综合网| 久久免费精品国产久精品久久久久| 免费久久精品视频| 日韩欧美色电影| 国产在线乱码一区二区三区| 欧美成人a视频| 狠狠色狠狠色综合| 国产蜜臀av在线一区二区三区| 韩国欧美一区二区| 国产日韩精品视频一区| 成人深夜福利app| 中文字幕一区二区不卡| 色综合久久中文字幕| 亚洲色图欧美激情| 欧美高清www午色夜在线视频| 爽好多水快深点欧美视频| 91精品国产91久久久久久最新毛片 | 97aⅴ精品视频一二三区| 亚洲私人影院在线观看| 欧美日韩午夜在线视频| 蜜臀av在线播放一区二区三区| 欧美一级国产精品| 国产91丝袜在线播放九色| 亚洲丝袜另类动漫二区| 欧美日韩亚洲综合一区二区三区| 日本亚洲视频在线| 国产亚洲精品aa午夜观看| 91天堂素人约啪| 亚洲成人1区2区| 久久综合色之久久综合| www..com久久爱| 亚洲va韩国va欧美va精品| 精品免费视频一区二区| 99天天综合性| 久久国产麻豆精品| 日韩毛片在线免费观看| 日韩欧美一级在线播放| 99久久婷婷国产综合精品| 日韩不卡一二三区| 中文字幕一区二区视频| 欧美一区二区在线视频| 成人午夜在线视频| 美腿丝袜亚洲一区| 亚洲黄一区二区三区| 久久色中文字幕| 欧美日韩国产一级二级| 波多野洁衣一区| 精品影院一区二区久久久| 亚洲美女精品一区| 久久久久亚洲蜜桃| 91 com成人网| 欧美色图天堂网| www.在线欧美| 国产精品白丝jk白祙喷水网站 | 这里只有精品免费| 99久久国产综合色|国产精品| 精品影院一区二区久久久| 一区二区三区电影在线播| 亚洲国产精品二十页| 精品福利一区二区三区免费视频| 在线日韩一区二区| 色综合久久综合网| 99re视频这里只有精品| 国产老肥熟一区二区三区| 日产精品久久久久久久性色| 亚洲精品视频免费看| 亚洲欧洲日韩av| 国产精品水嫩水嫩| 久久精品人人做人人爽人人| 精品欧美久久久| 精品国产乱码久久久久久牛牛| 欧美精品一级二级| 欧美日韩国产精品自在自线| 日本道精品一区二区三区| 色婷婷精品久久二区二区蜜臀av| 成人一区二区三区中文字幕| 国产精品99久久久| 国产98色在线|日韩| 国产91综合一区在线观看| 粉嫩av一区二区三区| 成人午夜视频福利| a亚洲天堂av| 91成人国产精品| 日本电影欧美片| 欧美视频三区在线播放| 欧美日韩在线一区二区| 欧美色精品在线视频| 欧美日韩国产高清一区二区三区| 欧美剧情电影在线观看完整版免费励志电影| 99免费精品在线| 欧美色图激情小说| 91精品免费在线观看| 久久综合九色综合97婷婷女人 | 久久综合色天天久久综合图片| 精品粉嫩aⅴ一区二区三区四区| 精品日韩在线观看| 中文一区一区三区高中清不卡| 亚洲少妇30p| 视频一区免费在线观看| 久久成人免费网站| 成人av高清在线| 欧美理论在线播放| 久久男人中文字幕资源站| 最新久久zyz资源站| 亚洲综合色在线| 久久精品国产精品亚洲精品| 丁香婷婷深情五月亚洲| 欧美亚洲一区三区| 久久综合中文字幕| 亚洲五码中文字幕| 国产91丝袜在线观看| 欧美综合一区二区三区| ww亚洲ww在线观看国产| 亚洲欧美偷拍另类a∨色屁股| 蜜乳av一区二区三区| 99久久精品免费看国产免费软件| 欧美美女激情18p| 日本一区二区三级电影在线观看 | **欧美大码日韩| 另类人妖一区二区av| 91丨porny丨在线| 欧美一三区三区四区免费在线看| 国产精品污网站| 精品一区二区三区久久| 在线欧美一区二区| 国产午夜精品一区二区三区视频|