青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 54, comments - 32, trackbacks - 0, articles - 0

Wince 串口驅(qū)動詳解-未完

Posted on 2007-09-17 22:30 宋鵬 閱讀(6408) 評論(1)  編輯 收藏 引用 所屬分類: BSP & Platform Builder

1、(oalintr.h)注冊串口中斷
//SP-A1
/*
打開oalintr.h文件,我們添加一個新的串口,并定義中斷號。
添加:
//SP-A8沒什么說的就是注冊中斷
#define SYSINTR_SERIAL1  (SYSINTR_FIRMWARE+19)


這里,我們可以看到SYSINTR_SERIAL1定義到16+19=35=0x23,與注冊表中一致。
然后修改下這個地方:
MapIrq2SysIntr(DWORD _Irq)
{
   if( _Irq<=19 )
       return ( SYSINTR_FIRMWARE + _Irq );
   else
       return (0xffffffff);

*/

2、(armint.c)在ISR中進(jìn)行中斷判斷,中斷使能
//SP-A2
/*
//SP-A9其中IntPendVal= s2410INT->rINTOFFSET
//INTOFFSET是中斷偏移寄存器,顯示中斷請求源,跟SRCPND一樣//在IRQ模式中,該寄存器顯示INTPND寄存器中的中斷請求

搜索:else if(IntPendVal == INTSRC_UART0)
在其后面添加:

 //SP-A10此處進(jìn)行中斷請求源的判斷。INTSRC_UART1被定義為UART1的中斷號,即SRCPND==23
 else if(IntPendVal == INTSRC_UART1)
 {
   //SP-A11 SUBSRCPND中包含一些中斷請求的細(xì)節(jié),對于串口就是INT_ERR、INT_RXD、INT_TXD
   //用于進(jìn)一步判斷中斷類型
   SubIntPendVal = s2410INT->rSUBSRCPND;

   // Note that we only mask the sub source interrupt - the serial driver will clear the
   // sub source pending register.
   //
   //SP-A11.1如果是ERR1則該位置0,解除該位中斷屏蔽INTSUBMSK
   if(SubIntPendVal & INTSUB_ERR1)
   {
     s2410INT->rINTSUBMSK |= INTSUB_ERR1;
   }
   else if(SubIntPendVal & INTSUB_RXD1)  //SP-A11.2 RXD1,解除該位中斷屏蔽INTSUBMSK
   {
     s2410INT->rINTSUBMSK |= INTSUB_RXD1;
   }
   else if(SubIntPendVal & INTSUB_TXD1)  //SP-A11.3 TXD1,
   {
     s2410INT->rINTSUBMSK |= INTSUB_TXD1;
   }
   else
   {
     return(SYSINTR_NOP);   //SP-A11.4什么都沒發(fā)生
   }
 
   // NOTE: Don't clear INTSRC:UART1 here - serial driver does that.
   //
   //SP-A12解放對應(yīng)位的總中斷屏蔽,此時中斷請求IRQ已經(jīng)傳達(dá)給CPU
   s2410INT->rINTMSK |= BIT_UART1;

   //SP-A13 INTPND顯示哪個中斷處于非屏蔽且等待服務(wù)的狀態(tài),即“該中斷被確定了(asserted 1)”,“相對于pending(待定)”
   //現(xiàn)在判斷完成,即“該中斷被確定了,所以向它發(fā)1,將之置0,清除中斷請求
   if (s2410INT->rINTPND & BIT_UART1) s2410INT->rINTPND  = BIT_UART1;

   //SP-A14向Wince發(fā)出對應(yīng)的邏輯中斷處理請求
   return(SYSINTR_SERIAL1);
  
 }
*/

