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

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

?? cfw.c

?? windows ce 50 drive program
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.
Copyright (c) 2001. Samsung Electronics, co. ltd  All rights reserved.
--*/

#include "windows.h"
#include "nkintr.h"
#include "oalintr.h"
#include "shx.h"
#include "p2.h"
#include "p2debug.h"
#include "tchaud.h"
#include "drv_glob.h"
#include <memory.h>
#ifdef MODULE_CERTIFY
#include "key1024.c"    // OEMLoadInit/OEMLoadModule implementation and the public key used for module signature verification.
#endif
//#include "timer.h"
#include <S2440.h>
#include <pehdr.h>
#include <romldr.h>


extern const unsigned short ScreenBitmap[];

/*
    @doc    EXTERNAL KERNEL HAL

    @module cfwp2.c - P2 HW Support | 
        OEM support Functions for the Windows CE P2 Platform.
    
    @xref <f OEMInit> <f OEMInterruptEnable> <f OEMInterruptDisable> 
          <f OEMInterruptDone> <l HAL Overview.Windows CE Kernel OEM Interface>
          
    @topic Windows CE Kernel OEM Interface |
          This defines the HAL layer - OEM and platform dependent pieces of
          code which we expect the OEM to deliver to us. There are three pieces
          of OEM deliverable code  - the bootstrap loader & monitor (for 
          debugging), the HAL portions which are interfaces between the kernel
          and the firmware, and the driver interface. This topic covers just 
          the HAL portion.

          The philosophy is to keep the HAL layer as simple as possible.  The 
          HAL should not be confused with the machine or CPU independence. HAL 
          is specific for a particular CPU and platform. It includes interfaces 
          for the following devices:<nl>
          Real Time Clock<nl>
          Interval Timer (used for the scheduler operation) <nl>
          Interrupt handlers and support <nl>

          Note that it does not include abstractions for devices like the DMA 
          controller etc. since the kernel does not use one. Also note that the
          list could change for different CPU's and platforms - for instance, 
          some chips might include a lot of peripheral devices (like the 
          interval timer) on the CPU chip itself, removing the need for a 
          separate interface for them.

          The interfaces for the real time clock and interval timer are still 
          being developed. But they should in general be extremely simple and
          straightforward. For details on the interrupt support model in the 
          kernel look at <l Interrupt Support Overview.Kernel Interrupt Support>

    @xref <l Interrupt Support Overview.Kernel Interrupt Support>
          <f OEMInit> <f OEMInterruptEnable> <f OEMInterruptDisable> 
          <f OEMInterruptDone> <f HookInterrupt>
             
 */


unsigned long OEMClockFreq;				// OEM clock frequency is used only in OAL

//
// Kernel global variables used by GetIdleTime( ) to determine CPU utilization
//
extern DWORD idleconv; 					// translation constant in 1 ms units
extern DWORD curridlehigh, curridlelow;	// 64-bit idle time in ms

extern int P2ISR();
extern void InitClock();
extern void HalCpuInit();
extern void HalTimerInit();
extern void HalSleep(DWORD);

extern void TIMERINIT();
extern void InitDebugEther(void);

static void InitDisplay(void);
static void OEMInitInterrupts(void);
static void InitSDMMC(void);

typedef volatile WORD *PVWORD;    /* pointer to a volatile word */
typedef volatile DWORD *PVDWORD;    /* pointer to a volatile dword */


#define REG(base, id)   (*(PVWORD)((base)+(id)))
#define REG32(base, id)   (*(PVDWORD)((base)+(id)))

#define SDIO_FOR_100BD	0
/*
#if (CE_MAJOR_VER == 0x0003)
	//Cedar
	// The kernel exports...
	#ifdef AddrCurMSec
		// Some kernels export a pointer to the CurMSec variable.
		static volatile DWORD * pCurMSec  = (volatile DWORD *) AddrCurMSec;
		static volatile DWORD * pDiffMSec = (volatile DWORD *) AddrDiffMSec;
	#else
		extern volatile DWORD CurMSec;
		extern volatile DWORD DiffMSec;
		static volatile DWORD * pCurMSec = &CurMSec;
		static volatile DWORD * pDiffMSec = &DiffMSec;
	#endif

	extern DWORD dwSleepMin;
	extern DWORD dwPartialDiffMSec;
	extern DWORD ticksleft;

#else
// dougfir or later
//
	#ifdef AddrCurMSec
		// Some kernels export a pointer to the CurMSec variable.
		static volatile DWORD * pCurMSec  = (volatile DWORD *) AddrCurMSec;
	#else
		extern volatile DWORD CurMSec;
		static volatile DWORD * pCurMSec = &CurMSec;
	#endif
	
extern DWORD dwReschedTime;
#endif
*/

