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

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

?? macinit.c

?? 三星4510開發(fā)板Sdns100上代的演示程序
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/*************************************************************************/
/*                                                                       */
/* FILE NAME                                      VERSION                */
/*                                                                       */
/*      macinit.c                  		 KS32C50100   : version 1.0 */
/*                                                                       */
/* COMPONENT                                                             */
/*                                                                       */
/* DESCRIPTION                                                           */
/*                                                                       */
/* AUTHOR                                                                */
/*                                                                       */
/*                                                                       */
/* DATA STRUCTURES                                                       */
/*                                                                       */
/*                                                                       */
/* FUNCTIONS                                                             */
/*                                                                       */
/*          Include All MAC & BDMAC Initialize Routine                   */
/*                                                                       */
/* DEPENDENCIES                                                          */
/*                                                                       */
/*                                                                       */
/*************************************************************************/
#include <stdarg.h>
#include <stdio.h>
#include <ctype.h>
#include <string.h>
#include "std.h"
#include "sysconf.h"
#include "isr.h"
#include "mac.h"
#include "uart.h"
#include "pollio.h"
#include "timer.h"
#include "memory.h"
#include "iic.h"


/* 
 * Define MAC address source, IIC EEPROM or set value by manual
 */
#define MAC_ADDR_FROM_IIC_EEPROM  	1
#define KS32C5000_BUG_FETCH 		1

sFrameDescriptor RxFDBaseAddr[MaxRxFrameDescriptors];   // Tx Frame Descriptor
sMACFrame RxFBABaseAddr[MaxRxFrameData];		// Tx Frame Buffer

sFrameDescriptor TxFDBaseAddr[MaxTxFrameDescriptors];   // Rx Frame Descriptor
sMACFrame TxFBABaseAddr[MaxTxFrameData];		// Rx Frame Buffer

// Global variables  used for MAC driver
volatile U32 gMacCon = FullDup ;
volatile U32 gMacTxCon = EnComp ;
volatile U32 gMacRxCon = RxEn | StripCRC ; 
volatile U32 gBdmaTxCon = BTxBRST | BTxMSL110 | BTxSTSKO ;
#ifdef LITTLE
volatile U32 gBdmaRxCon = BRxDIE | BRxEn | BRxLittle | BRxMAINC | BRxBRST | \
                          BRxNLIE | BRxNOIE | BRxSTSKO ;
#else
volatile U32 gBdmaRxCon = BRxDIE | BRxEn | BRxBig | BRxMAINC | BRxBRST | \
                          BRxNLIE | BRxNOIE | BRxSTSKO ;
#endif
volatile U32 gCamCon = CompEn | BroadAcc | GroupAcc;

volatile U32 gDuplexValue = 0 ;

volatile U32 gCTxFDPtr, gWTxFDPtr ;
volatile U32 gCRxFDPtr, gPreviousFdp=0 ;
volatile U32 gCam0_Addr0 = 0 , gCam0_Addr1 = 0  ;
volatile U8 MyMacSrcAddr[6] ;
volatile int WatchDogTime = 0 ;
volatile int gErrorPacketCnt =0 ;
#if KS32C5000_BUG_FETCH
	volatile U32 gPreviousStatusField = 0 ;
#endif
volatile int BdmaRxDoneFlagForLoopBackCheck = 0 ;
volatile int MacTxDoneFlagForLoopBackCheck = 0 ;

// Global variable structure for store status
pMACTxStatus gsMacTxStatus = {0,0,0,0,0,0,0,0,0,0,0} ;
pMACRxStatus gsMacRxStatus = {0,0,0,0,0,0,0,0,0} ;
pBDMATxStatus gsBdmaTxStatus = {0,0,0} ;
pBDMARxStatus gsBdmaRxStatus = {0,0,0,0,0} ;

extern TIME tm0 ;


/*
 * void LanInitialize(void)
 */
void LanInitialize(void)
{
	// Reset the PHY chip and start Auto-negotiat
	ResetPhyChip() ;

	// Read MAC address from IIC EEPROM
	GetMyMacAddr() ;

	// Initialize MAC and BDMA controller
//	MacInitialize() ;
}

/*
 * void MacInitialize(void)
 * Initialize MAC and BDMA Controller
 */