3、(cfw.c)在IST中進(jìn)行對應(yīng)中斷的使能和禁止
/*
//SP-A15此處是串行中斷初始化,將所有串行中斷屏蔽unmask,將所有串行中斷殘留pending清除。
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>
找到這一句:case SYSINTR_SERIAL:
在其后面添加:

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

//SP-A16此處是串行中斷禁止,即屏蔽所有串行中斷位
搜索:
void
OEMInterruptDisable(DWORD idInt)  // @parm Interrupt ID to be disabled. See <t Interrupt ID's>
還是這一句:case SYSINTR_SERIAL:
在其后面添加:

 case SYSINTR_SERIAL1:
   s2410INT->rINTMSK    |= BIT_UART1;
   s2410INT->rINTSUBMSK |= INTSUB_RXD1;
   s2410INT->rINTSUBMSK |= INTSUB_TXD1;
   s2410INT->rINTSUBMSK |= INTSUB_ERR1;
   break;

//SP-A17解除屏蔽?
搜索:
void
OEMInterruptDone(DWORD idInt)  // @parm Interrupt ID. See <t Interrupt ID's>
依舊找到case SYSINTR_SERIAL:
在其后面添加:

 case SYSINTR_SERIAL1:
   s2410INT->rINTMSK    &= ~BIT_UART1;
   s2410INT->rINTSUBMSK &= ~INTSUB_RXD1;
   break;

*/