// dougfir or later
//
	#ifdef AddrCurMSec
		// Some kernels export a pointer to the CurMSec variable.
		static volatile DWORD * pCurMSec  = (volatile DWORD *) AddrCurMSec;
	#else
		extern volatile DWORD CurMSec;
		static volatile DWORD * pCurMSec = &CurMSec;
	#endif
	
extern DWORD dwReschedTime;


extern BOOL fIntrTime;
extern BOOL bProfileTimerRunning;

volatile ULARGE_INTEGER CurTicks = { 0, 0 };
volatile ULARGE_INTEGER * pCurTicks = &CurTicks;

extern DWORD dwReschedIncrement;
extern DWORD OEMCount1ms;
//extern void Camera_Initialize(void);


#define NOT_FIXEDUP		   (DWORD*)-1
DWORD *pdwXIPLoc = NOT_FIXEDUP;
extern  ROMChain_t         *OEMRomChain;

/*
    @func   void | InitRomChain | Collects chain information for all image regions for the kernel.
    @rdesc  N/A.
    @comm    
    @xref   
*/
/*
void InitRomChain(void)
{
	static		ROMChain_t	s_pNextRom[MAX_ROM] = {0};
	DWORD		dwRomCount = 0;
    DWORD       dwChainCount = 0;
    DWORD		*pdwCurXIP;
    DWORD       dwNumXIPs;
    PXIPCHAIN_ENTRY pChainEntry = NULL;

    if(pdwXIPLoc == NOT_FIXEDUP)
	{
        return;  // no chain or not fixed up properly
    }

    // set the top bit to mark it as a virtual address
    pdwCurXIP = (DWORD*)(((DWORD)pdwXIPLoc) | 0x80000000);

    // first DWORD is number of XIPs
    dwNumXIPs = (*pdwCurXIP);

    if(dwNumXIPs > MAX_ROM)
	{
      lpWriteDebugStringFunc(TEXT("ERROR: Number of XIPs exceeds MAX\n"));
      return;
    }

    pChainEntry = (PXIPCHAIN_ENTRY)(pdwCurXIP + 1);

    while(dwChainCount < dwNumXIPs)
    {
        if ((pChainEntry->usFlags & ROMXIP_OK_TO_LOAD) &&  // flags indicates valid XIP
            *(LPDWORD)(((DWORD)(pChainEntry->pvAddr)) + ROM_SIGNATURE_OFFSET) == ROM_SIGNATURE)
        {
            s_pNextRom[dwRomCount].pTOC = *(ROMHDR **)(((DWORD)(pChainEntry->pvAddr)) + ROM_SIGNATURE_OFFSET + 4);
            s_pNextRom[dwRomCount].pNext = NULL;

            if (dwRomCount != 0)
            {
                s_pNextRom[dwRomCount-1].pNext = &s_pNextRom[dwRomCount];
            }
            else
            {
                OEMRomChain = s_pNextRom;
            }
            dwRomCount++;
        }
        else
        {
            lpWriteDebugStringFunc( _T("Invalid XIP found\n") );
        }

        ++pChainEntry;
		dwChainCount++;
	}
}
*/

#define FROM_BCD(n)		((((n) >> 4) * 10) + ((n) & 0xf))