void MacInitialize(void)
{

	/*-----------------------------------------------------------------*
	 * 1. Disable MAC and BDMA interrupts.                             *
	 *-----------------------------------------------------------------*/
	Disable_Int(nMAC_RX_INT) ;     // Disable MAC Rx Interrupt
	Disable_Int(nMAC_TX_INT) ;     // Disable MAC Tx Interrupt
	Disable_Int(nBDMA_RX_INT) ;    // Disable BDMA Rx Interrupt
	Disable_Int(nBDMA_TX_INT) ;    // Disable BDMA Tx Interrupt

	/*-----------------------------------------------------------------*
	 * 2. BDMA and MAC interrupt vector setup.                         * 
	 *-----------------------------------------------------------------*/
	SysSetInterrupt(nMAC_RX_INT, MAC_Rx_isr) ;
	SysSetInterrupt(nMAC_TX_INT, MAC_Tx_isr) ;
	SysSetInterrupt(nBDMA_RX_INT, BDMA_Rx_isr) ; 
	SysSetInterrupt(nBDMA_TX_INT, BDMA_Tx_isr) ;


	/*-----------------------------------------------------------------*
 	 * 3. Set the initial condition of the BDMA, and MAC               * 
 	 *-----------------------------------------------------------------*/
	BDMARXCON = BRxRS ;             // Reset BDMAC Receiver
	BDMATXCON = BTxRS ;             // Reset BDMAC Transceiver
	MACCON = SwReset ;
	BDMARXLSZ = MaxRxFrameSize+40 ;    // 1520
	MACCON = gMacCon ;

	/*-----------------------------------------------------------------*
 	 * 4. Set the BDMA Tx/Rx Frame Descriptor                          *
 	 *-----------------------------------------------------------------*/
	TxFDInitialize() ;
	RxFDInitialize() ;

	/*-----------------------------------------------------------------*
 	 * 5. Set the CAM Control register and the MAC address value       *
 	 *-----------------------------------------------------------------*/
 	// CAM0 register of CAM registers : 0x9100~0x9103, 0x9104, 0x9105
        CAM_Reg(0) =  gCam0_Addr0;
        CAM_Reg(1) =  gCam0_Addr1;

	// CAM Enable Register(CAMEN)
	CAMEN = 0x0001 ;
	CAMCON = gCamCon ;

	/*-----------------------------------------------------------------*
	 * 6. Enable interrupt BDMA Rx and MAC Tx interrupt.               *
	 *-----------------------------------------------------------------*/
	Enable_Int(nBDMA_RX_INT); 
	Enable_Int(nMAC_TX_INT);
	//Enable_Int(nMAC_RX_INT);

	/*-----------------------------------------------------------------*
 	 * 7. Configure the BDMA and MAC control registers.                *
 	 *-----------------------------------------------------------------*/
	ReadyMacTx() ;
	ReadyMacRx() ;
}

void MacWatchdogInit(void) 
{
	sFrameDescriptor *pRxFDptr ;

	MACRXCON = 0x0 ;		// Disable MAC contoller Rx operation
	BDMARXCON = 0x0 ;		// Disable BDMA contoller Rx operation
	BDMARXCON = BRxRS ;             // Reset BDMAC Receiver
	Disable_Int(nBDMA_RX_INT) ;     // Disable BDMA Rx Interrupt
	BDMARXLSZ = MaxRxFrameSize ;    // 1520
	pRxFDptr = (sFrameDescriptor *)gCRxFDPtr ;
	BDMARXPTR = gCRxFDPtr = (U32)(pRxFDptr->NextFrameDescriptor) ;
	Enable_Int(nBDMA_RX_INT); 
	BDMARXCON = gBdmaRxCon ;
	MACRXCON = gMacRxCon ;
}


/*
 * void TxFDInitialize(void) ;
 *           Initialize Tx frame descriptor area-buffers.
 */