4、(ser2410_hw.c)驅(qū)動程序進(jìn)行處理
//SP-A4
/*
打開串口源文件中ser2410_hw.c文件。
搜索:
S2410_SetSerialIOP(
      PVOID   pHead // @parm points to device head
      )
將其函數(shù)改為:

{
 //SP-A18 2410串口信息結(jié)構(gòu)體
 PS2410_UART_INFO   pHWHead   = (PS2410_UART_INFO)pHead;
 PSER_INFO     pHWHead1  = (PSER_INFO)pHead;

 RETAILMSG(DEBUGMODE, (TEXT("S2410_SetSerialIOP \r\n")));
 if(pHWHead1->dwIOBase == 0x50004000)  //SP-UART1 LINE CONTROL
 {
 #if USEVIRTUAL
   EnterCriticalSection(&(pHWHead->RegCritSec));
   v_pIOPregs->rGPHCON &= ~(0x3<<8 | 0x3<<10 /*| 0x3<<12 | 0x3<<14*/); // clear uart 1 - rx, tx
   v_pIOPregs->rGPHCON |= (0x2<<8 | 0x2<<10 /*| 0x1<<12 | 0x0<<14*/);
   v_pIOPregs->rGPHCON |= (0x2<<0 | 0x2<<2 );
   v_pIOPregs->rGPHUP  |= 0x03;
   pHWHead->rDTRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);
   pHWHead->rDSRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);
   pHWHead->DtrPortNum = 0;
   pHWHead->DsrPortNum = 1;
 #else
   volatile IOPreg *s2410IOP;
   s2410IOP   = (volatile IOPreg *)IOP_BASE;
 
   EnterCriticalSection(&(pHWHead->RegCritSec));
   //SP-A19 IO口設(shè)置
   s2410IOP->rGPHCON &= ~(0x3<<8 | 0x3<<10/* | 0x3<<12 | 0x3<<14*/); // clear uart 1 - rx, tx
   s2410IOP->rGPHCON |= (0x2<<8 | 0x2<<10 /*| 0x1<<12 | 0x0<<14*/);
   s2410IOP->rGPHCON |= (0x2<<0 | 0x2<<2 );
   s2410IOP->rGPHUP  |= 0x03;
   pHWHead->rDTRport = (volatile unsigned int *)(IOP_BASE+0x74); //s2410IOP->rGPHDAT
   pHWHead->rDSRport = (volatile unsigned int *)(IOP_BASE+0x74);
   pHWHead->DtrPortNum = 0;
   pHWHead->DsrPortNum = 1;
 #endif
 }
 else if(pHWHead1->dwIOBase == 0x50008000)  //SP-UART2 LINE CONTROL
 {
 #if USEVIRTUAL
   EnterCriticalSection(&(pHWHead->RegCritSec));
   v_pIOPregs->rGPHCON &= ~( 0x3<<12 | 0x3<<14); // clear uart 2 - rx, tx
   v_pIOPregs->rGPHCON |= ( 0x2<<12 | 0x2<<14);
   v_pIOPregs->rGPHCON |= (0x2<<0 | 0x2<<2 );
   v_pIOPregs->rGPHUP  &= ~0xc0;
   pHWHead->rDTRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);
   pHWHead->rDSRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);
   pHWHead->DtrPortNum = 0;
   pHWHead->DsrPortNum = 1;
 #else
   volatile IOPreg *s2410IOP;
   s2410IOP   = (volatile IOPreg *)IOP_BASE;
 
   EnterCriticalSection(&(pHWHead->RegCritSec));
   s2410IOP->rGPHCON &= ~(0x3<<12 | 0x3<<14); // clear uart 2 - rx, tx
   s2410IOP->rGPHCON |= ( 0x02<<12 | 0x02<<14);
   s2410IOP->rGPHCON |= (0x2<<0 | 0x2<<2 );
   s2410IOP->rGPHUP  &= ~0xc0;
   pHWHead->rDTRport = (volatile unsigned int *)(IOP_BASE+0x74); //s2410IOP->rGPHDAT
   pHWHead->rDSRport = (volatile unsigned int *)(IOP_BASE+0x74);
   pHWHead->DtrPortNum = 0;
   pHWHead->DsrPortNum = 1;
 #endif   
 }
 else       //SP-UART? LINE CONTROL
 {
 #if USEVIRTUAL
   EnterCriticalSection(&(pHWHead->RegCritSec));
   v_pIOPregs->rGPHCON &= ~(0x3<<0 | 0x3<<2 | 0x3<<4 | 0x3<<6/* | 0x3<<12 | 0x3<<14*/); // clear uart 0 - rx, tx
   v_pIOPregs->rGPHCON |= (0x2<<4 | 0x2<<6/* | 0x1<<12 | 0x0<<14*/);
   v_pIOPregs->rGPHCON |= (0x2<<0 | 0x2<<2 );
   v_pIOPregs->rGPHUP  |= 0x03;
   pHWHead->rDTRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);
   pHWHead->rDSRport = (volatile unsigned int *)&(v_pIOPregs->rGPHDAT);
   pHWHead->DtrPortNum = 0;
   pHWHead->DsrPortNum = 1;
 #else
   volatile IOPreg *s2410IOP;
   s2410IOP   = (volatile IOPreg *)IOP_BASE;
 
   EnterCriticalSection(&(pHWHead->RegCritSec));
   s2410IOP->rGPHCON &= ~(0x3<<0 | 0x3<<2 | 0x3<<4 | 0x3<<6 /*| 0x3<<12 | 0x3<<14*/); // clear uart 0 - rx, tx
   s2410IOP->rGPHCON |= (0x2<<4 | 0x2<<6 /*| 0x1<<12 | 0x0<<14*/);
   s2410IOP->rGPHCON |= (0x2<<0 | 0x2<<2 );
   s2410IOP->rGPHUP  |= 0x03;
   pHWHead->rDTRport = (volatile unsigned int *)(IOP_BASE+0x74); //s2410IOP->rGPHDAT
   pHWHead->rDSRport = (volatile unsigned int *)(IOP_BASE+0x74);
   pHWHead->DtrPortNum = 0;
   pHWHead->DsrPortNum =1;
 #endif
 }
 LeaveCriticalSection(&(pHWHead->RegCritSec));
}


接著搜索:
SL_Init(
      PVOID   pHead, // @parm points to device head
      PUCHAR  pRegBase, // Pointer to 16550 register base
      UINT8   RegStride, // Stride amongst the 16550 registers
      EVENT_FUNC EventCallback, // This callback exists in MDD
      PVOID   pMddHead,   // This is the first parm to callback
      PLOOKUP_TBL   pBaudTable  // BaudRate Table
      )
在PS2410_UART_INFO   pHWHead   = (PS2410_UART_INFO)pHead;這一句后面添加:

PSER_INFO     pHWHead1  = (PSER_INFO)pHead;


