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

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

?? ether79c970.c

?? 這是一個同樣來自貝爾實驗室的和UNIX有著淵源的操作系統, 其簡潔的設計和實現易于我們學習和理解
?? C
字號:
/* * AMD79C970 * PCnet-PCI Single-Chip Ethernet Controller for PCI Local Bus * To do: *	finish this rewrite */#include "u.h"#include "../port/lib.h"#include "mem.h"#include "dat.h"#include "fns.h"#include "io.h"#include "../port/error.h"#include "../port/netif.h"#include "etherif.h"enum {	Lognrdre	= 6,	Nrdre		= (1<<Lognrdre),/* receive descriptor ring entries */	Logntdre	= 4,	Ntdre		= (1<<Logntdre),/* transmit descriptor ring entries */	Rbsize		= ETHERMAXTU+4,	/* ring buffer size (+4 for CRC) */};enum {					/* DWIO I/O resource map */	Aprom		= 0x0000,	/* physical address */	Rdp		= 0x0010,	/* register data port */	Rap		= 0x0014,	/* register address port */	Sreset		= 0x0018,	/* software reset */	Bdp		= 0x001C,	/* bus configuration register data port */};enum {					/* CSR0 */	Init		= 0x0001,	/* begin initialisation */	Strt		= 0x0002,	/* enable chip */	Stop		= 0x0004,	/* disable chip */	Tdmd		= 0x0008,	/* transmit demand */	Txon		= 0x0010,	/* transmitter on */	Rxon		= 0x0020,	/* receiver on */	Iena		= 0x0040,	/* interrupt enable */	Intr		= 0x0080,	/* interrupt flag */	Idon		= 0x0100,	/* initialisation done */	Tint		= 0x0200,	/* transmit interrupt */	Rint		= 0x0400,	/* receive interrupt */	Merr		= 0x0800,	/* memory error */	Miss		= 0x1000,	/* missed frame */	Cerr		= 0x2000,	/* collision */	Babl		= 0x4000,	/* transmitter timeout */	Err		= 0x8000,	/* Babl|Cerr|Miss|Merr */};	enum {					/* CSR3 */	Bswp		= 0x0004,	/* byte swap */	Emba		= 0x0008,	/* enable modified back-off algorithm */	Dxmt2pd		= 0x0010,	/* disable transmit two part deferral */	Lappen		= 0x0020,	/* look-ahead packet processing enable */};enum {					/* CSR4 */	ApadXmt		= 0x0800,	/* auto pad transmit */};enum {					/* CSR15 */	Prom		= 0x8000,	/* promiscuous mode */};typedef struct Iblock Iblock;struct Iblock {			/* Initialisation Block */	ushort	mode;	uchar	rlen;			/* upper 4 bits */	uchar	tlen;			/* upper 4 bits */	uchar	padr[6];	uchar	res[2];	uchar	ladr[8];	ulong	rdra;	ulong	tdra;};typedef struct Dre Dre;struct Dre {			/* descriptor ring entry */	ulong	addr;	ulong	md1;			/* status|bcnt */	ulong	md2;			/* rcc|rpc|mcnt */	Block*	bp;};enum {					/* md1 */	Enp		= 0x01000000,	/* end of packet */	Stp		= 0x02000000,	/* start of packet */	RxBuff		= 0x04000000,	/* buffer error */	Def		= 0x04000000,	/* deferred */	Crc		= 0x08000000,	/* CRC error */	One		= 0x08000000,	/* one retry needed */	Oflo		= 0x10000000,	/* overflow error */	More		= 0x10000000,	/* more than one retry needed */	Fram		= 0x20000000,	/* framing error */	RxErr		= 0x40000000,	/* Fram|Oflo|Crc|RxBuff */	TxErr		= 0x40000000,	/* Uflo|Lcol|Lcar|Rtry */	Own		= 0x80000000,};enum {					/* md2 */	Rtry		= 0x04000000,	/* failed after repeated retries */	Lcar		= 0x08000000,	/* loss of carrier */	Lcol		= 0x10000000,	/* late collision */	Uflo		= 0x40000000,	/* underflow error */	TxBuff		= 0x80000000,	/* buffer error */};typedef struct Ctlr Ctlr;struct Ctlr {	Lock;	int	port;	Pcidev*	pcidev;	Ctlr*	next;	int	active;	int	init;			/* initialisation in progress */	Iblock	iblock;	Dre*	rdr;			/* receive descriptor ring */	int	rdrx;	Dre*	tdr;			/* transmit descriptor ring */	int	tdrh;			/* host index into tdr */	int	tdri;			/* interface index into tdr */	int	ntq;			/* descriptors active */	ulong	rxbuff;			/* receive statistics */	ulong	crc;	ulong	oflo;	ulong	fram;	ulong	rtry;			/* transmit statistics */	ulong	lcar;	ulong	lcol;	ulong	uflo;	ulong	txbuff;	ulong	merr;			/* bobf is such a whiner */	ulong	miss;	ulong	babl;	int	(*ior)(Ctlr*, int);	void	(*iow)(Ctlr*, int, int);};static Ctlr* ctlrhead;static Ctlr* ctlrtail;/* * The Rdp, Rap, Sreset, Bdp ports are 32-bit port offset in the enumeration above. * To get to 16-bit offsets, scale down with 0x10 staying the same. */static intio16r(Ctlr *c, int r){	if(r >= Rdp)		r = (r-Rdp)/2+Rdp;	return ins(c->port+r);}static voidio16w(Ctlr *c, int r, int v){	if(r >= Rdp)		r = (r-Rdp)/2+Rdp;	outs(c->port+r, v);}static intio32r(Ctlr *c, int r){	return inl(c->port+r);}static voidio32w(Ctlr *c, int r, int v){	outl(c->port+r, v);}static voidattach(Ether*){}static longifstat(Ether* ether, void* a, long n, ulong offset){	char *p;	int len;	Ctlr *ctlr;	ctlr = ether->ctlr;	ether->crcs = ctlr->crc;	ether->frames = ctlr->fram;	ether->buffs = ctlr->rxbuff+ctlr->txbuff;	ether->overflows = ctlr->oflo;	if(n == 0)		return 0;	p = malloc(READSTR);	len = snprint(p, READSTR, "Rxbuff: %ld\n", ctlr->rxbuff);	len += snprint(p+len, READSTR-len, "Crc: %ld\n", ctlr->crc);	len += snprint(p+len, READSTR-len, "Oflo: %ld\n", ctlr->oflo);	len += snprint(p+len, READSTR-len, "Fram: %ld\n", ctlr->fram);	len += snprint(p+len, READSTR-len, "Rtry: %ld\n", ctlr->rtry);	len += snprint(p+len, READSTR-len, "Lcar: %ld\n", ctlr->lcar);	len += snprint(p+len, READSTR-len, "Lcol: %ld\n", ctlr->lcol);	len += snprint(p+len, READSTR-len, "Uflo: %ld\n", ctlr->uflo);	len += snprint(p+len, READSTR-len, "Txbuff: %ld\n", ctlr->txbuff);	len += snprint(p+len, READSTR-len, "Merr: %ld\n", ctlr->merr);	len += snprint(p+len, READSTR-len, "Miss: %ld\n", ctlr->miss);	snprint(p+len, READSTR-len, "Babl: %ld\n", ctlr->babl);	n = readstr(offset, a, n, p);	free(p);	return n;}static voidringinit(Ctlr* ctlr){	Dre *dre;	/*	 * Initialise the receive and transmit buffer rings.	 * The ring entries must be aligned on 16-byte boundaries.	 *	 * This routine is protected by ctlr->init.	 */	if(ctlr->rdr == 0){		ctlr->rdr = xspanalloc(Nrdre*sizeof(Dre), 0x10, 0);		for(dre = ctlr->rdr; dre < &ctlr->rdr[Nrdre]; dre++){			dre->bp = iallocb(Rbsize);			if(dre->bp == nil)				panic("can't allocate ethernet receive ring\n");			dre->addr = PADDR(dre->bp->rp);			dre->md2 = 0;			dre->md1 = Own|(-Rbsize & 0xFFFF);		}	}	ctlr->rdrx = 0;	if(ctlr->tdr == 0)		ctlr->tdr = xspanalloc(Ntdre*sizeof(Dre), 0x10, 0);	memset(ctlr->tdr, 0, Ntdre*sizeof(Dre));	ctlr->tdrh = ctlr->tdri = 0;}static voidpromiscuous(void* arg, int on){	Ether *ether;	int x;	Ctlr *ctlr;	ether = arg;	ctlr = ether->ctlr;	/*	 * Put the chip into promiscuous mode. First must wait until	 * anyone transmitting is done, then stop the chip and put	 * it in promiscuous mode. Restarting is made harder by the chip	 * reloading the transmit and receive descriptor pointers with their	 * base addresses when Strt is set (unlike the older Lance chip),	 * so the rings must be re-initialised.	 */	ilock(ctlr);	if(ctlr->init){		iunlock(ctlr);		return;	}	ctlr->init = 1;	iunlock(ctlr);	while(ctlr->ntq)		;	ctlr->iow(ctlr, Rdp, Stop);	ctlr->iow(ctlr, Rap, 15);	x = ctlr->ior(ctlr, Rdp) & ~Prom;	if(on)		x |= Prom;	ctlr->iow(ctlr, Rdp, x);	ctlr->iow(ctlr, Rap, 0);	ringinit(ctlr);	ilock(ctlr);	ctlr->init = 0;	ctlr->iow(ctlr, Rdp, Iena|Strt);	iunlock(ctlr);}static voidmulticast(void* arg, uchar*, int){	promiscuous(arg, 1);}static voidtxstart(Ether* ether){	Ctlr *ctlr;	Block *bp;	Dre *dre;	ctlr = ether->ctlr;	if(ctlr->init)		return;	while(ctlr->ntq < (Ntdre-1)){		bp = qget(ether->oq);		if(bp == nil)			break;		/*		 * Give ownership of the descriptor to the chip,		 * increment the software ring descriptor pointer		 * and tell the chip to poll.		 * There's no need to pad to ETHERMINTU		 * here as ApadXmt is set in CSR4.		 */		dre = &ctlr->tdr[ctlr->tdrh];		dre->bp = bp;		dre->addr = PADDR(bp->rp);		dre->md2 = 0;		dre->md1 = Own|Stp|Enp|(-BLEN(bp) & 0xFFFF);		ctlr->ntq++;		ctlr->iow(ctlr, Rdp, Iena|Tdmd);		ctlr->tdrh = NEXT(ctlr->tdrh, Ntdre);	}}static voidtransmit(Ether* ether){	Ctlr *ctlr;	ctlr = ether->ctlr;	ilock(ctlr);	txstart(ether);	iunlock(ctlr);}static voidinterrupt(Ureg*, void* arg){	Ctlr *ctlr;	Ether *ether;	int csr0, len;	Dre *dre;	Block *bp;	ether = arg;	ctlr = ether->ctlr;	/*	 * Acknowledge all interrupts and whine about those that shouldn't	 * happen.	 */intrloop:	csr0 = ctlr->ior(ctlr, Rdp) & 0xFFFF;	ctlr->iow(ctlr, Rdp, Babl|Cerr|Miss|Merr|Rint|Tint|Iena);	if(csr0 & Merr)		ctlr->merr++;	if(csr0 & Miss)		ctlr->miss++;	if(csr0 & Babl)		ctlr->babl++;	//if(csr0 & (Babl|Miss|Merr))	//	print("#l%d: csr0 = 0x%uX\n", ether->ctlrno, csr0);	if(!(csr0 & (Rint|Tint)))		return;	/*	 * Receiver interrupt: run round the descriptor ring logging	 * errors and passing valid receive data up to the higher levels	 * until a descriptor is encountered still owned by the chip.	 */	if(csr0 & Rint){		dre = &ctlr->rdr[ctlr->rdrx];		while(!(dre->md1 & Own)){			if(dre->md1 & RxErr){				if(dre->md1 & RxBuff)					ctlr->rxbuff++;				if(dre->md1 & Crc)					ctlr->crc++;				if(dre->md1 & Oflo)					ctlr->oflo++;				if(dre->md1 & Fram)					ctlr->fram++;			}			else if(bp = iallocb(Rbsize)){				len = (dre->md2 & 0x0FFF)-4;				dre->bp->wp = dre->bp->rp+len;				etheriq(ether, dre->bp, 1);				dre->bp = bp;				dre->addr = PADDR(bp->rp);			}			/*			 * Finished with this descriptor, reinitialise it,			 * give it back to the chip, then on to the next...			 */			dre->md2 = 0;			dre->md1 = Own|(-Rbsize & 0xFFFF);			ctlr->rdrx = NEXT(ctlr->rdrx, Nrdre);			dre = &ctlr->rdr[ctlr->rdrx];		}	}	/*	 * Transmitter interrupt: wakeup anyone waiting for a free descriptor.	 */	if(csr0 & Tint){		lock(ctlr);		while(ctlr->ntq){			dre = &ctlr->tdr[ctlr->tdri];			if(dre->md1 & Own)				break;				if(dre->md1 & TxErr){				if(dre->md2 & Rtry)					ctlr->rtry++;				if(dre->md2 & Lcar)					ctlr->lcar++;				if(dre->md2 & Lcol)					ctlr->lcol++;				if(dre->md2 & Uflo)					ctlr->uflo++;				if(dre->md2 & TxBuff)					ctlr->txbuff++;				ether->oerrs++;			}				freeb(dre->bp);				ctlr->ntq--;			ctlr->tdri = NEXT(ctlr->tdri, Ntdre);		}		txstart(ether);		unlock(ctlr);	}	goto intrloop;}static voidamd79c970pci(void){	int port;	Ctlr *ctlr;	Pcidev *p;	p = nil;	while(p = pcimatch(p, 0x1022, 0x2000)){		port = p->mem[0].bar & ~0x01;		if(ioalloc(port, p->mem[0].size, 0, "amd79c970") < 0){			print("amd79c970: port 0x%uX in use\n", port);			continue;		}		ctlr = malloc(sizeof(Ctlr));		ctlr->port = p->mem[0].bar & ~0x01;		ctlr->pcidev = p;		if(ctlrhead != nil)			ctlrtail->next = ctlr;		else			ctlrhead = ctlr;		ctlrtail = ctlr;	}}static intreset(Ether* ether){	int x;	uchar ea[Eaddrlen];	Ctlr *ctlr;	if(ctlrhead == nil)		amd79c970pci();	/*	 * Any adapter matches if no port is supplied,	 * otherwise the ports must match.	 */	for(ctlr = ctlrhead; ctlr != nil; ctlr = ctlr->next){		if(ctlr->active)			continue;		if(ether->port == 0 || ether->port == ctlr->port){			ctlr->active = 1;			break;		}	}	if(ctlr == nil)		return -1;	/*	 * Allocate a controller structure and start to initialise it.	 */	ether->ctlr = ctlr;	ether->port = ctlr->port;	ether->irq = ctlr->pcidev->intl;	ether->tbdf = ctlr->pcidev->tbdf;	pcisetbme(ctlr->pcidev);	ilock(ctlr);	ctlr->init = 1;	io32r(ctlr, Sreset);	io16r(ctlr, Sreset);	if(io16w(ctlr, Rap, 0), io16r(ctlr, Rdp) == 4){		ctlr->ior = io16r;		ctlr->iow = io16w;	}else if(io32w(ctlr, Rap, 0), io32r(ctlr, Rdp) == 4){		ctlr->ior = io32r;		ctlr->iow = io32w;	}else{		print("#l%d: card doesn't talk right\n", ether->ctlrno);		iunlock(ctlr);		return -1;	}	ctlr->iow(ctlr, Rap, 88);	x = ctlr->ior(ctlr, Rdp);	ctlr->iow(ctlr, Rap, 89);	x |= ctlr->ior(ctlr, Rdp)<<16;	switch(x&0xFFFFFFF){	case 0x2420003:	/* PCnet/PCI 79C970 */	case 0x2621003:	/* PCnet/PCI II 79C970A */		break;	default:		print("#l%d: unknown PCnet card version %.7ux\n",			ether->ctlrno, x&0xFFFFFFF);		iunlock(ctlr);		return -1;	}	/*	 * Set the software style in BCR20 to be PCnet-PCI to ensure 32-bit access.	 * Set the auto pad transmit in CSR4.	 */	ctlr->iow(ctlr, Rap, 20);	ctlr->iow(ctlr, Bdp, 0x0002);	ctlr->iow(ctlr, Rap, 4);	x = ctlr->ior(ctlr, Rdp) & 0xFFFF;	ctlr->iow(ctlr, Rdp, ApadXmt|x);	ctlr->iow(ctlr, Rap, 0);	/*	 * Check if the adapter's station address is to be overridden.	 * If not, read it from the I/O-space and set in ether->ea prior to	 * loading the station address in the initialisation block.	 */	memset(ea, 0, Eaddrlen);	if(!memcmp(ea, ether->ea, Eaddrlen)){		x = ctlr->ior(ctlr, Aprom);		ether->ea[0] = x;		ether->ea[1] = x>>8;		if(ctlr->ior == io16r)			x = ctlr->ior(ctlr, Aprom+2);		else			x >>= 16;		ether->ea[2] = x;		ether->ea[3] = x>>8;		x = ctlr->ior(ctlr, Aprom+4);		ether->ea[4] = x;		ether->ea[5] = x>>8;	}	/*	 * Start to fill in the initialisation block	 * (must be DWORD aligned).	 */	ctlr->iblock.rlen = Lognrdre<<4;	ctlr->iblock.tlen = Logntdre<<4;	memmove(ctlr->iblock.padr, ether->ea, sizeof(ctlr->iblock.padr));	ringinit(ctlr);	ctlr->iblock.rdra = PADDR(ctlr->rdr);	ctlr->iblock.tdra = PADDR(ctlr->tdr);	/*	 * Point the chip at the initialisation block and tell it to go.	 * Mask the Idon interrupt and poll for completion. Strt and interrupt	 * enables will be set later when attaching to the network.	 */	x = PADDR(&ctlr->iblock);	ctlr->iow(ctlr, Rap, 1);	ctlr->iow(ctlr, Rdp, x & 0xFFFF);	ctlr->iow(ctlr, Rap, 2);	ctlr->iow(ctlr, Rdp, (x>>16) & 0xFFFF);	ctlr->iow(ctlr, Rap, 3);	ctlr->iow(ctlr, Rdp, Idon);	ctlr->iow(ctlr, Rap, 0);	ctlr->iow(ctlr, Rdp, Init);	while(!(ctlr->ior(ctlr, Rdp) & Idon))		;	/*	 * We used to set CSR0 to Idon|Stop here, and then	 * in attach change it to Iena|Strt.  Apparently the simulated	 * 79C970 in VMware never enables after a write of Idon|Stop,	 * so we enable the device here now.	 */	ctlr->iow(ctlr, Rdp, Iena|Strt);	ctlr->init = 0;	iunlock(ctlr);	/*	 * Linkage to the generic ethernet driver.	 */	ether->attach = attach;	ether->transmit = transmit;	ether->interrupt = interrupt;	ether->ifstat = ifstat;	ether->arg = ether;	ether->promiscuous = promiscuous;	ether->multicast = multicast;//	ether->shutdown = shutdown;	return 0;}voidether79c970link(void){	addethercard("AMD79C970",  reset);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产亚洲一本大道中文在线| 中文字幕在线观看不卡视频| 亚洲国产一区二区视频| 91天堂素人约啪| 国产精品的网站| 91久久国产最好的精华液| 亚洲精品水蜜桃| 欧美性猛交xxxx黑人交| 亚洲午夜一区二区三区| 日韩一级片网站| 国产成a人亚洲| 亚洲午夜久久久| 欧美v国产在线一区二区三区| 国产美女精品在线| 亚洲韩国一区二区三区| 久久精品亚洲一区二区三区浴池| 成人性生交大片| 免费人成网站在线观看欧美高清| 欧美日韩国产美女| 91在线观看视频| 老汉av免费一区二区三区| 亚洲人午夜精品天堂一二香蕉| 欧美一区二区视频观看视频| jlzzjlzz欧美大全| 久久国产生活片100| 亚洲第一成人在线| 亚洲精品国产a久久久久久| 国产精品三级电影| 久久久国产一区二区三区四区小说 | 激情综合色播五月| 《视频一区视频二区| 精品免费国产二区三区| 欧美撒尿777hd撒尿| 欧美三级资源在线| 91美女视频网站| 91视频com| 国产精品一区二区三区乱码| 日本中文字幕一区| 国产中文字幕一区| 丁香六月久久综合狠狠色| 国产一区二区福利视频| 国产乱码精品1区2区3区| av在线综合网| 欧美日韩国产影片| 精品少妇一区二区三区视频免付费| 欧美日韩久久一区二区| 在线观看精品一区| 欧美成人一区二区三区片免费| 精品少妇一区二区三区视频免付费| 精品99999| 亚洲蜜桃精久久久久久久| 日韩影视精彩在线| 国产91高潮流白浆在线麻豆| 91麻豆免费视频| 日韩三级伦理片妻子的秘密按摩| 久久久电影一区二区三区| 国产精品私人影院| 男女性色大片免费观看一区二区 | 日韩精品一区二区三区四区视频| 日韩一区二区三区精品视频| 日本一区二区免费在线观看视频| 亚洲精品免费在线| 奇米精品一区二区三区在线观看| 久久se精品一区二区| 在线免费观看一区| 国产精品色婷婷| 国产一区视频网站| 精品日韩99亚洲| 亚洲综合999| 99re免费视频精品全部| 久久久久久免费| 国产一区在线不卡| 亚洲精品一区二区三区福利| 免费成人美女在线观看| 欧美日韩免费高清一区色橹橹| 久久综合久久99| 另类调教123区 | 国产suv精品一区二区三区| 欧美一区二区三区视频免费| 性欧美大战久久久久久久久| 欧美色图第一页| 一级女性全黄久久生活片免费| 国产资源精品在线观看| 久久综合国产精品| 国产盗摄精品一区二区三区在线| 精品国产精品一区二区夜夜嗨| 老汉av免费一区二区三区| 日韩久久久久久| 成人小视频免费在线观看| 亚洲色图清纯唯美| 欧美三级日本三级少妇99| 久久精品理论片| 国产欧美日韩中文久久| 欧美在线小视频| 蜜臀a∨国产成人精品| 久久精品免费在线观看| 91麻豆福利精品推荐| 日本欧美一区二区三区乱码| 国产日韩欧美精品电影三级在线 | 日韩激情一区二区| 国产精品素人一区二区| 欧美日本视频在线| 不卡影院免费观看| 久久国产精品无码网站| 一区二区三区av电影| 久久新电视剧免费观看| 99国产精品久久久久| 国产做a爰片久久毛片| 亚洲3atv精品一区二区三区| 自拍偷拍国产精品| 欧美激情一区二区三区| 久久只精品国产| 日韩午夜小视频| 日韩欧美亚洲国产另类| 欧美电影在线免费观看| a亚洲天堂av| 91在线一区二区三区| 国产精品羞羞答答xxdd| 国产一区在线观看麻豆| 国产一区中文字幕| 国产美女精品在线| 成人av电影在线播放| eeuss影院一区二区三区| 91色在线porny| 欧美伦理视频网站| 911精品国产一区二区在线| 在线不卡a资源高清| 日韩精品中午字幕| 国产午夜精品一区二区三区视频| 91视频在线观看| 91精品国产91久久久久久一区二区| 91精品国产综合久久久久| 欧美电影免费观看完整版| 国产精品网站在线观看| 亚洲午夜电影在线观看| 免费成人av资源网| 99国产精品久久久| 日韩一级大片在线| 国产精品国产自产拍高清av王其| 亚洲蜜臀av乱码久久精品| 久久草av在线| 日本道色综合久久| 国产亚洲一区字幕| 亚洲黄色在线视频| 国产a区久久久| 日韩美女在线视频| 亚洲视频一区在线| 国产高清成人在线| 日韩免费高清av| 亚洲在线观看免费| 不卡视频一二三| 国产日本欧洲亚洲| 久久成人久久鬼色| 91精品国产综合久久福利| 洋洋av久久久久久久一区| 成人自拍视频在线观看| 国产精品区一区二区三| 成人开心网精品视频| 欧美成人video| 国产一区二区毛片| 欧美激情综合网| 99精品欧美一区二区三区小说| 久久精品夜夜夜夜久久| 国产伦精品一区二区三区免费迷| 日韩欧美在线影院| 麻豆国产欧美日韩综合精品二区| 666欧美在线视频| 久久精品国产网站| 国产人成亚洲第一网站在线播放| 国产精品自拍av| 国产精品剧情在线亚洲| 色老头久久综合| 天天色 色综合| 久久视频一区二区| 高清免费成人av| 中文字幕亚洲欧美在线不卡| 亚洲三级在线免费| 蜜桃91丨九色丨蝌蚪91桃色| 丁香婷婷综合激情五月色| 国产精品日日摸夜夜摸av| 欧美性大战久久久久久久蜜臀| 日韩激情中文字幕| 亚洲天堂av老司机| 日韩欧美国产综合在线一区二区三区| 精品一二线国产| 一区二区在线观看免费视频播放| 色就色 综合激情| 精品一区二区免费| 一区二区激情小说| 国产精品女同互慰在线看| 4438成人网| 欧美日本在线视频| 91一区二区三区在线播放| 九一九一国产精品| 日本欧美在线看| 亚洲最大成人综合| 亚洲美女视频在线观看| 亚洲人成在线播放网站岛国| 日韩欧美在线影院| 精品精品欲导航|