void TxFDInitialize(void)
{
	sFrameDescriptor *pFrameDescriptor;
	sFrameDescriptor *pStartFrameDescriptor;
	sFrameDescriptor *pLastFrameDescriptor = NULL;
	U32 FrameDataAddr;
	U32 i;

	// Get Frame descriptor's base address.   
	// +0x4000000 is for setting this area to non-cacheable area. 
	BDMATXPTR = (U32)TxFDBaseAddr + 0x4000000;
	gWTxFDPtr = gCTxFDPtr = BDMATXPTR;

	// Get Transmit buffer base address.
	FrameDataAddr = (U32)TxFBABaseAddr + 0x4000000;

	// Generate linked list.
	pFrameDescriptor = (sFrameDescriptor *) gCTxFDPtr;
	pStartFrameDescriptor = pFrameDescriptor;

	for(i=0; i < MaxTxFrameDescriptors; i++)  {
		if(pLastFrameDescriptor == NULL)
			pLastFrameDescriptor = pFrameDescriptor;
		else  	pLastFrameDescriptor->NextFrameDescriptor = (U32)pFrameDescriptor;

		pFrameDescriptor->FrameDataPtr = 
			(U32)(FrameDataAddr & fOwnership_CPU);
		pFrameDescriptor->Reserved = (U32)0x0;
		pFrameDescriptor->StatusAndFrameLength = (U32)0x0;
		pFrameDescriptor->NextFrameDescriptor = NULL;

		pLastFrameDescriptor = pFrameDescriptor;
		pFrameDescriptor++;
		FrameDataAddr += sizeof(sMACFrame);
	} // end for loop

	// Make Frame descriptor to ring buffer type.     
	pFrameDescriptor--; 
	pFrameDescriptor->NextFrameDescriptor = (U32)pStartFrameDescriptor;
}

/*
 * void RxFDInitialize(void) ;
 *           Initialize Rx frame descriptor area-buffers.
 */
void RxFDInitialize(void)
{
	sFrameDescriptor *pFrameDescriptor;
	sFrameDescriptor *pStartFrameDescriptor;
	sFrameDescriptor *pLastFrameDescriptor = NULL;
	U32 FrameDataAddr;
	U32 i;

	// Get Frame descriptor's base address.  
	// +0x4000000 is for setting this area to non-cacheable area. 
	BDMARXPTR = (U32)RxFDBaseAddr + 0x4000000;
	gCRxFDPtr = BDMARXPTR;
	
	// Get Transmit buffer base address.  
	FrameDataAddr = (U32)RxFBABaseAddr + 0x4000000;

	// Generate linked list. 
	pFrameDescriptor = (sFrameDescriptor *) gCRxFDPtr;
	pStartFrameDescriptor = pFrameDescriptor;
	
	for(i=0; i < MaxRxFrameDescriptors; i++)  {
		if(pLastFrameDescriptor == NULL)
			pLastFrameDescriptor = pFrameDescriptor;
		else  	pLastFrameDescriptor->NextFrameDescriptor = (U32)pFrameDescriptor;

		pFrameDescriptor->FrameDataPtr =
		(U32)(FrameDataAddr | fOwnership_BDMA | 0x4000000 );
		pFrameDescriptor->Reserved = (U32)0x0;
		pFrameDescriptor->StatusAndFrameLength = (U32)0x0;
		pFrameDescriptor->NextFrameDescriptor = NULL;
		
		pLastFrameDescriptor = pFrameDescriptor;
		pFrameDescriptor++;
		FrameDataAddr += sizeof(sMACFrame); 
	} // end for loop
      
	// Make Frame descriptor to ring buffer type.     
	pFrameDescriptor--; 
	pFrameDescriptor->NextFrameDescriptor = (U32)pStartFrameDescriptor;
}



/*
 * Function : ReadyMacTx
 * Description : set Tx Registers related with BDMA & MAC to transmit
 *               packet.
 */
void ReadyMacTx(void)
{
	BDMATXCON = gBdmaTxCon ;
	MACTXCON =  gMacTxCon ;
}

/*
 * Function : ReadyMacRx
 * Description : set Rx Registers related with BDMA & MAC to Receive packet.
 */
void ReadyMacRx(void)
{
	BDMARXCON = gBdmaRxCon ;
	MACRXCON = gMacRxCon ;
}

/*
 * Function : MacTxGo
 * Description : MAC Transfer Start for interactive mode
 */
void MacTxGo(void)
{
	// Enable MAC and BDMA Transfer
	if (!(BDMATXCON & BTxEn))  BDMATXCON |= BTxEn ;
	MACTXCON |= TxEn  ;
}