再搜索:
 if ( pHWHead->UseIrDA )
 {
   pHWHead->bINT = BIT_UART2;
   pHWHead->bTxINT = INTSUB_TXD2;
   pHWHead->bRxINT = INTSUB_RXD2;
   pHWHead->bErrINT = INTSUB_ERR2;
#if USEVIRTUAL
   pHWHead->s2410SerReg = (S2410_UART_REG *)v_pUART2regs;
   pRegBase = (PUCHAR)pHWHead->s2410SerReg;
#else   
   pRegBase = (PUCHAR)UART2_BASE;
   pHWHead->s2410SerReg = (S2410_UART_REG *)pRegBase;
#endif
 }
 else
 {
 把這其中的代碼修改為以下代碼
 }

   if(pHWHead1->dwIOBase == 0x50004000)
   {
     pHWHead->bINT = BIT_UART1;
     pHWHead->bTxINT = INTSUB_TXD1;
     pHWHead->bRxINT = INTSUB_RXD1;
     pHWHead->bErrINT = INTSUB_ERR1;
   #if USEVIRTUAL
     pHWHead->s2410SerReg = (S2410_UART_REG *)v_pUART1regs;
     pRegBase = (PUCHAR)pHWHead->s2410SerReg;
   #else   
     pRegBase = (PUCHAR)UART1_BASE;
     pHWHead->s2410SerReg = (S2410_UART_REG *)pRegBase;
   #endif
    
   }
   else if(pHWHead1->dwIOBase == 0x50008000)
   {
     pHWHead->bINT = BIT_UART2;
     pHWHead->bTxINT = INTSUB_TXD2;
     pHWHead->bRxINT = INTSUB_RXD2;
     pHWHead->bErrINT = INTSUB_ERR2;
   #if USEVIRTUAL
     pHWHead->s2410SerReg = (S2410_UART_REG *)v_pUART2regs;
     pRegBase = (PUCHAR)pHWHead->s2410SerReg;
   #else   
     pRegBase = (PUCHAR)UART2_BASE;
     pHWHead->s2410SerReg = (S2410_UART_REG *)pRegBase;
   #endif
   }
   else
   {
    
     pHWHead->bINT = BIT_UART0;
     pHWHead->bTxINT = INTSUB_TXD0;
     pHWHead->bRxINT = INTSUB_RXD0;
     pHWHead->bErrINT = INTSUB_ERR0;
   #if USEVIRTUAL
     pHWHead->s2410SerReg = (S2410_UART_REG *)v_pUART0regs;
     pRegBase = (PUCHAR)pHWHead->s2410SerReg;
   #else   
     pRegBase = (PUCHAR)UART0_BASE;
     pHWHead->s2410SerReg = (S2410_UART_REG *)pRegBase;
   #endif
   }


再搜索:
 if ( pHWHead->UseIrDA )
 {
   pHWHead->pUFTXH = (volatile unsigned char *)&(v_pUART2regs->rUTXH);
   pHWHead->pUFRXH = (volatile unsigned char *)&(v_pUART2regs->rURXH);   
 }
 else
 {
 把這其中的代碼修改為以下代碼
 }

   if(pHWHead1->dwIOBase == 0x50004000)
   {
     pHWHead->pUFTXH = (volatile unsigned char *)&(v_pUART1regs->rUTXH);
     pHWHead->pUFRXH = (volatile unsigned char *)&(v_pUART1regs->rURXH);
   }
   else if(pHWHead1->dwIOBase == 0x50008000)
   {
     pHWHead->pUFTXH = (volatile unsigned char *)&(v_pUART2regs->rUTXH);
     pHWHead->pUFRXH = (volatile unsigned char *)&(v_pUART2regs->rURXH);      
   }
   else
   {
     pHWHead->pUFTXH = (volatile unsigned char *)&(v_pUART0regs->rUTXH);
     pHWHead->pUFRXH = (volatile unsigned char *)&(v_pUART0regs->rURXH);   
   }

*/

5、(ser2410_ser.c)驅(qū)動程序進(jìn)一步處理
//SP-A4
*/
搜索:
const HWOBJ IoObj = {
 THREAD_AT_INIT,
 SYSINTR_SERIAL,
 (PHW_VTBL) &IoVTbl
};
在其后面添加:

const HWOBJ Io1Obj = {
 THREAD_AT_INIT,
 SYSINTR_SERIAL1,
 (PHW_VTBL) &IoVTbl
};

