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

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

?? macinit.c

?? 三星4510開發板Sdns100上代的演示程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*************************************************************************/
/*                                                                       */
/* 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--) ;
}


/*

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲人成人一区二区在线观看| 久久99精品久久久| 麻豆精品国产91久久久久久| 成人午夜视频在线观看| 欧美顶级少妇做爰| 中文字幕亚洲一区二区va在线| 麻豆精品在线视频| 欧美日本视频在线| 亚洲欧美另类图片小说| 国产精品1024| 欧美v日韩v国产v| 亚州成人在线电影| 99久久精品一区二区| 久久久91精品国产一区二区三区| 亚洲成人tv网| 日本精品免费观看高清观看| 久久九九久久九九| 久久99精品国产麻豆不卡| 欧美日韩久久一区二区| 亚洲久草在线视频| av在线播放不卡| 国产蜜臀97一区二区三区| 国内成+人亚洲+欧美+综合在线| 欧美高清视频一二三区 | 成人av动漫在线| 久久嫩草精品久久久精品一| 久久疯狂做爰流白浆xx| 欧美一区二区久久| 日韩精品福利网| 欧美电影影音先锋| 视频一区二区三区在线| 制服.丝袜.亚洲.另类.中文| 性做久久久久久久久| 欧美日韩一区二区三区免费看| 亚洲综合丝袜美腿| 欧美三级视频在线播放| 亚洲大尺度视频在线观看| 欧美日韩成人综合天天影院| 日本不卡免费在线视频| 日韩欧美一区电影| 国产一区二区精品在线观看| 久久精品亚洲一区二区三区浴池| 国产乱对白刺激视频不卡| 久久久精品tv| 色系网站成人免费| 亚洲成在线观看| 欧美大片在线观看| 丁香六月久久综合狠狠色| 中文字幕av一区二区三区高| 91一区二区三区在线播放| 亚洲制服欧美中文字幕中文字幕| 欧美午夜精品理论片a级按摩| 亚洲小少妇裸体bbw| 欧美日韩激情一区二区三区| 久久se精品一区精品二区| 久久综合中文字幕| 91丨porny丨在线| 日韩成人免费看| 国产欧美一区二区三区在线看蜜臀| caoporn国产一区二区| 亚洲美女少妇撒尿| 日韩欧美一区二区在线视频| 国产99久久精品| 一区二区三区在线免费观看| 在线播放亚洲一区| 国产成人av影院| 一区二区三区蜜桃| 欧美一级黄色录像| 成人精品小蝌蚪| 日日噜噜夜夜狠狠视频欧美人| 久久嫩草精品久久久精品| 欧美亚洲综合网| 久久国产乱子精品免费女| 国产精品成人免费在线| 欧美一级电影网站| 91丨porny丨最新| 狠狠久久亚洲欧美| 亚洲国产日日夜夜| 中文文精品字幕一区二区| 欧美日韩久久一区二区| 成人国产精品免费网站| 精品一区二区三区在线视频| 欧美韩日一区二区三区| 制服视频三区第一页精品| 国产成人精品免费在线| 久久精品99国产精品日本| 亚洲在线视频网站| 亚洲天堂久久久久久久| 精品国产91洋老外米糕| 欧美丝袜丝nylons| 91伊人久久大香线蕉| 国产成人精品一区二| 麻豆国产精品一区二区三区 | 久久一区二区三区四区| 欧美日韩你懂的| 色爱区综合激月婷婷| 北岛玲一区二区三区四区| 国产一区二区三区国产| 日本在线不卡视频一二三区| 亚洲精品国产高清久久伦理二区| 中文字幕的久久| 国产日韩在线不卡| 久久精品一区二区三区不卡牛牛| 欧美一区二区黄| 欧美精品三级在线观看| 欧洲人成人精品| 色综合天天天天做夜夜夜夜做| 高清视频一区二区| 粉嫩aⅴ一区二区三区四区| 极品瑜伽女神91| 久久99精品国产麻豆婷婷洗澡| 老色鬼精品视频在线观看播放| 天天综合天天综合色| 亚洲曰韩产成在线| 亚洲国产日韩a在线播放性色| 一区二区三区中文在线观看| 一区二区三区四区中文字幕| 一区二区三区日韩| 亚洲午夜av在线| 亚洲成人先锋电影| 天天综合天天综合色| 免费观看一级欧美片| 精品亚洲免费视频| 国产不卡视频一区二区三区| 成人黄色大片在线观看| 91丨porny丨国产| 91黄色小视频| 欧美日韩和欧美的一区二区| 欧美一区二区视频在线观看2022| 7777精品伊人久久久大香线蕉超级流畅 | 国产精品88av| 粉嫩一区二区三区性色av| 成人免费毛片片v| 97se亚洲国产综合在线| 日本久久电影网| 欧美午夜宅男影院| 欧美v日韩v国产v| 国产婷婷一区二区| 亚洲视频中文字幕| 午夜电影网亚洲视频| 久久国产人妖系列| 99久免费精品视频在线观看| 欧美三级电影一区| 26uuu亚洲综合色欧美| 久久久不卡影院| 亚洲自拍偷拍图区| 美女网站色91| 91在线一区二区| 制服丝袜av成人在线看| 国产午夜精品美女毛片视频| 悠悠色在线精品| 久久99九九99精品| 91免费版在线| 欧美成va人片在线观看| 最新中文字幕一区二区三区 | 精品一区二区在线看| 99国产精品视频免费观看| 欧美一区二区三区婷婷月色| 国产精品免费av| 婷婷中文字幕综合| 成人午夜激情在线| 91精品国产免费| 亚洲色图在线视频| 韩国视频一区二区| 欧美中文字幕一区二区三区亚洲| 26uuu亚洲| 亚洲a一区二区| 成人黄色国产精品网站大全在线免费观看 | 日韩午夜中文字幕| 亚洲欧美色一区| 国产精品一线二线三线精华| 欧美三级在线视频| 亚洲女厕所小便bbb| 国产在线精品一区二区不卡了| 欧美日韩免费电影| 亚洲欧美日韩电影| 成人一区二区三区视频在线观看| 欧美伦理视频网站| 一区二区欧美在线观看| 成人免费电影视频| 久久久不卡网国产精品一区| 日韩1区2区日韩1区2区| 欧亚一区二区三区| 亚洲欧美日韩国产另类专区 | 欧美日韩高清不卡| 亚洲免费av网站| 91网页版在线| 国产精品久久久久久久久动漫| 激情国产一区二区| 精品国产91亚洲一区二区三区婷婷 | 奇米777欧美一区二区| 欧美日韩性生活| 亚洲一区二区在线免费看| 97久久久精品综合88久久| 国产精品黄色在线观看| 国产精品一区专区| 久久嫩草精品久久久久| 国产精品乡下勾搭老头1| 久久久久久久久久久黄色| 久久成人18免费观看|