/*
 * Function : Lan_WatchDog
 * Description : LAN watchdog function 
 */
void Lan_WatchDog(void)
{

	WatchDogTime++ ;
        if ( !(WatchDogTime%100) ) {
                if (gCRxFDPtr == gPreviousFdp) {
			MacWatchdogInit() ; 
		}
                else gPreviousFdp = gCRxFDPtr ;
	}
}


/*
 * Function : GetMyMacAddr 
 * Description : Get MAC Address From IIC EEPROM
 */
	
void GetMyMacAddr(void)
{
	U8 *MacAddr;
	U8 TempAddr[MAC_ADDR_SIZE];
	int i;
	
	gCam0_Addr0 = gCam0_Addr1 = 0 ;

#if MAC_ADDR_FROM_IIC_EEPROM // when use IIC EEPROM for store MAC address 
	MacAddr=(U8 *)IICReadInt((U8)IIC_DEV_0,(U32)iMacAddrPtr,(U32)MAC_ADDR_SIZE) ;
#else	// When manual ly setting the MAC address
	MacAddr[0] = 0x00 ;
	MacAddr[1] = 0x00 ;
	MacAddr[2] = 0xf0 ;
	MacAddr[3] = 0x11 ;
	MacAddr[4] = 0x00 ;
	MacAddr[5] = 0x00 ;
#endif

	/* Get MAC Address */
	for (i=0;i<(int)MAC_ADDR_SIZE;i++)  TempAddr[i] = *MacAddr++;
	
	/* Copy MAC Address to global variable */
	for (i=0;i<(int)MAC_ADDR_SIZE-2;i++)
		gCam0_Addr0 = (gCam0_Addr0 << 8) | TempAddr[i] ;

	for (i=(int)(MAC_ADDR_SIZE-2);i<(int)MAC_ADDR_SIZE;i++)
		gCam0_Addr1 = (gCam0_Addr1 << 8) | TempAddr[i] ;
	gCam0_Addr1 = (gCam0_Addr1 << 16) ;

 	/* Set CAM0 register : 0x9100~0x9103, 0x9104, 0x9105 */
        CAM_Reg(0) =  gCam0_Addr0;
        CAM_Reg(1) =  gCam0_Addr1;

	for (i=0;i<(int)MAC_ADDR_SIZE;i++) MyMacSrcAddr[i] = TempAddr[i];
}


/*
 * Function : ResetPhyChip
 * Description : Reset The Phychip, Auto-Negotiation Enable 
 */
void ResetPhyChip(void)
{
	U32	value ;

	if(MACCON&MACLoop) MiiStationWrite(PHY_CNTL_REG,PHYHWADDR,DR_100MB|PHY_FULLDUPLEX) ;
	else {

#if 0  /* This routine is not used, because have some error */
	// 1. Reset PHY chip
	MiiStationWrite(PHY_CNTL_REG, PHYHWADDR, RESET_PHY ) ;
	while ( (MiiStationRead(PHY_CNTL_REG, PHYHWADDR) & RESET_PHY) )  ;

	// 2. Restart PHY auto-negotiation
	MiiStationWrite(PHY_CNTL_REG, PHYHWADDR, ENABLE_AN | RESTART_AN); 

	// 3. Wait until auto-negotiation complete
	while ( !(MiiStationRead(PHY_STATUS_REG, PHYHWADDR) & AN_COMPLETE) ) ;

	// 4. Read auto-negotiation status from PHY register
	value = MiiStationRead(PHY_ANLPAR_REG, PHYHWADDR)  ;

	// 5. Set PHY control register as auto-negotiation status 
	if ( (value & DR100_TX_FULL) ) {
		MiiStationWrite(PHY_CNTL_REG,PHYHWADDR,DR_100MB|PHY_FULLDUPLEX) ;
		gDuplexValue = FullDup ;
	}
	else if ( (value & DR100_TX_HALF) )
		MiiStationWrite(PHY_CNTL_REG,PHYHWADDR,DR_100MB) ;
	else if ( (value & DR10_TX_FULL) ) {
		MiiStationWrite(PHY_CNTL_REG,PHYHWADDR,PHY_FULLDUPLEX) ;
		gDuplexValue = FullDup ;
	}
	else 	MiiStationWrite(PHY_CNTL_REG,PHYHWADDR,0) ;
#endif
	}

	//MiiStationWrite(PHY_CNTL_REG, PHYHWADDR, ENABLE_AN | RESTART_AN); 
	//MiiStationWrite(PHY_CNTL_REG,PHYHWADDR,DR_100MB|PHY_FULLDUPLEX) ;
	//MiiStationWrite(PHY_CNTL_REG,PHYHWADDR,DR_100MB) ;
	//MiiStationWrite(PHY_CNTL_REG,PHYHWADDR,PHY_FULLDUPLEX) ;
	//MiiStationWrite(PHY_CNTL_REG,PHYHWADDR,0) ;
	//gDuplexValue = FullDup ;
}