//------------------------------------------------------------------------------
//
//  @func   void | OEMInit | Initialize Hardware Interfaces
//  @rdesc  none
//  @comm   OEMInit is called by the kernel after it has performed minimal
//          initialization. Interrupts are disabled and the kernel is not
//          ready to handle exceptions. The only kernel service available
//          to this function is <f HookInterrupt>. This should be used to 
//          install ISR's for all the hardware interrupts to be handled by
//          the firmware. Note that ISR's must be installed for any interrupt
//          that is to be routed to a device driver - otherwise the 
//          <f InterruptInitialize> call from the driver will fail.
//  @xref   <l Overview.Windows CE Kernel OEM Interface> <f HookInterrupt>
//          <f InterruptInitialize>
//            
//------------------------------------------------------------------------------
void OEMInit()  
{
	volatile IOPreg *s2440IOP = (IOPreg *)IOP_BASE;

	// Instead of calling OEMWriteDebugString directly, call through exported
	// function pointer.  This will allow these messages to be seen if debug
	// message output is redirected to Ethernet or the parallel port.  Otherwise,
	// lpWriteDebugStringFunc == OEMWriteDebugString.
	lpWriteDebugStringFunc(TEXT("\nWindows CE Firmware Init\r\n"));


#ifdef MODULE_CERTIFY
	//
	// Set the module signature verification hooks
	//
	pOEMLoadInit   = OEMLoadInit;
	pOEMLoadModule = OEMLoadModule;
	//
	// Init the signature verification public key
	//
	InitPubKey(g_bSignPublicKeyBlob,sizeof(g_bSignPublicKeyBlob));
#endif

    //
    // Set up translation constant for GetIdleTime() (1 ms units).
    // Note: Since curridlehigh, curridlelow is counting in ms, and GetIdleTime()
    // reports in ms, the conversion ratio is one.  If curridlehigh, curridlelow
    // were using other units (like ticks), then the conversion would be calculated
    // from the clock frequency.
    //
    idleconv = 1;

	// Initialize interrupts.
	//
    lpWriteDebugStringFunc(TEXT("INFO: Initializing system interrupts...\r\n"));
	OEMInitInterrupts();

	// Initialize the system clock(s).
	//
    lpWriteDebugStringFunc(TEXT("INFO: Initializing system clock(s)...\r\n"));
    InitClock();

    // Initialize driver globals area.
	//
    lpWriteDebugStringFunc(TEXT("INFO: Initializing driver globals area...\r\n"));
    memset((PVOID)DRIVER_GLOBALS_ZEROINIT_START, 0, DRIVER_GLOBALS_ZEROINIT_SIZE);
    
    // Initialize S2440X01 LCD controller
	InitDisplay();
	
    // Initialize debug Ethernet (KITL) connection.
    //
	// InitDebugEther();	
 
	// Initialize GPIO	/// ;;; SHL
	s2440IOP->rPAD9 = (1<<12) | (0<<11);
	//s2440IOP->rGPJCON = 0x016aaaa;
	//s2440IOP->rGPJUP  = ~((0<<12) | (1<<11));

	s2440IOP->rGPHCON = (s2440IOP->rGPHCON & ~(0xf<<18)) | (1<<20) | (1<<18);	// CLKOUT1, CLKOUT0

	s2440IOP->rDSC0 = 0x3ff;
	s2440IOP->rDSC1 = 0x3fffffff;

	// camera
	//Camera_Initialize();
	//s2440IOP->rGPJCON = 0x2aaaaaa;
	//s2440IOP->rGPJUP  = 0x1fff;

	InitSDMMC();

	// led(GPB5,6,7,8)
	s2440IOP->rGPBCON  = (s2440IOP->rGPBCON  &~(3 << 10)) | (1<< 10);	// GPB5 == OUTPUT.
	s2440IOP->rGPBCON  = (s2440IOP->rGPBCON  &~(3 << 12)) | (1<< 12);	// GPB6 == OUTPUT.
	s2440IOP->rGPBCON  = (s2440IOP->rGPBCON  &~(3 << 14)) | (1<< 14);	// GPB7 == OUTPUT.
	s2440IOP->rGPBCON  = (s2440IOP->rGPBCON  &~(3 << 16)) | (1<< 16);	// GPB8 == OUTPUT.
	//led off
	s2440IOP->rGPBDAT=s2440IOP->rGPBDAT|(0x1<<5)|(0x1<<6)|(0x1<<7)|(0x1<<8);
	
	// Initialize the ROM chain (multi-region).
	//
//	InitRomChain();
	lpWriteDebugStringFunc(TEXT("OEMInit Done...\r\n"));

}