const HWOBJ Io2Obj = {
 THREAD_AT_INIT,
 SYSINTR_IR,
 (PHW_VTBL) &IoVTbl
};


接著搜索:
const PCHWOBJ HWObjects[] = {
 &IoObj,
 &IrObj
};
將其修改為:

const PCHWOBJ HWObjects[] = {
 &IoObj,
 &Io1Obj,
 &Io2Obj
};


再搜索:
GetSerialObject(
              DWORD DeviceArrayIndex
              )
將其函數(shù)改為:

{
 PHWOBJ pSerObj;

 DEBUGMSG(DEBUGMODE,(TEXT("GetSerialObject : DeviceArrayIndex = %d\r\n"), DeviceArrayIndex));

 // Now return this structure to the MDD.
 if ( DeviceArrayIndex == 2 )
 { 
   RETAILMSG(1,(TEXT("GetSerialObject Io2Obj\r\n")));
   pSerObj = (PHWOBJ)(&Io2Obj);
 }
 else if(DeviceArrayIndex == 1)
   pSerObj = (PHWOBJ)(&Io1Obj);
 else
   pSerObj = (PHWOBJ)(&IoObj);

 return (pSerObj);
}
*/

6、在CEC中增加特性
//SP-A6
/*
添加UART1這個feature。
搜索
ComponentType
(
 Name ( "Serial" )
 GUID ( {6563AD6C-E71C-11D4-B892-0050FC049781} )
 MaxResolvedImpsAllowed( 999 )
 Implementations
 (
   Implementation
   (
     Name ( "S32410 Serial UART" )
在其后面添加:

   Implementation 
   (
     Name ( "S32410 Serial UART1" )
     GUID ( {7C4427A5-286C-4C7A-B687-4E3B364D079B} )
     Description ( "Samsung S32410 serial UART controller." )
     BSPPlatformDir ( "smdk2410" )
     Version ( "5.0.0.0" )
     Locale ( 0409 )
     Vendor ( "Microsoft" )
     Date ( "2003-1-13" )
     SizeIsCPUDependent( 1 )
     BuildMethods
     (
       BuildMethod
       (
         GUID ( {07DA2083-6261-4ED6-B5BB-70CF4D930D68} )
         Step ( BSP )
         CPU ( "ARMV4" )
         CPU ( "ARMV4I" )
         Action ( '#BUILD(SOURCES,"$(_WINCEROOT)\PLATFORM\SMDK2410\drivers\serial")')
        )
     )
   )
*/

