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

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

?? ne2000end.c

?? tornado開發 三星s3c44b0x開發板 bsp
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* ne2000End.c - NE2000 END network interface driver *//* Copyright 2004-2005 Amine@263.net *//* Copyright 1984-2002 Wind River Systems, Inc. */#include "copyright_wrs.h"/*modification history--------------------01o,23jul04,a_m  BSP定制 for 思創S3C44B0X黃金開發板01o,24jan02,rcs  added support for user setting the "Configuration Register A"                 or "Configuration Register B" from the load end string.01n,14jan02,dat  Removing warnings from Diab compiler01m,05dec00,dat  merge from sustaining to tor2_0_x01l,30nov00,pai  corrected the handling of EIOCSFLAGS ioctl (SPR #29423).01k,30nov00,pai  IFF_UP flag set in ne2000Start routine (SPR #32034, 34433).01j,10may00,pai  Discontinued use of splnet() (SPR #28366).  The ne2000Send()                 routine now returns END_ERR_BLOCK instead of ERROR so that                 upper-level protocols will clean up passed in mBlk.01i,28jul99,jkf  cleaned up warnings, fixed multicast support. (SPR#27921)01h,31mar99,sbs  changed atoi to strtoul for offset parameter parsing.                 (SPR #26208)01g,29mar99,dat  SPR 26119, documentation, usage of .bS/.bE01f,09feb99,fle  doc : fixed a problem with end of library description01e,27jan99,dat  removed most of the lint. (more work needed)01d,11aug98,mem  rewrote part of the overwrite recovery handling to		 avoid locking up the driver.01c,20may98,mem  added additional debug tracing, removed free of		 pMblk in ne2000PollSend().01b,06may98,mem  integrated changes from Brian Nash.01a,16mar98,mem	 written, based on drv/netif/if_ene.c.*//*DESCRIPTIONThis module implements the NE2000 Ethernet network interface driver.EXTERNAL INTERFACEThe only external interface is the ne2000EndLoad() routine, which expectsthe <initString> parameter as input.  This parameter passes in acolon-delimited string of the format:<unit>:<adrs>:<vecNum>:<intLvl>:<byteAccess>:<usePromEnetAddr>:<offset>The ne2000EndLoad() function uses strtok() to parse the string.TARGET-SPECIFIC PARAMETERS.IP <unit>A convenient holdover from the former model.  This parameter is used onlyin the string name for the driver..IP <adrs>Tells the driver where to find the ne2000..IP <vecNum>Configures the ne2000 device to generate hardware interruptsfor various events within the device. Thus, it containsan interrupt handler routine.  The driver calls sysIntConnect() to connectits interrupt handler to the interrupt vector generated as a result ofthe ne2000 interrupt..IP <intLvl>This parameter is passed to an external support routine, sysLanIntEnable(),which is described below in "External Support Requirements." This routineis called during as part of driver's initialization.  It handles anyboard-specific operations required to allow the servicing of a ne2000interrupt on targets that use additional interrupt controller devices tohelp organize and service the various interrupt sources.  This parametermakes it possible for this driver to avoid all board-specific knowledge ofsuch devices..IP <byteAccess>Tells the driver the NE2000 is jumpered to operate in 8-bit mode.Requires that SYS_IN_WORD_STRING() and SYS_OUT_WORD_STRING() bewritten to properly access the device in this mode..IP <usePromEnetAddr>Attempt to get the ethernet address for the device from the on-chip(board) PROM attached to the NE2000.  Will fall back to using theBSP-supplied ethernet address if this parameter is 0 or if unable toread the ethernet address..IP <offset>Specifies the memory alignment offset.EXTERNAL SUPPORT REQUIREMENTSThis driver requires several external support functions, defined as macros:.CS    SYS_INT_CONNECT(pDrvCtrl, routine, arg)    SYS_INT_DISCONNECT (pDrvCtrl, routine, arg)    SYS_INT_ENABLE(pDrvCtrl)    SYS_IN_CHAR(pDrvCtrl, reg, pData)    SYS_OUT_CHAR(pDrvCtrl, reg, pData)    SYS_IN_WORD_STRING(pDrvCtrl, reg, pData)    SYS_OUT_WORD_STRING(pDrvCtrl, reg, pData).CEThese macros allow the driver to be customized for BSPs that usespecial versions of these routines.The macro SYS_INT_CONNECT is used to connect the interrupt handler tothe appropriate vector.  By default it is the routine intConnect().The macro SYS_INT_DISCONNECT is used to disconnect the interrupt handler priorto unloading the module.  By default this is a dummy routine thatreturns OK.The macro SYS_INT_ENABLE is used to enable the interrupt level for theend device.  It is called once during initialization.  By default this isthe routine sysLanIntEnable(), defined in the module sysLib.o.The macro SYS_ENET_ADDR_GET is used to get the ethernet address (MAC)for the device.  The single argument to this routine is the END_DEVICEpointer.  By default this routine copies the ethernet address stored inthe global variable ne2000EndEnetAddr into the END_DEVICE structure.The macros SYS_IN_CHAR, SYS_OUT_CHAR, SYS_IN_WORD_STRING andSYS_OUT_WORD_STRING are used for accessing the ne2000 device.  Thedefault macros map these operations onto sysInByte(), sysOutByte(),sysInWordString() and sysOutWordString().INCLUDES:end.h endLib.h etherMultiLib.hSEE ALSO: muxLib, endLib.I "Writing and Enhanced Network Driver"INTERNAL: We are using the DP83905 manual as our reference. It is NE2000 compatible.*/#include "vxWorks.h"#include "endLib.h"			/* Common END structures. */#include "etherMultiLib.h"#include "netLib.h"#include "cacheLib.h"#include "lstLib.h"			/* Needed to maintain protocol list. */#include "iv.h"#include "stdlib.h"#include "sysLib.h"#include "intLib.h"#include "taskLib.h"#include "ne2000End.h"		/* Common defines. Amine: 包含BSP目錄的定制頭文件*//***** LOCAL DEFINITIONS *****/#define NE2000_ALL_INTS    (IM_OVWE | IM_TXEE | IM_RXEE | IM_PTXE | IM_PRXE)/* * AUTODIN-II, FDDI, ethernet polynomial for 32 bit CRC. * * The polynomial is expressed: * *   ( x^32 + x^26 + x^23 + x^22 + x^16 + *     x^12 + x^11 + x^10 + x^8  + x^7  + *            x^5  + x^4  + x^2  + x^1  + 1 ) = 0x04c11db7 * * Where x = base 2 (binary) and x^32 is ignored for CRC. * (x^32, is not in 32 bit value (ends at x^31) */#define CRC32_POLYNOMIAL		0x04c11db7/* Configuration items */#define END_SPEED		10000000/* Naming items */#define NE2000_DEV_NAME		"ene"#define NE2000_DEV_NAME_LEN	4/* * Default macro definitions for BSP interface. * These macros can be redefined in a wrapper file, to generate * a new module with an optimized interface. *//* Macro to connect interrupt handler to vector *//* Amine: 名稱替換sysIntConnect->intConnect,其他相同 */#ifndef SYS_INT_CONNECT#define SYS_INT_CONNECT(pDrvCtrl,rtn,arg,pResult) \	{ \	IMPORT STATUS intConnect(); \	*pResult = intConnect ((VOIDFUNCPTR *)INUM_TO_IVEC (pDrvCtrl->ivec), \			     rtn, (int)arg); \	}#endif/* Macro to disconnect interrupt handler from vector */#ifndef SYS_INT_DISCONNECT#define SYS_INT_DISCONNECT(pDrvCtrl,rtn,arg,pResult) \	{ \	*pResult = OK; /* HELP: need a real routine */ \	}#endif/* Macro to enable the appropriate interrupt level *//* Amine: 名稱替換sysLanIntEnable->intEnable,返回類型不同void->STATUS */#ifndef SYS_INT_ENABLE#define SYS_INT_ENABLE(pDrvCtrl) \	{ \	IMPORT STATUS intEnable(); \	intEnable (pDrvCtrl->ilevel); \	}#endif/* Macro to get the ethernet address from the BSP */#ifndef SYS_ENET_ADDR_GET#define SYS_ENET_ADDR_GET(pDevice) \	ne2000EnetAddrGet(pDevice)#endif/* * Macros to do a short (UINT16) access to the chip. Default * assumes a normal memory mapped device. * CPU_FAMILY is used to avoid conflict between x86 and non * x86 defintitions (proper) of these macro's.  This is * to avoid some compiler warnings. */#if     (CPU_FAMILY == I80X86)/* sysLib.h uses two declarations of sys<Blah>WordString */#ifndef SYS_OUT_CHAR#define SYS_OUT_CHAR(pDrvCtrl,addr,value) \	sysOutByte((pDrvCtrl)->base + (int) (addr),(char) (value))#endif#ifndef SYS_IN_CHAR#define SYS_IN_CHAR(pDrvCtrl,addr,pData) \	(*(pData) = (UCHAR) sysInByte((pDrvCtrl)->base + (int) (addr)))#endif/* sysLib.h head setsup to declarations of sys<Blah>WordString */#ifndef SYS_IN_WORD_STRING#define SYS_IN_WORD_STRING(pDrvCtrl,addr,pData,len) \	(sysInWordString ((pDrvCtrl)->base + (int) (addr), (short *)(pData), \			  (len)))#endif#ifndef SYS_OUT_WORD_STRING#define SYS_OUT_WORD_STRING(pDrvCtrl,addr,pData,len) \	(sysOutWordString ((pDrvCtrl)->base + (int) (addr), (short *)(pData), \			   (len)))#endif#else /* #if     (CPU_FAMILY == I80X86) */#ifndef SYS_OUT_CHAR#define SYS_OUT_CHAR(pDrvCtrl,addr,value) \    	sysOutByte((pDrvCtrl)->base + (UINT) (addr), (value))#endif#ifndef SYS_IN_CHAR#define SYS_IN_CHAR(pDrvCtrl,addr,pData) \    	(*(pData) = (UCHAR) sysInByte((pDrvCtrl)->base + (UINT) (addr)))#endif#ifndef SYS_IN_WORD_STRING#define SYS_IN_WORD_STRING(pDrvCtrl,addr,pData,len) \    	(sysInWordString ((pDrvCtrl)->base + (UINT) (addr),  \			  (UINT16 *)(pData), (len)))#endif#ifndef SYS_OUT_WORD_STRING#define SYS_OUT_WORD_STRING(pDrvCtrl,addr,pData,len) \    	(sysOutWordString ((pDrvCtrl)->base + (UINT) (addr), \			   (UINT16 *) (pData), (len)))#endif#endif /* #if     (CPU_FAMILY == I80X86) *//* A shortcut for getting the hardware address from the MIB II stuff. */#define END_HADDR(pEnd)	\		((pEnd)->mib2Tbl.ifPhysAddress.phyAddress)#define END_HADDR_LEN(pEnd) \		((pEnd)->mib2Tbl.ifPhysAddress.addrLength)/* Statistics we gather from the NE2000 */typedef struct    {    UINT collisions;    UINT crcs;    UINT aligns;    UINT missed;    UINT overruns;    UINT disabled;    UINT deferring;    UINT underruns;    UINT aborts;    UINT outofwindow;    UINT heartbeats;    UINT badPacket;    UINT shortPacket;    UINT tnoerror;    UINT rnoerror;    UINT terror;    UINT rerror;    UINT overwrite;    UINT wrapped;    UINT interrupts;    UINT reset;    UINT strayint;    UINT jabber;    } NE2000_STAT;/* * The definition of the driver control structure.  The packetBuf[] * array needs to be kept at least word-aligned as it gets passed to * SYS_OUT_WORD_STRING() and some architectures cannot handle * misaligned accesses. */typedef struct ne2000_device    {    END_OBJ		endObj;		/* The class we inherit from. */    END_ERR		lastError;	/* Last error passed to muxError */    int			lastIntError;	/* last interrupt signalled error */    int			unit;		/* unit number */    int			ivec;		/* interrupt vector */    int			ilevel;		/* interrupt level */    int			byteAccess;	/* 8-bit access mode */    int			usePromEnetAddr;/* enet addr from PROM */    ULONG		base;		/* base address */    int			offset;		/* offset for memory alignment */    char		packetBuf [NE2000_BUFSIZ];	/* long-aligned */    volatile long	flags;		/* Our local flags. */    volatile UCHAR	current;	/* current-page reg at interrupt */    volatile ULONG	imask;		/* interrupt mask */    volatile NE2000_STAT stats;		/* NE2000 stats */    UCHAR		enetAddr[6];	/* ethernet address */    UCHAR		mcastFilter[8];	/* multicast filter */    UCHAR		nextPacket;	/* where the next received packet is */    CL_POOL_ID		clPoolId;    int                 configRegA;     /* configuration register A */    int                 configRegB;     /* configuration register B */} NE2000END_DEVICE;/* Definitions for the flags field */#define END_PROMISCUOUS_FLAG	0x01#define END_RECV_HANDLING_FLAG	0x02#define END_TX_IN_PROGRESS	0x04#define END_TX_BLOCKED		0x08#define END_POLLING		0x10#define END_OVERWRITE		0x20#define END_OVERWRITE2		0x40/***** DEBUG MACROS *****/#undef DEBUG#ifdef DEBUG#   include "stdio.h"#   include "logLib.h"    int endDebug = 0;#   define ENDLOGMSG(x) \	do { \	    if (endDebug) \		logMsg x; \	   } while (0)#else#   define ENDLOGMSG(x)#endif /* ENDDEBUG *//***** LOCALS *****//* imports */IMPORT char ne2000EnetAddr[];IMPORT int endMultiLstCnt (END_OBJ *);/* forward static functions */LOCAL void	ne2000Int (NE2000END_DEVICE* pDrvCtrl);LOCAL void	ne2000HandleRcvInt (NE2000END_DEVICE* pDrvCtrl);LOCAL void	ne2000Config (NE2000END_DEVICE* pDrvCtrl,			      int intEnable);LOCAL void	ne2000OverwriteRecover (NE2000END_DEVICE* pDrvCtrl,					UCHAR cmdStatus);LOCAL int	ne2000PacketGet (NE2000END_DEVICE* pDrvCtrl, char *pData);LOCAL void	ne2000AddrFilterSet (NE2000END_DEVICE* pDrvCtrl);LOCAL UINT32 	ne2000CrcWork (UINT8 inChar, UINT32 inCrc);LOCAL void	ne2000EnetAddrGet (NE2000END_DEVICE* pDrvCtrl);LOCAL UCHAR	ne2000GetCurr (NE2000END_DEVICE* pDrvCtrl);LOCAL void	ne2000DataIn (NE2000END_DEVICE* pDrvCtrl, int eneAddress,			      int len, char* pData);LOCAL void	ne2000DataOut (NE2000END_DEVICE* pDrvCtrl, char* pData,			       int len, int eneAddress);LOCAL STATUS	ne2000Parse (NE2000END_DEVICE* pDrvCtrl, char* initString);LOCAL STATUS	ne2000MemInit (NE2000END_DEVICE* pDrvCtrl);LOCAL STATUS	ne2000PollStart (NE2000END_DEVICE* pDrvCtrl);LOCAL STATUS	ne2000PollStop (NE2000END_DEVICE* pDrvCtrl);/* END Specific interfaces. *//* This is the only externally visible interface. */END_OBJ * 	ne2000EndLoad (char* initString, void *pBSP);LOCAL STATUS	ne2000Start (void* pCookie);LOCAL STATUS	ne2000Stop (void* pCookie);LOCAL STATUS	ne2000Unload (void *pCookie);LOCAL int	ne2000Ioctl (void *pCookie, int cmd, caddr_t data);LOCAL STATUS	ne2000Send (void *pCookie, M_BLK_ID pBuf);LOCAL STATUS	ne2000MCastAdd (void *pCookie, char* pAddress);LOCAL STATUS	ne2000MCastDel (void *pCookie, char* pAddress);LOCAL STATUS	ne2000MCastGet (void *pCookie, MULTI_TABLE* pTable);LOCAL STATUS	ne2000PollSend (void *pCookie, M_BLK_ID pBuf);LOCAL STATUS	ne2000PollRecv (void *pCookie, M_BLK_ID pBuf);/* * Declare our function table.  This is static across all driver * instances. */LOCAL NET_FUNCS ne2000FuncTable =    {    (FUNCPTR) ne2000Start,	/* Function to start the device. */    (FUNCPTR) ne2000Stop,	/* Function to stop the device. */    (FUNCPTR) ne2000Unload,	/* Unloading function for the driver. */    (FUNCPTR) ne2000Ioctl,	/* Ioctl function for the driver. */    (FUNCPTR) ne2000Send,	/* Send function for the driver. */    (FUNCPTR) ne2000MCastAdd,	/* Multicast address add function for the */				/* driver. */    (FUNCPTR) ne2000MCastDel,	/* Multicast address delete function for */				/* the driver. */    (FUNCPTR) ne2000MCastGet,	/* Multicast table retrieve function for */				/* the driver. */    (FUNCPTR) ne2000PollSend,	/* Polling send function for the driver. */    (FUNCPTR) ne2000PollRecv,	/* Polling receive function for the driver. */    endEtherAddressForm, /* put address info into a NET_BUFFER */    (FUNCPTR) endEtherPacketDataGet, /* get pointer to data in NET_BUFFER */    (FUNCPTR) endEtherPacketAddrGet  /* Get packet addresses. */    };/******************************************************************************** ne2000EndLoad - initialize the driver and device** This routine initializes the driver and the device to the operational state.* All of the device specific parameters are passed in the initString.** The string contains the target specific parameters like this:** "unit:register addr:int vector:int level:shmem addr:shmem size:shmem width"** RETURNS: An END object pointer or NULL on error.*/END_OBJ* ne2000EndLoad    (    char* initString,		/* String to be parsed by the driver. */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区在线免费播放| 国产精品69毛片高清亚洲| 在线观看亚洲精品| 亚洲激情五月婷婷| 欧美亚洲国产一区二区三区va| 亚洲人吸女人奶水| 欧美日韩视频在线第一区| 视频一区二区国产| 日韩一卡二卡三卡四卡| 国模大尺度一区二区三区| 亚洲国产精品激情在线观看| 91伊人久久大香线蕉| 一区二区三区精品视频| 91麻豆精品国产91久久久久久久久 | 日韩极品在线观看| 日韩欧美亚洲一区二区| 国产精品 日产精品 欧美精品| 中文字幕欧美日本乱码一线二线| 99精品桃花视频在线观看| 亚洲一区二区黄色| 欧美成人精品1314www| 成人精品亚洲人成在线| 一区二区三区在线观看视频| 911精品国产一区二区在线| 国内精品写真在线观看| 日韩伦理av电影| 4438x成人网最大色成网站| 国内成人精品2018免费看| 国产精品久久久久久久久晋中| 91免费国产在线| 久久99热狠狠色一区二区| 国产精品久久99| 4hu四虎永久在线影院成人| 国内久久婷婷综合| 亚洲一区二区不卡免费| 久久日一线二线三线suv| 色综合久久综合网欧美综合网| 美女视频黄频大全不卡视频在线播放| 中文字幕欧美日本乱码一线二线 | 欧美乱妇23p| 波多野结衣中文一区| 肉丝袜脚交视频一区二区| 国产精品午夜在线| 在线综合+亚洲+欧美中文字幕| 99视频精品全部免费在线| 另类小说视频一区二区| 一区二区三区日本| 国产亚洲精品bt天堂精选| 欧美疯狂性受xxxxx喷水图片| 成人av网站在线观看免费| 久久99精品久久久久| 亚洲国产精品久久人人爱| 国产精品网站一区| 精品国产乱码久久久久久浪潮| 在线亚洲一区二区| 成人激情综合网站| 国产一区二三区| 免费成人在线网站| 亚洲国产cao| 亚洲最新视频在线播放| 一色桃子久久精品亚洲| 久久久久久影视| 日韩精品在线网站| 欧美精品自拍偷拍动漫精品| 色婷婷久久综合| 91免费国产视频网站| www.在线成人| 成人精品视频一区二区三区| 国产原创一区二区| 久久精品国产精品亚洲综合| 日韩精品一二区| 亚洲3atv精品一区二区三区| 亚洲国产中文字幕| 一级日本不卡的影视| 亚洲精品成人a在线观看| 亚洲欧美福利一区二区| 亚洲人亚洲人成电影网站色| 国产精品欧美一区喷水| 欧美激情一区二区三区全黄| 久久毛片高清国产| 久久亚洲春色中文字幕久久久| 精品久久久久av影院 | 国产欧美日韩久久| 久久亚洲精华国产精华液| 久久精品亚洲麻豆av一区二区 | 欧美日韩国产综合一区二区| 欧美亚洲国产bt| 欧美精选午夜久久久乱码6080| 欧美精品久久99| 欧美成人精品高清在线播放| 久久久久久久网| 国产精品久久久久久久久果冻传媒| 中文字幕亚洲电影| 一区二区三区成人在线视频| 亚洲国产综合91精品麻豆| 青青草原综合久久大伊人精品优势| 欧美aⅴ一区二区三区视频| 精品写真视频在线观看| 国产经典欧美精品| 一本久久综合亚洲鲁鲁五月天| 欧美午夜精品理论片a级按摩| 91精品在线免费| 国产欧美精品日韩区二区麻豆天美 | 成人高清视频在线| 色激情天天射综合网| 欧美色区777第一页| 日韩一区二区三区在线| 国产欧美一区二区三区在线看蜜臀 | 在线观看一区不卡| 日韩亚洲欧美高清| 国产精品网站在线播放| 亚洲一区二区三区激情| 激情综合网激情| 91视频观看免费| 欧美电影免费观看高清完整版 | 精品久久久久久久久久久院品网| 国产精品久久三| 日精品一区二区| 国内精品国产三级国产a久久| 暴力调教一区二区三区| 3d动漫精品啪啪一区二区竹菊| 国产亚洲视频系列| 亚洲第一成年网| 福利一区二区在线观看| 欧美肥妇毛茸茸| 国产精品毛片久久久久久| 热久久国产精品| 色综合久久综合网97色综合 | 欧美国产精品久久| 午夜天堂影视香蕉久久| 粉嫩在线一区二区三区视频| 国产视频911| 日韩高清不卡一区二区三区| 不卡的电影网站| 精品播放一区二区| 性久久久久久久久久久久| av激情综合网| 久久久久久久精| 日韩在线一区二区三区| 91猫先生在线| 久久老女人爱爱| 日本美女一区二区三区视频| 99久久99久久精品国产片果冻 | 久久综合一区二区| 日韩福利电影在线观看| 91理论电影在线观看| 久久精品无码一区二区三区| 日韩高清电影一区| 欧美日韩国产片| 亚洲色图在线播放| av一区二区三区在线| 久久久高清一区二区三区| 蜜臀av性久久久久蜜臀aⅴ四虎| 色偷偷久久一区二区三区| 中文字幕欧美激情| 福利电影一区二区三区| 久久久久9999亚洲精品| 国产美女av一区二区三区| 日韩亚洲欧美高清| 日本中文一区二区三区| 91麻豆精品国产自产在线观看一区| 亚洲夂夂婷婷色拍ww47| 色视频成人在线观看免| 亚洲色图20p| 色婷婷综合激情| 亚洲国产精品视频| 欧美午夜免费电影| 亚洲成人免费视频| 欧美私人免费视频| 亚洲午夜激情av| 欧美日韩卡一卡二| 午夜免费久久看| 91精品国产aⅴ一区二区| 丝袜亚洲另类欧美| 日韩欧美资源站| 国产一区免费电影| 中文字幕av在线一区二区三区| 成人动漫一区二区三区| 亚洲日本va午夜在线影院| 在线看不卡av| 日韩国产成人精品| 在线电影一区二区三区| 秋霞成人午夜伦在线观看| 日韩精品一区二区三区老鸭窝| 国产在线精品国自产拍免费| 国产欧美日韩在线看| 99久久亚洲一区二区三区青草| 亚洲人成亚洲人成在线观看图片| 91国产精品成人| 日韩福利视频网| 国产精品三级视频| 91成人免费在线| 国产综合成人久久大片91| 亚洲国产精品二十页| 91欧美一区二区| 奇米亚洲午夜久久精品| 国产亲近乱来精品视频| 91久久免费观看| 狠狠色狠狠色合久久伊人| 国产精品午夜电影|