//------------------------------------------------------------------------------
//  
//  @func   BOOL | OEMInterruptEnable | Enable a hardware interrupt
//  @rdesc  Returns TRUE if valid interrupt ID or FALSE if invalid ID.
//  @comm   This function is called by the Kernel when a device driver
//          calls <f InterruptInitialize>. The system is not preemptible when this
//          function is called.
//  @xref   <l Overview.Windows CE Kernel OEM Interface> <f InterruptInitialize>
//  
//------------------------------------------------------------------------------
BOOL 
OEMInterruptEnable(DWORD  idInt,	// @parm Interrupt ID to be enabled. See <l Interrupt ID's.Interrupt ID's>  for a list of possble values.
				   LPVOID pvData,	// @parm ptr to data passed in in the <f InterruptInitialize> call
		           DWORD  cbData)	// @parm Size of data pointed to be <p pvData>
{
	volatile INTreg *s2440INT = (INTreg *)INT_BASE;
	volatile IOPreg *s2440IOP = (IOPreg *)IOP_BASE;
	volatile MMCreg *s2440SDIO = (MMCreg *)MMC_BACE;
	BOOL bRet = TRUE;

	INTERRUPTS_OFF();
	
	switch (idInt) 
	{
	case SYSINTR_VMINI:		// Vmini.
		//return (TRUE);
		break;

	case SYSINTR_BREAK:		// There is no halt button on P2.
		//return(FALSE);
        break;


    case SYSINTR_DMA0:
        s2440INT->rINTMSK &= ~BIT_DMA0; // SDIO DMA interrupt
		//RETAILMSG(1,(TEXT("::: SYSINTR_DMA0    OEMInterruptDisable\r\n")));
       	break;

	case SYSINTR_SDMMC:
		s2440INT->rINTMSK &= ~BIT_MMC;
		//RETAILMSG(1,(TEXT("::: SYSINTR_SDMMC    OEMInterruptDisable\r\n")));
		break;        

	case SYSINTR_SDMMC_SDIO_INTERRUPT:
		s2440INT->rINTMSK &= ~BIT_MMC;
		//RETAILMSG(1,(TEXT("::: SYSINTR_SDMMC_SDIO_INTERRUPT    OEMInterruptEnable\r\n")));		
		break;

	case SYSINTR_SDMMC_CARD_DETECT:
#if SDIO_FOR_100BD		// for b'd revision 1.00
		s2440IOP->rEINTPEND  = (1 << 18);
		s2440IOP->rEINTMASK &= ~(1 << 18);
		//s2440INT->rSRCPND	= BIT_EINT8_23;
		// if (s2440INT->rINTPND & BIT_EINT8_23) 
	
		// s2440INT->rINTMSK  &= ~BIT_EINT8_23;
		//RETAILMSG(1,(TEXT("::: SYSINTR_SDMMC_CARD_DETECT    OEMInterruptEnable\r\n")));
#else					// for b'd revision 0.17
		s2440IOP->rEINTPEND  = (1 << 16);
		s2440IOP->rEINTMASK &= ~(1 << 16);  
#endif
		s2440INT->rSRCPND = BIT_EINT8_23;
		s2440INT->rINTPND = BIT_EINT8_23;
		s2440INT->rINTMSK &= ~BIT_EINT8_23;

		break;     

    case SYSINTR_TOUCH:
		//RETAILMSG(0,(TEXT("OEMInterruptEnable:TOUCH\n\r\n")));
        break;
	
    case SYSINTR_TOUCH_CHANGED:
		//RETAILMSG(0,(TEXT("OEMInterruptEnable:TOUCH CHANGED\r\n\r\n")));
		s2440INT->rINTMSK &= ~BIT_ADC;
		s2440INT->rINTSUBMSK &= ~INTSUB_TC;
        break;

	case SYSINTR_KEYBOARD:	// Keyboard on EINT1.
/*
		s2440INT->rSRCPND  = BIT_EINT1;
		// S3C2440X Developer Notice (page 4) warns against writing a 1 to a 0 bit in the INTPND register.
		if (s2440INT->rINTPND & BIT_EINT1) s2440INT->rINTPND = BIT_EINT1;
*/
		s2440INT->rINTMSK &= ~BIT_EINT1;
		break;

	case SYSINTR_SERIAL:	// Serial port.
		s2440INT->rSUBSRCPND  = (INTSUB_RXD0 | INTSUB_TXD0 | INTSUB_ERR0);
		s2440INT->rINTSUBMSK &= ~INTSUB_RXD0;
		s2440INT->rINTSUBMSK &= ~INTSUB_TXD0;
		s2440INT->rINTSUBMSK &= ~INTSUB_ERR0;
		s2440INT->rSRCPND     = BIT_UART0;
		// S3C2440X Developer Notice (page 4) warns against writing a 1 to a 0 bit in the INTPND register.
		if (s2440INT->rINTPND & BIT_UART0) s2440INT->rINTPND = BIT_UART0;
		s2440INT->rINTMSK    &= ~BIT_UART0;
		break;

	case SYSINTR_SERIAL2:  
    		s2440INT->rSUBSRCPND  = (INTSUB_RXD1 | INTSUB_TXD1 | INTSUB_ERR1); 
    		s2440INT->rINTSUBMSK &= ~INTSUB_RXD1; 
    		s2440INT->rINTSUBMSK &= ~INTSUB_TXD1; 
    		s2440INT->rINTSUBMSK &= ~INTSUB_ERR1; 
    		s2440INT->rSRCPND     = BIT_UART1; 
    		// S3C2440X Developer Notice (page 4) warns against writing a 1 to a 0 bit in the INTPND register. 
    		if (s2440INT->rINTPND & BIT_UART1) s2440INT->rINTPND = BIT_UART1; 
    		s2440INT->rINTMSK    &= ~BIT_UART1; 
    		break; 

	case SYSINTR_SERIAL3:  
		s2440INT->rSUBSRCPND  = (INTSUB_RXD2 | INTSUB_TXD2 | INTSUB_ERR2);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国模套图日韩精品一区二区| 91欧美一区二区| 亚洲桃色在线一区| 日韩你懂的在线播放| 91原创在线视频| 国产老肥熟一区二区三区| 丝袜国产日韩另类美女| 亚洲三级免费观看| 国产欧美精品一区二区三区四区| 欧美老肥妇做.爰bbww| 91丝袜国产在线播放| 国产美女视频91| 久久精品免费观看| 亚洲国产另类av| 亚洲精品国久久99热| 久久久久88色偷偷免费| 日韩一级成人av| 正在播放亚洲一区| 欧美日韩精品免费| 在线一区二区观看| www.66久久| 懂色av中文一区二区三区| 韩国欧美国产一区| 久久狠狠亚洲综合| 久久精品国产亚洲5555| 天天综合网天天综合色| 亚洲一区二区在线免费观看视频 | 欧美亚洲一区三区| 色综合久久天天综合网| 成年人网站91| 成人毛片在线观看| 高清不卡一区二区在线| 国产精品羞羞答答xxdd| 国产成人久久精品77777最新版本| 精品一区二区久久| 国产一区免费电影| 国产精品资源在线观看| 国产成a人亚洲精| 风间由美中文字幕在线看视频国产欧美| 国产一区二区三区蝌蚪| 国产91精品在线观看| 成人性生交大合| 丰满放荡岳乱妇91ww| 粉嫩欧美一区二区三区高清影视| 国产suv精品一区二区6| 成人的网站免费观看| 粉嫩在线一区二区三区视频| 69堂精品视频| 欧美老人xxxx18| 精品日本一线二线三线不卡 | 亚洲午夜久久久久久久久电影院 | 久久久美女毛片| 国产欧美精品国产国产专区| 中文字幕高清不卡| 亚洲视频免费观看| 伊人婷婷欧美激情| 日本在线播放一区二区三区| 麻豆精品视频在线观看免费| 国产另类ts人妖一区二区| 波多野结衣亚洲| 欧美网站大全在线观看| 欧美一区二区观看视频| 国产三级精品在线| 樱桃国产成人精品视频| 免费看日韩精品| 国产精品69毛片高清亚洲| 色呦呦一区二区三区| 制服丝袜中文字幕亚洲| 久久久综合激的五月天| 一区二区三区不卡视频| 日本不卡在线视频| 国产成人精品免费一区二区| 欧洲精品在线观看| 欧美成人r级一区二区三区| 一色屋精品亚洲香蕉网站| 亚洲国产精品久久久男人的天堂 | 91麻豆国产自产在线观看| 欧美日韩免费一区二区三区视频| 精品对白一区国产伦| 欧美国产精品中文字幕| 日日夜夜精品免费视频| 岛国精品一区二区| 7799精品视频| 国产精品国产精品国产专区不蜜 | 麻豆国产精品一区二区三区| 白白色 亚洲乱淫| 日韩欧美成人午夜| 一区二区三区中文在线| 国内精品写真在线观看| 欧美三级电影精品| 国产精品久久久久aaaa樱花 | 亚洲欧美一区二区三区极速播放 | 欧美日韩夫妻久久| 国产精品美女久久久久久久久| 日韩中文字幕一区二区三区| 成人精品高清在线| 亚洲电影视频在线| 成人精品gif动图一区| 日韩亚洲欧美在线| 亚洲妇熟xx妇色黄| 99精品视频一区| 久久久电影一区二区三区| 天天影视网天天综合色在线播放| 91视频xxxx| 国产精品少妇自拍| 精品一区二区在线观看| 91精品国产综合久久福利| 亚洲另类中文字| 成人av网址在线观看| 久久免费午夜影院| 久久精品72免费观看| 这里是久久伊人| 亚洲chinese男男1069| 色综合天天综合网国产成人综合天 | 日韩欧美亚洲国产另类| 午夜伦理一区二区| 91成人在线观看喷潮| 亚洲欧美欧美一区二区三区| 国产91精品一区二区麻豆亚洲| 久久尤物电影视频在线观看| 久久精品国产在热久久| 91精品视频网| 日韩电影在线观看网站| 欧美日韩国产高清一区二区三区| 亚洲一区二区精品3399| 欧美亚洲国产一区二区三区va| 亚洲人午夜精品天堂一二香蕉| av爱爱亚洲一区| 综合久久久久综合| 97久久超碰国产精品| 最新国产成人在线观看| 91看片淫黄大片一级在线观看| 日韩毛片一二三区| 色狠狠色狠狠综合| 亚洲综合999| 欧美日韩美少妇| 秋霞影院一区二区| 精品国产免费人成电影在线观看四季 | 欧美日韩三级视频| 五月婷婷另类国产| 日韩欧美的一区| 国产麻豆成人精品| 国产欧美久久久精品影院| 成人av高清在线| 亚洲综合一区二区三区| 9191成人精品久久| 激情成人午夜视频| 亚洲国产精品av| 色欧美片视频在线观看| 视频在线观看91| 精品国产髙清在线看国产毛片| 国产**成人网毛片九色| 自拍偷自拍亚洲精品播放| 精品视频免费在线| 久久精品久久综合| 国产精品人妖ts系列视频| 91美女在线观看| 日韩高清电影一区| 国产欧美视频在线观看| 国产清纯在线一区二区www| 成人av综合在线| 亚洲国产视频一区二区| 精品粉嫩超白一线天av| 成人av在线播放网站| 亚洲第一会所有码转帖| 2023国产精华国产精品| 91香蕉视频mp4| 轻轻草成人在线| 一区精品在线播放| 欧美电影一区二区| 国产成人免费在线视频| 一区二区三区四区五区视频在线观看 | www.66久久| 日韩不卡一二三区| 国产精品成人免费精品自在线观看| 欧美日韩午夜影院| 国产iv一区二区三区| 午夜视频一区二区三区| 日本一区二区视频在线| 在线成人av影院| 成人激情免费视频| 免费在线视频一区| 亚洲欧美日韩国产综合在线| 精品久久国产字幕高潮| 在线观看免费成人| 国产成人欧美日韩在线电影| 亚洲成人资源在线| 国产精品不卡在线| 日韩欧美123| 欧美私人免费视频| 成人网在线免费视频| 日韩高清一区在线| 亚洲麻豆国产自偷在线| 国产亚洲va综合人人澡精品 | 久久亚洲一区二区三区四区| 91成人免费在线| 不卡电影一区二区三区| 狠狠色丁香婷婷综合久久片| 亚洲在线视频免费观看| 中文字幕一区二区三|