7、修改注冊表
//SP-A7
/*
打開platform.reg文件,這個是WinCE注冊表文件,在這里,我們要修改并添加串口。
搜索:[HKEY_LOCAL_MACHINE\Drivers\BuiltIn\SER2410],這就是串口1。
將其下面的鍵值改為:

[HKEY_LOCAL_MACHINE\Drivers\BuiltIn\SER2410]
  "DeviceArrayIndex"=dword:0
  "Irq"=dword:13
  "IoBase"=dword:50000000
  "IoLen"=dword:2C
  "Prefix"="COM"
  "Dll"="SER2410.Dll"
  "Order"=dword:0
  "Priority"=dword:0
  "Port"="COM1:"
  "DeviceType"=dword:0
  "FriendlyName"="Serial Cable on COM1:"
  "Tsp"="Unimodem.dll"
  "DevConfig"=hex: 10,00, 00,00, 05,00,00,00, 10,01,00,00, 00,4B,00,00, 00,00, 08, 00, 00, 00,00,00,00


再在其后面添加串口2:

[HKEY_LOCAL_MACHINE\Drivers\BuiltIn\SER2410_2]
  "DeviceArrayIndex"=dword:1
  "Irq"=dword:23
  "IoBase"=dword:50004000
  "IoLen"=dword:2C
  "Prefix"="COM"
  "Dll"="SER2410.Dll"
  "Order"=dword:1
  "Priority"=dword:0
  "Port"="COM2:"
  "DeviceType"=dword:0
  "FriendlyName"="Serial Cable on COM2:"
  "Tsp"="Unimodem.dll"
  "DevConfig"=hex: 10,00, 00,00, 05,00,00,00, 10,01,00,00, 00,4B,00,00, 00,00, 08, 00, 00, 00,00,00,00

[HKEY_LOCAL_MACHINE\Drivers\BuiltIn\SER2410_2\Unimodem]
  "Tsp"="Unimodem.dll"
  "DeviceType"=dword:0
  "FriendlyName"="SER2410_2 UNIMODEM"
  "DevConfig"=hex: 10,00, 00,00, 05,00,00,00, 10,01,00,00, 00,4B,00,00, 00,00, 08, 00, 00, 00,00,00,00


再搜索:[HKEY_LOCAL_MACHINE\Drivers\BuiltIn\IRDA2410],這個是紅外,也要修改下:

[HKEY_LOCAL_MACHINE\Drivers\BuiltIn\IRDA2410]
  "DeviceArrayIndex"=dword:2
  "Irq"=dword:19
  "IoBase"=dword:50008000
  "IoLen"=dword:2C
  "Prefix"="COM"
  "Dll"="IRDA2410.Dll"
  "Order"=dword:0
  "Priority"=dword:0
  "Port"="COM3:"
  "DeviceType"=dword:0  ; IRDA modem, 0 -> null modem
  "FriendlyName"="S2410 IRDA2410"
  "Index"=dword:2
  "IClass"="{A32942B7-920C-486b-B0E6-92A702A99B35}"


好了,注冊表就改到這里,以上要特別注意Irq的值,要和oalintr.h里面的中斷定義對應(yīng),并且注意Order的順序,DeviceArrayIndex的值以及IoBase,后面串口源代碼中要用到該值作判斷。

*/

 

 

Feedback

# re: Wince 串口驅(qū)動詳解-未完  回復(fù)  更多評論   

