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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? amd74xx.c

?? ep9315平臺下硬盤驅(qū)動的源碼
?? C
字號:
/* * Version 2.10 * * AMD 755/756/766/8111 and nVidia nForce IDE driver for Linux. * * Copyright (c) 2000-2002 Vojtech Pavlik * * Based on the work of: *      Andre Hedrick *//* * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 as published by * the Free Software Foundation. */#include <linux/config.h>#include <linux/module.h>#include <linux/kernel.h>#include <linux/ioport.h>#include <linux/blkdev.h>#include <linux/pci.h>#include <linux/init.h>#include <linux/ide.h>#include <asm/io.h>#include "ide-timing.h"#include "amd74xx.h"#define AMD_IDE_ENABLE		(0x00 + amd_config->base)#define AMD_IDE_CONFIG		(0x01 + amd_config->base)#define AMD_CABLE_DETECT	(0x02 + amd_config->base)#define AMD_DRIVE_TIMING	(0x08 + amd_config->base)#define AMD_8BIT_TIMING		(0x0e + amd_config->base)#define AMD_ADDRESS_SETUP	(0x0c + amd_config->base)#define AMD_UDMA_TIMING		(0x10 + amd_config->base)#define AMD_UDMA		0x07#define AMD_UDMA_33		0x01#define AMD_UDMA_66		0x02#define AMD_UDMA_100		0x03#define AMD_CHECK_SWDMA		0x08#define AMD_BAD_SWDMA		0x10#define AMD_BAD_FIFO		0x20/* * AMD SouthBridge chips. */static struct amd_ide_chip {	unsigned short id;	unsigned char rev;	unsigned long base;	unsigned char flags;} amd_ide_chips[] = {	{ PCI_DEVICE_ID_AMD_COBRA_7401, 0x00, 0x40, AMD_UDMA_33 | AMD_BAD_SWDMA },	/* AMD-755 Cobra */	{ PCI_DEVICE_ID_AMD_VIPER_7409, 0x00, 0x40, AMD_UDMA_66 | AMD_CHECK_SWDMA },	/* AMD-756 Viper */	{ PCI_DEVICE_ID_AMD_VIPER_7411, 0x00, 0x40, AMD_UDMA_100 | AMD_BAD_FIFO },	/* AMD-766 Viper */	{ PCI_DEVICE_ID_AMD_OPUS_7441, 0x00, 0x40, AMD_UDMA_100 },			/* AMD-768 Opus */	{ PCI_DEVICE_ID_AMD_8111_IDE,  0x00, 0x40, AMD_UDMA_100 },			/* AMD-8111 */        { PCI_DEVICE_ID_NVIDIA_NFORCE_IDE, 0x00, 0x50, AMD_UDMA_100 },                  /* nVidia nForce */        { PCI_DEVICE_ID_NVIDIA_NFORCE2_IDE, 0x00, 0x50, AMD_UDMA_100 },                  /* nVidia nForce */	{ 0 }};static struct amd_ide_chip *amd_config;static unsigned char amd_enabled;static unsigned int amd_80w;static unsigned int amd_clock;static unsigned char amd_cyc2udma[] = { 6, 6, 5, 4, 0, 1, 1, 2, 2, 3, 3 };static unsigned char amd_udma2cyc[] = { 4, 6, 8, 10, 3, 2, 1, 1 };static char *amd_dma[] = { "MWDMA16", "UDMA33", "UDMA66", "UDMA100" };/* * AMD /proc entry. */#ifdef CONFIG_PROC_FS#include <linux/stat.h>#include <linux/proc_fs.h>static unsigned long amd_base;static struct pci_dev *bmide_dev;extern int (*amd74xx_display_info)(char *, char **, off_t, int); /* ide-proc.c */#define amd_print(format, arg...) p += sprintf(p, format "\n" , ## arg)#define amd_print_drive(name, format, arg...)\	p += sprintf(p, name); for (i = 0; i < 4; i++) p += sprintf(p, format, ## arg); p += sprintf(p, "\n");static int amd74xx_get_info(char *buffer, char **addr, off_t offset, int count){	int speed[4], cycle[4], setup[4], active[4], recover[4], den[4],		 uen[4], udma[4], active8b[4], recover8b[4];	struct pci_dev *dev = bmide_dev;	unsigned int v, u, i;	unsigned short c, w;	unsigned char t;	char *p = buffer;	int len;	amd_print("----------AMD BusMastering IDE Configuration----------------");	amd_print("Driver Version:                     2.10");	amd_print("South Bridge:                       %s", bmide_dev->name);	pci_read_config_byte(dev, PCI_REVISION_ID, &t);	amd_print("Revision:                           IDE %#x", t);	amd_print("Highest DMA rate:                   %s", amd_dma[amd_config->flags & AMD_UDMA]);	amd_print("BM-DMA base:                        %#lx", amd_base);	amd_print("PCI clock:                          %d.%dMHz", amd_clock / 1000, amd_clock / 100 % 10);		amd_print("-----------------------Primary IDE-------Secondary IDE------");	pci_read_config_byte(dev, AMD_IDE_CONFIG, &t);	amd_print("Prefetch Buffer:       %10s%20s", (t & 0x80) ? "yes" : "no", (t & 0x20) ? "yes" : "no");	amd_print("Post Write Buffer:     %10s%20s", (t & 0x40) ? "yes" : "no", (t & 0x10) ? "yes" : "no");	pci_read_config_byte(dev, AMD_IDE_ENABLE, &t);	amd_print("Enabled:               %10s%20s", (t & 0x02) ? "yes" : "no", (t & 0x01) ? "yes" : "no");	c = inb(amd_base + 0x02) | (inb(amd_base + 0x0a) << 8);	amd_print("Simplex only:          %10s%20s", (c & 0x80) ? "yes" : "no", (c & 0x8000) ? "yes" : "no");	amd_print("Cable Type:            %10s%20s", (amd_80w & 1) ? "80w" : "40w", (amd_80w & 2) ? "80w" : "40w");	if (!amd_clock)                return p - buffer;	amd_print("-------------------drive0----drive1----drive2----drive3-----");	pci_read_config_byte(dev, AMD_ADDRESS_SETUP, &t);	pci_read_config_dword(dev, AMD_DRIVE_TIMING, &v);	pci_read_config_word(dev, AMD_8BIT_TIMING, &w);	pci_read_config_dword(dev, AMD_UDMA_TIMING, &u);	for (i = 0; i < 4; i++) {		setup[i]     = ((t >> ((3 - i) << 1)) & 0x3) + 1;		recover8b[i] = ((w >> ((1 - (i >> 1)) << 3)) & 0xf) + 1;		active8b[i]  = ((w >> (((1 - (i >> 1)) << 3) + 4)) & 0xf) + 1;		active[i]    = ((v >> (((3 - i) << 3) + 4)) & 0xf) + 1;		recover[i]   = ((v >> ((3 - i) << 3)) & 0xf) + 1;		udma[i] = amd_udma2cyc[((u >> ((3 - i) << 3)) & 0x7)];		uen[i]  = ((u >> ((3 - i) << 3)) & 0x40) ? 1 : 0;		den[i]  = (c & ((i & 1) ? 0x40 : 0x20) << ((i & 2) << 2));		if (den[i] && uen[i] && udma[i] == 1) {			speed[i] = amd_clock * 3;			cycle[i] = 666666 / amd_clock;			continue;		}		speed[i] = 4 * amd_clock / ((den[i] && uen[i]) ? udma[i] : (active[i] + recover[i]) * 2);		cycle[i] = 1000000 * ((den[i] && uen[i]) ? udma[i] : (active[i] + recover[i]) * 2) / amd_clock / 2;	}	amd_print_drive("Transfer Mode: ", "%10s", den[i] ? (uen[i] ? "UDMA" : "DMA") : "PIO");	amd_print_drive("Address Setup: ", "%8dns", 1000000 * setup[i] / amd_clock);	amd_print_drive("Cmd Active:    ", "%8dns", 1000000 * active8b[i] / amd_clock);	amd_print_drive("Cmd Recovery:  ", "%8dns", 1000000 * recover8b[i] / amd_clock);	amd_print_drive("Data Active:   ", "%8dns", 1000000 * active[i] / amd_clock);	amd_print_drive("Data Recovery: ", "%8dns", 1000000 * recover[i] / amd_clock);	amd_print_drive("Cycle Time:    ", "%8dns", cycle[i]);	amd_print_drive("Transfer Rate: ", "%4d.%dMB/s", speed[i] / 1000, speed[i] / 100 % 10);	/* hoping p - buffer is less than 4K... */	len = (p - buffer) - offset;	*addr = buffer + offset;		return len > count ? count : len;}#endif/* * amd_set_speed() writes timing values to the chipset registers */static void amd_set_speed(struct pci_dev *dev, unsigned char dn, struct ide_timing *timing){	unsigned char t;	pci_read_config_byte(dev, AMD_ADDRESS_SETUP, &t);	t = (t & ~(3 << ((3 - dn) << 1))) | ((FIT(timing->setup, 1, 4) - 1) << ((3 - dn) << 1));	pci_write_config_byte(dev, AMD_ADDRESS_SETUP, t);	pci_write_config_byte(dev, AMD_8BIT_TIMING + (1 - (dn >> 1)),		((FIT(timing->act8b, 1, 16) - 1) << 4) | (FIT(timing->rec8b, 1, 16) - 1));	pci_write_config_byte(dev, AMD_DRIVE_TIMING + (3 - dn),		((FIT(timing->active, 1, 16) - 1) << 4) | (FIT(timing->recover, 1, 16) - 1));	switch (amd_config->flags & AMD_UDMA) {		case AMD_UDMA_33:  t = timing->udma ? (0xc0 | (FIT(timing->udma, 2, 5) - 2)) : 0x03; break;		case AMD_UDMA_66:  t = timing->udma ? (0xc0 | amd_cyc2udma[FIT(timing->udma, 2, 10)]) : 0x03; break;		case AMD_UDMA_100: t = timing->udma ? (0xc0 | amd_cyc2udma[FIT(timing->udma, 1, 10)]) : 0x03; break;		default: return;	}	pci_write_config_byte(dev, AMD_UDMA_TIMING + (3 - dn), t);}/* * amd_set_drive() computes timing values configures the drive and * the chipset to a desired transfer mode. It also can be called * by upper layers. */static int amd_set_drive(ide_drive_t *drive, u8 speed){	ide_drive_t *peer = HWIF(drive)->drives + (~drive->dn & 1);	struct ide_timing t, p;	int T, UT;	if (speed != XFER_PIO_SLOW && speed != drive->current_speed)		if (ide_config_drive_speed(drive, speed))			printk(KERN_WARNING "ide%d: Drive %d didn't accept speed setting. Oh, well.\n",				drive->dn >> 1, drive->dn & 1);	T = 1000000000 / amd_clock;	UT = T / min_t(int, max_t(int, amd_config->flags & AMD_UDMA, 1), 2);	ide_timing_compute(drive, speed, &t, T, UT);	if (peer->present) {		ide_timing_compute(peer, peer->current_speed, &p, T, UT);		ide_timing_merge(&p, &t, &t, IDE_TIMING_8BIT);	}	if (speed == XFER_UDMA_5 && amd_clock <= 33333) t.udma = 1;	amd_set_speed(HWIF(drive)->pci_dev, drive->dn, &t);	if (!drive->init_speed)			drive->init_speed = speed;	drive->current_speed = speed;	return 0;}/* * amd74xx_tune_drive() is a callback from upper layers for * PIO-only tuning. */static void amd74xx_tune_drive(ide_drive_t *drive, u8 pio){	if (!((amd_enabled >> HWIF(drive)->channel) & 1))		return;	if (pio == 255) {		amd_set_drive(drive, ide_find_best_mode(drive, XFER_PIO | XFER_EPIO));		return;	}	amd_set_drive(drive, XFER_PIO_0 + min_t(byte, pio, 5));}/* * amd74xx_dmaproc() is a callback from upper layers that can do * a lot, but we use it for DMA/PIO tuning only, delegating everything * else to the default ide_dmaproc(). */static int amd74xx_ide_dma_check(ide_drive_t *drive){	int w80 = HWIF(drive)->udma_four;	u8 speed = ide_find_best_mode(drive,		XFER_PIO | XFER_EPIO | XFER_MWDMA | XFER_UDMA |		((amd_config->flags & AMD_BAD_SWDMA) ? 0 : XFER_SWDMA) |		(w80 && (amd_config->flags & AMD_UDMA) >= AMD_UDMA_66 ? XFER_UDMA_66 : 0) |		(w80 && (amd_config->flags & AMD_UDMA) >= AMD_UDMA_100 ? XFER_UDMA_100 : 0));	amd_set_drive(drive, speed);	if (drive->autodma && (speed & XFER_MODE) != XFER_PIO)		return HWIF(drive)->ide_dma_on(drive);	return HWIF(drive)->ide_dma_off_quietly(drive);}/* * The initialization callback. Here we determine the IDE chip type * and initialize its drive independent registers. */static unsigned int __init init_chipset_amd74xx(struct pci_dev *dev, const char *name){	unsigned char t;	unsigned int u;	int i;/* * Check for bad SWDMA. */	if (amd_config->flags & AMD_CHECK_SWDMA) {		pci_read_config_byte(dev, PCI_REVISION_ID, &t);		if (t <= 7)			amd_config->flags |= AMD_BAD_SWDMA;	}/* * Check 80-wire cable presence. */	switch (amd_config->flags & AMD_UDMA) {		case AMD_UDMA_100:			pci_read_config_byte(dev, AMD_CABLE_DETECT, &t);			pci_read_config_dword(dev, AMD_UDMA_TIMING, &u);			amd_80w = ((t & 0x3) ? 1 : 0) | ((t & 0xc) ? 2 : 0);			for (i = 24; i >= 0; i -= 8)				if (((u >> i) & 4) && !(amd_80w & (1 << (1 - (i >> 4))))) {					printk(KERN_WARNING "AMD_IDE: Bios didn't set cable bits corectly. Enabling workaround.\n");					amd_80w |= (1 << (1 - (i >> 4)));				}			break;		case AMD_UDMA_66:			pci_read_config_dword(dev, AMD_UDMA_TIMING, &u);			for (i = 24; i >= 0; i -= 8)				if ((u >> i) & 4)					amd_80w |= (1 << (1 - (i >> 4)));			break;	}	pci_read_config_dword(dev, AMD_IDE_ENABLE, &u);	amd_enabled = ((u & 1) ? 2 : 0) | ((u & 2) ? 1 : 0);/* * Take care of prefetch & postwrite. */	pci_read_config_byte(dev, AMD_IDE_CONFIG, &t);	pci_write_config_byte(dev, AMD_IDE_CONFIG,		(amd_config->flags & AMD_BAD_FIFO) ? (t & 0x0f) : (t | 0xf0));/* * Determine the system bus clock. */	amd_clock = system_bus_clock() * 1000;	switch (amd_clock) {		case 33000: amd_clock = 33333; break;		case 37000: amd_clock = 37500; break;		case 41000: amd_clock = 41666; break;	}	if (amd_clock < 20000 || amd_clock > 50000) {		printk(KERN_WARNING "AMD_IDE: User given PCI clock speed impossible (%d), using 33 MHz instead.\n", amd_clock);		printk(KERN_WARNING "AMD_IDE: Use ide0=ata66 if you want to assume 80-wire cable\n");		amd_clock = 33333;	}/* * Print the boot message. */	pci_read_config_byte(dev, PCI_REVISION_ID, &t);	printk(KERN_INFO "AMD_IDE: %s (rev %02x) %s controller on pci%s\n",		dev->name, t, amd_dma[amd_config->flags & AMD_UDMA], dev->slot_name);/* * Register /proc/ide/amd74xx entry */#if defined(DISPLAY_AMD_TIMINGS) && defined(CONFIG_PROC_FS)        if (!amd74xx_proc) {                amd_base = pci_resource_start(dev, 4);                bmide_dev = dev;                ide_pci_register_host_proc(&amd74xx_procs[0]);                amd74xx_proc = 1;        }#endif /* DISPLAY_AMD_TIMINGS && CONFIG_PROC_FS */	return 0;}static unsigned int __init ata66_amd74xx(ide_hwif_t *hwif){	return ((amd_enabled & amd_80w) >> hwif->channel) & 1;}static void __init init_hwif_amd74xx(ide_hwif_t *hwif){	int i;	hwif->autodma = 0;	hwif->tuneproc = &amd74xx_tune_drive;	hwif->speedproc = &amd_set_drive;	for (i = 0; i < 2; i++) {		hwif->drives[i].io_32bit = 1;		hwif->drives[i].unmask = 1;		hwif->drives[i].autotune = 1;		hwif->drives[i].dn = hwif->channel * 2 + i;	}	if (!hwif->dma_base)		return;        hwif->atapi_dma = 1;        hwif->ultra_mask = 0x7f;        hwif->mwdma_mask = 0x07;        hwif->swdma_mask = 0x07;        if (!(hwif->udma_four))                hwif->udma_four = ((amd_enabled & amd_80w) >> hwif->channel) & 1;        hwif->ide_dma_check = &amd74xx_ide_dma_check;        if (!noautodma)                hwif->autodma = 1;        hwif->drives[0].autodma = hwif->autodma;        hwif->drives[1].autodma = hwif->autodma;}/* * We allow the BM-DMA driver only work on enabled interfaces. */static void __init init_dma_amd74xx(ide_hwif_t *hwif, unsigned long dmabase){	if ((amd_enabled >> hwif->channel) & 1)		ide_setup_dma(hwif, dmabase, 8);}extern void ide_setup_pci_device(struct pci_dev *, ide_pci_device_t *);static int __devinit amd74xx_probe(struct pci_dev *dev, const struct pci_device_id *id){	ide_pci_device_t *d = amd74xx_chipsets + id->driver_data;	amd_config = amd_ide_chips + id->driver_data;	if (dev->device != d->device) BUG();	if (dev->device != amd_config->id) BUG();	ide_setup_pci_device(dev, d);	MOD_INC_USE_COUNT;	return 0;}static struct pci_device_id amd74xx_pci_tbl[] __devinitdata = {	{ PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_COBRA_7401,	PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},	{ PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_VIPER_7409,	PCI_ANY_ID, PCI_ANY_ID, 0, 0, 1},	{ PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_VIPER_7411,	PCI_ANY_ID, PCI_ANY_ID, 0, 0, 2},	{ PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_OPUS_7441,	PCI_ANY_ID, PCI_ANY_ID, 0, 0, 3},	{ PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_8111_IDE, 	PCI_ANY_ID, PCI_ANY_ID, 0, 0, 4},	{ PCI_VENDOR_ID_NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE_IDE, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 5},	{ PCI_VENDOR_ID_NVIDIA, PCI_DEVICE_ID_NVIDIA_NFORCE2_IDE, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 6},	{ 0, },};static struct pci_driver driver = {	.name		= "AMD IDE",	.id_table	= amd74xx_pci_tbl,	.probe		= amd74xx_probe,};static int amd74xx_ide_init(void){	return ide_pci_register_driver(&driver);}static void amd74xx_ide_exit(void){	ide_pci_unregister_driver(&driver);}module_init(amd74xx_ide_init);module_exit(amd74xx_ide_exit);MODULE_AUTHOR("Vojtech Pavlik");MODULE_DESCRIPTION("AMD PCI IDE driver");MODULE_LICENSE("GPL");EXPORT_NO_SYMBOLS;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91久久线看在观草草青青| 国产精品亚洲第一区在线暖暖韩国| 成人性生交大合| 国产婷婷色一区二区三区在线| 久久91精品久久久久久秒播| 欧美xxx久久| 国产一区高清在线| 国产清纯在线一区二区www| 成人综合在线网站| 国产精品久久久久久久久免费丝袜 | 欧美日韩一区三区| 性做久久久久久免费观看欧美| 91精品国产麻豆国产自产在线| 免费xxxx性欧美18vr| 久久久久久久综合日本| 成人性色生活片| 亚洲sss视频在线视频| 欧美精品一区二区久久婷婷| 成人国产精品视频| 天天亚洲美女在线视频| 精品福利二区三区| caoporen国产精品视频| 日精品一区二区三区| 精品成人佐山爱一区二区| 成人av在线资源| 亚洲第一会所有码转帖| 久久综合九色综合欧美亚洲| 成人免费看视频| 日韩精品电影在线观看| 中文一区二区完整视频在线观看| 欧美亚洲精品一区| 国产麻豆精品久久一二三| 亚洲自拍偷拍图区| 2020国产精品自拍| 欧美主播一区二区三区| 国产不卡视频一区二区三区| 天天色图综合网| 亚洲国产精品ⅴa在线观看| 欧美日韩精品三区| 成人免费三级在线| 日韩电影在线免费| 一区二区三区欧美激情| 国产亚洲欧美激情| 欧美一级在线观看| 欧洲精品视频在线观看| 国产精品自拍网站| 日韩精彩视频在线观看| 亚洲黄色性网站| 国产欧美精品区一区二区三区 | 高清不卡在线观看av| 五月婷婷激情综合网| 亚洲欧洲日韩av| 久久先锋影音av| 日韩一区二区免费视频| 欧美性受xxxx黑人xyx| 岛国精品在线播放| 国产剧情一区二区三区| 久久精工是国产品牌吗| 亚洲成人你懂的| 一区二区三区不卡在线观看| 中文字幕在线一区| 久久久久久久久岛国免费| 日韩限制级电影在线观看| 欧美日韩国产天堂| 在线免费观看一区| 色综合中文综合网| 91精品国产综合久久久久久久| 91免费小视频| 91日韩精品一区| 99久久免费国产| 成人免费视频一区| 丁香一区二区三区| 国产成人精品aa毛片| 激情偷乱视频一区二区三区| 男女视频一区二区| 日韩国产精品久久久久久亚洲| 亚洲一区在线播放| 亚洲h在线观看| 五月激情丁香一区二区三区| 亚洲第一久久影院| 日韩一区精品字幕| 日本不卡123| 久久精品99国产国产精| 国产在线精品一区二区不卡了 | 日韩欧美国产三级| 日韩视频一区二区三区在线播放| 91精品国产综合久久精品性色| 69久久99精品久久久久婷婷| 这里只有精品视频在线观看| 欧美大片一区二区| 国产日产欧美一区| 中文字幕一区二区三区不卡 | 制服丝袜日韩国产| 欧美一区二区网站| 精品福利一二区| 国产精品午夜在线| 一区二区三区四区视频精品免费| 亚洲制服丝袜一区| 秋霞国产午夜精品免费视频| 免费观看一级欧美片| 国产麻豆一精品一av一免费| 成人动漫视频在线| 欧美亚洲国产怡红院影院| 3d动漫精品啪啪1区2区免费| 欧美tickle裸体挠脚心vk| 欧美国产日韩精品免费观看| 一区二区三区在线不卡| 蜜臀av性久久久久蜜臀aⅴ| 国产一区二区精品久久91| 成人国产精品免费网站| 欧美性淫爽ww久久久久无| 精品免费视频一区二区| 中日韩免费视频中文字幕| 亚洲国产精品视频| 国产综合色产在线精品| 99久久精品国产一区二区三区| 欧美日韩精品欧美日韩精品一| 精品欧美久久久| 亚洲综合另类小说| 国产1区2区3区精品美女| 欧美唯美清纯偷拍| 国产亚洲成av人在线观看导航 | 91精品国产综合久久久蜜臀图片| 国产午夜一区二区三区| 亚洲一区二区中文在线| 韩国v欧美v亚洲v日本v| 91精彩视频在线观看| 久久精品视频一区| 五月天国产精品| jlzzjlzz国产精品久久| 日韩免费观看高清完整版在线观看| 国产精品私房写真福利视频| 轻轻草成人在线| 91美女蜜桃在线| 久久精品无码一区二区三区| 天堂在线一区二区| www.日韩av| 久久人人97超碰com| 日本欧美久久久久免费播放网| av高清不卡在线| 国产亚洲一区字幕| 美日韩一区二区| 欧美日韩国产一二三| 一区二区在线看| 99久久久国产精品| 国产精品麻豆久久久| 精品一区二区三区视频| 在线电影国产精品| 亚洲一区二区三区自拍| 色婷婷av一区二区三区之一色屋| 中文乱码免费一区二区| 国产精品香蕉一区二区三区| 欧美成人精品3d动漫h| 午夜国产精品一区| 日本道在线观看一区二区| 亚洲欧美一区二区在线观看| 国产精品一区一区三区| 久久久久久麻豆| 国产高清在线精品| 久久久亚洲精品一区二区三区| 美腿丝袜在线亚洲一区| 日韩精品一区二区在线观看| 日韩精品每日更新| 日韩一区二区不卡| 裸体歌舞表演一区二区| 91麻豆精品国产自产在线| 午夜私人影院久久久久| 欧美日韩国产精品自在自线| 亚洲123区在线观看| 欧美三级在线播放| 午夜影院在线观看欧美| 在线电影院国产精品| 热久久一区二区| 精品国产乱码91久久久久久网站| 麻豆精品一区二区| 久久嫩草精品久久久久| 成人午夜激情影院| 1000精品久久久久久久久| 91农村精品一区二区在线| 亚洲成人精品一区二区| 欧美日本在线看| 麻豆精品在线观看| 国产日韩视频一区二区三区| 成人h动漫精品| 亚洲三级理论片| 欧美乱妇15p| 美女视频黄 久久| 国产欧美日韩久久| 91香蕉视频污| 亚洲va韩国va欧美va精品 | 国产麻豆91精品| 欧美国产精品v| 日本高清视频一区二区| 美日韩黄色大片| 国产精品私人影院| 亚洲视频精选在线| 日本久久精品电影| 日本欧洲一区二区| 国产精品免费看片| 欧美久久婷婷综合色|