/*
 * Function : MiiStationRead, MiiStationWrite  
 * Description : MII Interface Station Management Register Read or Write
 * Input : PhyInAddr(PHY internal register address)
 *         PhyAddr(PHY unique address)
 *         PhyWrData(When Write) 
 * Output: PhyRdData(WhenRead) 
 */
void MiiStationWrite(U32 PhyInAddr, U32 PhyAddr, U32 PhyWrData)
{
	STADATA = PhyWrData ;
	STACON = PhyInAddr | PhyAddr |  MiiBusy | PHYREGWRITE ;
	while( (STACON & MiiBusy) )  ;
	delay_physet() ;
}
U32 MiiStationRead(U32 PhyInAddr, U32 PhyAddr) 
{
	U32	PhyRdData ;
	STACON = PhyInAddr | PhyAddr |  MiiBusy ;
	while( (STACON & MiiBusy) )  ;
	PhyRdData = STADATA ;
	return PhyRdData ;
}

void delay_physet(void) 
{
	int i=1000 ;
	while(i--) ;
}


/*

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美二区三区| 亚洲成人久久影院| 免费一级片91| 欧美视频精品在线| av电影天堂一区二区在线观看| 伊人一区二区三区| 欧美性猛交xxxx乱大交退制版| 懂色一区二区三区免费观看| 美女视频一区在线观看| 粉嫩aⅴ一区二区三区四区五区| 丁香婷婷综合色啪| 日韩av午夜在线观看| 国产精品区一区二区三| 久久亚洲精品国产精品紫薇| 欧美日韩成人综合| 在线观看视频欧美| 欧美三级在线播放| 久久夜色精品国产噜噜av| 亚洲天堂成人网| 天天操天天综合网| av一区二区三区在线| 欧美日韩成人一区| 久久亚洲精精品中文字幕早川悠里| www激情久久| 综合久久给合久久狠狠狠97色 | 亚洲综合激情另类小说区| 婷婷丁香激情综合| 国产精品一二三四| 欧美日韩免费高清一区色橹橹 | 成人一区在线看| 在线视频中文字幕一区二区| 亚洲国产成人一区二区三区| 国产亲近乱来精品视频| 国产精品久久久一区麻豆最新章节| 激情综合网激情| 精品美女在线观看| 亚洲va在线va天堂| 欧美性欧美巨大黑白大战| 国产精品白丝在线| 在线视频国内自拍亚洲视频| 国产精品久久777777| 99久久久久久| 欧美一区二区三区爱爱| 天天色天天爱天天射综合| 色综合咪咪久久| 欧美伊人精品成人久久综合97 | 久久国产福利国产秒拍| 亚洲欧美日韩国产成人精品影院| 在线一区二区三区四区五区 | 91高清视频免费看| 欧美精品一区二区在线播放| 麻豆精品在线视频| 欧美日高清视频| 亚洲午夜精品久久久久久久久| 午夜精品久久一牛影视| 91网页版在线| 欧美性三三影院| 成人免费视频免费观看| 五月婷婷综合激情| 日韩三级av在线播放| 麻豆精品在线观看| 亚洲国产精品欧美一二99| 在线播放一区二区三区| 激情图区综合网| 久久九九99视频| 国产成人av电影在线| 久久久久久久久久久久电影| 国产精品免费丝袜| 成人午夜电影小说| 欧美视频中文字幕| 8v天堂国产在线一区二区| 国产精品一区二区三区乱码| 国产精品亲子伦对白| 天天操天天综合网| 欧美日产国产精品| 99麻豆久久久国产精品免费| 免费成人av在线| 一区二区三区成人| 国产精品网站导航| 国产精品久久久久影视| 中文字幕一区二区三区不卡 | 99国产欧美久久久精品| 久久久久久久综合狠狠综合| 亚洲女厕所小便bbb| 91视频在线观看免费| 国产在线不卡一卡二卡三卡四卡| 亚洲人快播电影网| 久久久久国产免费免费| 午夜精品久久久久久久99樱桃 | 亚洲人成伊人成综合网小说| 久久av中文字幕片| 国产真实精品久久二三区| 国产欧美日韩精品在线| 午夜久久久影院| 色婷婷av久久久久久久| 亚洲欧美国产三级| 成人妖精视频yjsp地址| 国产精品久久久久aaaa| 成人h动漫精品一区二区| 中文字幕在线一区免费| 欧美性色欧美a在线播放| 日韩中文字幕1| 国产精品人人做人人爽人人添| 久久女同性恋中文字幕| 黄页网站大全一区二区| 欧美优质美女网站| 视频一区在线视频| 中国av一区二区三区| 不卡在线视频中文字幕| 日韩高清电影一区| 国产偷国产偷亚洲高清人白洁| 国产精品一区二区久久精品爱涩| 亚洲欧美一区二区久久| 亚洲乱码国产乱码精品精可以看 | 国产视频视频一区| 91黄视频在线| 国产一区二区三区四区五区入口 | 一本到三区不卡视频| 午夜激情久久久| 久久综合狠狠综合久久激情| 99国产欧美另类久久久精品| 久久精品国产成人一区二区三区| 中文字幕欧美国产| 欧美日韩性生活| 国产乱码精品一区二区三区忘忧草| ●精品国产综合乱码久久久久 | 久久久久久影视| 在线观看免费亚洲| 国产不卡视频在线观看| 国产乱淫av一区二区三区 | 欧美激情艳妇裸体舞| 91福利社在线观看| 一本色道久久综合亚洲91 | 国产午夜久久久久| 久久se这里有精品| 日韩欧美激情在线| 制服丝袜亚洲播放| 日本韩国欧美在线| 亚洲精品写真福利| 久久美女高清视频 | 美腿丝袜在线亚洲一区| 免费在线看成人av| 18欧美亚洲精品| 亚洲男人的天堂一区二区 | 国产日韩精品一区| 国产精品国产三级国产a | 成人一区在线观看| 精品99久久久久久| 91精品国产综合久久婷婷香蕉| 欧美色视频在线观看| 中文字幕一区日韩精品欧美| 美女视频一区在线观看| 国产午夜亚洲精品羞羞网站| 91福利在线导航| 激情成人综合网| 午夜精品久久久久久不卡8050| 日韩av网站在线观看| 精品一区免费av| 欧美精品一区二区三| 久久99精品国产麻豆不卡| 欧美一区午夜视频在线观看 | 欧美在线综合视频| 一区二区视频免费在线观看| 国产伦精品一区二区三区在线观看| 欧美日韩国产高清一区二区三区 | 91在线精品一区二区| 欧美一级一区二区| 亚洲色图欧美激情| 成人av电影在线观看| 国产欧美精品一区二区色综合| 国产福利视频一区二区三区| 成人免费看视频| 最新欧美精品一区二区三区| 麻豆视频一区二区| 精品国产一区二区亚洲人成毛片| 亚洲综合一区二区三区| 色婷婷综合久色| 亚洲欧美日韩成人高清在线一区| 亚洲五码中文字幕| 欧美精品色一区二区三区| 美国十次综合导航| 日韩精品一区二区三区视频播放 | 日本aⅴ亚洲精品中文乱码| 日韩精品资源二区在线| 亚洲精品日韩综合观看成人91| 99久久99久久综合| 五月天一区二区| 91亚洲大成网污www| 亚洲综合色噜噜狠狠| 日韩欧美二区三区| 欧洲亚洲国产日韩| 久久精品免费观看| 成人免费在线视频观看| 精品三级在线观看| 欧美午夜在线观看| 激情久久五月天| 日本aⅴ精品一区二区三区 | 国产99一区视频免费| 国产精品无遮挡| 日韩区在线观看|