2011-11-21 09:49 by crashcrazy
官人我要!!!!!!!!!!!
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美成人a视频| 久久综合久久综合久久| 久久免费国产| 久久亚洲综合色一区二区三区| 欧美一区二区三区免费视频| 性8sex亚洲区入口| 久久久久五月天| 亚洲第一偷拍| 日韩网站在线观看| 亚洲婷婷在线| 久久米奇亚洲| 欧美日韩亚洲一区二区三区在线 | 久久亚洲春色中文字幕| 久久久综合视频| 欧美精品国产一区| 国产精品手机视频| 在线欧美小视频| 一区二区三区欧美视频| 久久狠狠一本精品综合网| 欧美大片在线看| 国产精品99久久久久久久vr| 久久国产一区二区三区| 欧美激情亚洲自拍| 国产精品亚洲精品| 亚洲欧洲精品天堂一级| 欧美怡红院视频| 亚洲第一主播视频| 亚洲午夜一级| 欧美刺激午夜性久久久久久久| 国产精品青草久久| 亚洲美女毛片| 每日更新成人在线视频| 亚洲一区二区免费看| 欧美91精品| 韩国v欧美v日本v亚洲v| 亚洲一区二区三区视频播放| 蜜臀久久99精品久久久久久9 | 欧美日韩国产免费观看| 国产综合亚洲精品一区二| 一本色道久久88综合日韩精品| 久久国产精品久久久久久久久久 | 欧美成人一区在线| 亚洲综合二区| 欧美少妇一区| 99在线精品视频| 欧美.www| 久久精品国产亚洲一区二区三区 | 亚洲少妇在线| 欧美激情综合在线| 久久人人爽爽爽人久久久| 国产日韩欧美视频| 亚洲欧美在线免费| 一区二区三区四区五区在线 | 久久精品男女| 国产午夜精品一区理论片飘花 | 这里只有精品丝袜| 欧美黄色成人网| 亚洲日本欧美天堂| 亚洲激精日韩激精欧美精品| 蜜臀久久99精品久久久久久9 | 男女精品网站| 亚洲成人在线| 欧美激情一区二区三区不卡| 麻豆精品网站| 99视频热这里只有精品免费| 亚洲美女网站| 国产精品捆绑调教| 午夜精品亚洲| 欧美在线免费观看亚洲| 国产综合久久久久久鬼色| 久久精品女人| 久久久久久亚洲综合影院红桃 | 亚洲精品视频在线看| 欧美日韩一区二区免费在线观看 | 久久精品人人做人人综合| 一区二区在线看| 欧美高清视频在线| 欧美日韩18| 性欧美18~19sex高清播放| 午夜激情综合网| 国产一区二区三区精品欧美日韩一区二区三区 | 久久久999| 老司机免费视频一区二区三区| 亚洲国产三级在线| 日韩亚洲在线观看| 国产亚洲人成a一在线v站| 免费久久久一本精品久久区| 亚洲精品在线观看视频| 国产精品xnxxcom| 久久久久久久一区| 蜜臀av性久久久久蜜臀aⅴ四虎 | 久久久xxx| 亚洲精选在线| 亚洲一区激情| 亚洲福利视频网| 亚洲精品偷拍| 国内精品久久久久久久影视麻豆| 91久久夜色精品国产九色| 国产精品久久久久久久午夜片| 久久精品最新地址| 欧美日本高清视频| 久久成人免费日本黄色| 欧美激情视频一区二区三区在线播放| 亚洲一品av免费观看| 久久精品123| 亚洲一区国产| 麻豆精品精品国产自在97香蕉| 亚洲一区欧美二区| 欧美成人高清视频| 久久天天躁狠狠躁夜夜爽蜜月| 欧美日韩久久| 欧美国产大片| 国产亚洲午夜| 亚洲午夜av| 亚洲精品孕妇| 老司机精品视频一区二区三区| 欧美一区二区播放| 欧美色视频日本高清在线观看| 欧美激情1区| 在线播放中文一区| 久久不射中文字幕| 欧美在线播放一区| 国产精品久久影院| 亚洲美女一区| 99在线精品观看| 欧美大片免费久久精品三p| 久久亚洲综合色| 国内精品久久久| 午夜在线成人av| 午夜在线播放视频欧美| 欧美日韩大片| 亚洲日韩成人| 夜夜爽www精品| 欧美日韩精品免费观看视频完整| 亚洲国产裸拍裸体视频在线观看乱了| 国模 一区 二区 三区| 午夜免费久久久久| 久久精品视频一| 国内欧美视频一区二区| 欧美专区日韩视频| 六月丁香综合| 亚洲国产精品第一区二区| 久久蜜臀精品av| 亚洲国产精品久久| 亚洲最新视频在线播放| 欧美日韩情趣电影| 在线亚洲+欧美+日本专区| 午夜电影亚洲| 国内精品久久久久久久果冻传媒| 久久九九热免费视频| 猛男gaygay欧美视频| 最新国产成人av网站网址麻豆 | 亚洲国产视频一区二区| 你懂的一区二区| 亚洲精品免费在线| 亚洲男人的天堂在线| 国产日产高清欧美一区二区三区| 性色av香蕉一区二区| 久久精品国产一区二区三区免费看| 国产自产精品| 欧美不卡高清| 一区二区三区av| 久久久久一区二区| 亚洲九九精品| 国产美女精品| 美女图片一区二区| 亚洲网址在线| 美女精品网站| 亚洲影音一区| 亚洲国产一区二区精品专区| 欧美私人啪啪vps| 久久蜜桃精品| 亚洲视频在线观看| 欧美成在线观看| 午夜综合激情| 亚洲日本中文字幕| 国产午夜精品视频| 欧美精品精品一区| 欧美综合国产| 一区二区国产在线观看| 老司机久久99久久精品播放免费 | 欧美欧美全黄| 久久久久国色av免费观看性色| 亚洲黄色一区二区三区| 久久精品成人| 中文国产成人精品| 亚洲第一区中文99精品| 国产精品久久久久久久久久妞妞 | 欧美在线亚洲一区| 亚洲日本电影在线| 狠狠网亚洲精品| 国产精品制服诱惑| 欧美日韩在线免费观看| 另类尿喷潮videofree| 午夜一级久久| 亚洲午夜久久久| 一区二区动漫| 9色精品在线| 亚洲精品一区二区三区在线观看| 免费成人美女女|