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

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

?? s3c2510eth.c

?? s3c2510 VxWorks BSP包
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* s3c2510Eth.c - SAMSUNG S3C2510 Ethernet controller driver  */

/* Copyright 2002 SAMSUNG ELECTRONICS */

/*
modification history
--------------------
01a,08feb02,jmLee   created.
*/


#include "vxWorks.h"
#include "intLib.h"
#include "netLib.h"
#include "end.h"
#include "endLib.h"
#include "cacheLib.h"
#include "miiLib.h"
#include "errno.h"
#include "stdio.h"
#include "logLib.h"
#include "taskLib.h"

#include "drv/multi/s3c2510.h"
#include "config.h"
#include "drv/intrCtl/s3c2510Intr.h"
#include "s3c2510Eth.h"
#include "s3c2510Des.h"


#undef  DEBUG_TRACE
#define DEBUG_LOG(x, p1, p2, p3, p4, p5, p6) \
        logMsg(x, (int)(UINT32)(p1), (int)(UINT32)(p2), (int)(UINT32)(p3), (int)(UINT32)(p4), (int)(UINT32)(p5), (int)(UINT32)(p6))

#define RX_WAIT_MAX                     (CPLL_FREQ * 1000)  /* Rx completion timeout */
#define TX_WAIT_MAX                     (CPLL_FREQ * 1000)  /* Tx completion timeout */
#define MII_WAIT_MAX                    (CPLL_FREQ * 1000)  /* max delay for the MII operation */

#ifndef NSDELAY
#define NSDELAY(nsec)                                           \
{                                                               \
    volatile int nx;                                            \
    volatile int loop = (int)(((CPLL_FREQ * nsec) / 1000) + 1); \
                                                                \
    for (nx=0; nx<loop; nx++);                                  \
}
#endif  /* NSDELAY */


/* External */

IMPORT STATUS   sysSecEnetAddrGet(int unit, UCHAR* address);


/* Forward Function Declarations */

LOCAL STATUS    s3c2510EthInitPhy(ETH_DRV_CTRL *pDrvCtrl);
LOCAL STATUS    s3c2510EthAnRestart(ETH_DRV_CTRL *pDrvCtrl);
LOCAL STATUS    s3c2510EthMiiRead(ETH_DRV_CTRL *pDrvCtrl, UINT8 phyAddr, UINT8 regAddr, UINT16 *miiData);
LOCAL STATUS    s3c2510EthMiiWrite(ETH_DRV_CTRL *pDrvCtrl, UINT8 phyAddr, UINT8 regAddr, UINT16 miiData);
LOCAL void      s3c2510EthInitBD(ETH_DRV_CTRL *pDrvCtrl);
LOCAL void      s3c2510EthIntRx(ETH_DRV_CTRL *pDrvCtrl);
LOCAL void      s3c2510EthIntTx(ETH_DRV_CTRL *pDrvCtrl);
LOCAL void      s3c2510EthRxHandler(ETH_DRV_CTRL *pDrvCtrl);
LOCAL void      s3c2510EthTxHandler(ETH_DRV_CTRL *pDrvCtrl);

#ifdef  DEBUG_TRACE
LOCAL void      s3c2510EthHexDump(UCHAR *p, ULONG l);
#endif  /* DEBUG_TRACE */



/*******************************************************************************
*
* s3c2510EthInit - initialize S3C2510 Ethernet controller
*
* RETURNS: OK, or ERROR.
*/

STATUS s3c2510EthInit(
    ETH_DRV_CTRL *pDrvCtrl                                  /* pointer to driver structure */
    )
{
    int unit = pDrvCtrl->unit;

#ifdef  DEBUG_TRACE
    printf("s3c2510Eth%d Init\n", unit);
#endif  /* DEBUG_TRACE */

    if (unit == 0)
    {
        pDrvCtrl->intLvlRx = INT_LVL_ETH0RX;
        pDrvCtrl->intLvlTx = INT_LVL_ETH0TX;
        pDrvCtrl->intVecRx = INT_VEC_ETH0RX;
        pDrvCtrl->intVecTx = INT_VEC_ETH0TX;
    }
    else if (unit == 1)
    {
        pDrvCtrl->intLvlRx = INT_LVL_ETH1RX;
        pDrvCtrl->intLvlTx = INT_LVL_ETH1TX;
        pDrvCtrl->intVecRx = INT_VEC_ETH1RX;
        pDrvCtrl->intVecTx = INT_VEC_ETH1TX;
    }
    else
    {
        printf("s3c2510Eth%d Error: Invalid unit number\n", unit);

        return ERROR;
    }

    /* Disable BDMA/MAC. */
    s3c2510EthStop(pDrvCtrl);

    /* Enable peripheral clock. */
    *S3C2510_PCLKDIS &= ~(S3C2510_PCLKDIS_ETH0 << unit);

    /* Initialize PHY. */
    s3c2510EthInitPhy(pDrvCtrl);

    /* Reset BDMA. */
    *S3C2510_BRXCON(unit) = S3C2510_BRXCON_RESET;
    *S3C2510_BTXCON(unit) = S3C2510_BTXCON_RESET;

    /* Reset MAC. */
    *S3C2510_MACCON(unit) = S3C2510_MACCON_RESET;

    /* Initlalize Buffer Descriptor. */
    s3c2510EthInitBD(pDrvCtrl);

    /* Initlalize BDMA Receive Frame Size Register. */
    *S3C2510_BRXLEN(unit) = (SIZE_ETH_MDMA << S3C2510_BRXLEN_MFS_SHIFT) |
                            (SIZE_ETH_MDMA << S3C2510_BRXLEN_BS_SHIFT);

    /* Initialize BDMA RBD/TBD Start Address Register. */
    *S3C2510_BRXBDPTR(unit) = pDrvCtrl->rbdBase;
    *S3C2510_BTXBDPTR(unit) = pDrvCtrl->tbdBase;

    /* Initialize BDMA Rx/Tx Control Register. */
    *S3C2510_BRXCON(unit) = NBD_RBD_ETH |                   /* defined in smdk2510.h */
                            (SIZE_ETH_WA << S3C2510_BRXCON_WA_SHIFT);
    *S3C2510_BTXCON(unit) = NBD_TBD_ETH |                   /* defined in smdk2510.h */
                            S3C2510_BTXCON_SL_6;            /* Wait to Fill 6/8 of BDMA Tx Buffer */

    /* Initialize MAC Rx/Tx Control Register. */
    *S3C2510_MRXCON(unit) =
#if     (SIZE_ETH_CRC == 0)
                            S3C2510_MRXCON_STRIPCRC |       /* Strip CRC Value */
#endif  /* (SIZE_ETH_CRC > 0) */
                            0;
    *S3C2510_MTXCON(unit) = 0;

    /* Initialize BDMA-MAC Rx/Tx Interrupt Enable Register. */
    *S3C2510_BMRXINTEN(unit) = S3C2510_BMRXINTEN_BNOIE |    /* BDMA Rx Not Owner Interrupt Enable */
                               S3C2510_BMRXINTEN_BDONEIE;   /* BDMA Rx Done Interrupt Enable */
    *S3C2510_BMTXINTEN(unit) = S3C2510_BMTXINTEN_MCOMPIE;   /* MAC Tx Completion Interrupt Enable */

    /* Initialize MAC Control Register. */
    if (pDrvCtrl->l80225Status & L80225_STAT_FDX)
    {
        *S3C2510_MACCON(unit) = S3C2510_MACCON_FULLDUPLEX;  /* Full-Duplex Enable */
    }
    else
    {
        *S3C2510_MACCON(unit) = 0;
    }

    /* Get hardware address. */
    sysSecEnetAddrGet(unit, pDrvCtrl->IFADDR.phyAddress);

    /* Set hardware address. */
    s3c2510EthAddrSet(pDrvCtrl);

    /* Initialize CAM. First entry is reserved for our MAC address. */
    *S3C2510_CAMEN(unit) = 0x00000001;
    *S3C2510_CAMCON(unit) = S3C2510_CAMCON_COMPEN |         /* Compare Enable */
                            S3C2510_CAMCON_BROAD |          /* Broadcast Accept */
                            S3C2510_CAMCON_GROUP |          /* Group Accept */
                            S3C2510_CAMCON_STATION;         /* Station Accept */

    /* Initialize flags. */
    pDrvCtrl->bPolling   = FALSE;
    pDrvCtrl->bTxBlocked = FALSE;
    pDrvCtrl->bRxHandler = FALSE;
    pDrvCtrl->bTxHandler = FALSE;

    /* Clear status. */
    /* should be clear value one, jwchoi
    *S3C2510_BMRXSTAT(unit) = 0;
    *S3C2510_BMTXSTAT(unit) = 0;
    */
    /* Connect interrupt. */
    intConnect(pDrvCtrl->intVecRx, (VOIDFUNCPTR)s3c2510EthIntRx, (int)pDrvCtrl);
    intConnect(pDrvCtrl->intVecTx, (VOIDFUNCPTR)s3c2510EthIntTx, (int)pDrvCtrl);

    return OK;
}

/*******************************************************************************
*
* s3c2510EthInitPhy - initialize S3C2510 Ethernet PHY
*
* RETURNS: OK, or ERROR.
*/

STATUS s3c2510EthInitPhy(
    ETH_DRV_CTRL *pDrvCtrl                                  /* pointer to driver structure */
    )
{
    int unit = pDrvCtrl->unit;
    UINT8 phyAddr = (UINT8)(unit + 1);

#ifdef  DEBUG_TRACE
    printf("s3c2510Eth%d InitPhy\n", unit);
#endif  /* DEBUG_TRACE */

    /* Save PHY address. */
    pDrvCtrl->phyInfo.phyAddr = phyAddr;

    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_CTRL_REG,      &pDrvCtrl->PHYREGS.phyCtrl);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_STAT_REG,      &pDrvCtrl->PHYREGS.phyStatus);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_PHY_ID1_REG,   &pDrvCtrl->PHYREGS.phyId1);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_PHY_ID2_REG,   &pDrvCtrl->PHYREGS.phyId2);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_AN_ADS_REG,    &pDrvCtrl->PHYREGS.phyAds);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_AN_PRTN_REG,   &pDrvCtrl->PHYREGS.phyPrtn);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_AN_EXP_REG,    &pDrvCtrl->PHYREGS.phyExp);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_AN_NEXT_REG,   &pDrvCtrl->PHYREGS.phyNext);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, L80225_STAT_REG,   &pDrvCtrl->l80225Status);

#ifdef  ETH_AUTO_NEGOTIATION
    /* If link is down, abort auto negotiation. */
    if (pDrvCtrl->PHYREGS.phyPrtn)
    {
        s3c2510EthAnRestart(pDrvCtrl);
    }
#else   /* ETH_AUTO_NEGOTIATION */
    /* Initialize MII Control Register. */
    pDrvCtrl->PHYREGS.phyCtrl =
#ifndef ETH_10BT
                                MII_CR_100 |                /* 100T */
#endif  /* ETH_10BT */
#ifdef  ETH_FULL_DUPLEX
                                MII_CR_FDX |                /* Full-Duplex */
#endif  /* ETH_FULL_DUPLEX */
                                0;
    s3c2510EthMiiWrite(pDrvCtrl, phyAddr, MII_CTRL_REG, pDrvCtrl->PHYREGS.phyCtrl);

    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_STAT_REG, &pDrvCtrl->PHYREGS.phyStatus);
#endif  /* ETH_AUTO_NEGOTIATION */

    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_CTRL_REG,    &pDrvCtrl->PHYREGS.phyCtrl);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_AN_ADS_REG,  &pDrvCtrl->PHYREGS.phyAds);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_AN_PRTN_REG, &pDrvCtrl->PHYREGS.phyPrtn);
    s3c2510EthMiiRead(pDrvCtrl, phyAddr, L80225_STAT_REG, &pDrvCtrl->l80225Status);

     /* Connection speed. */
    if (pDrvCtrl->l80225Status & L80225_STAT_100)
    {
        pDrvCtrl->phyInfo.phySpeed = MII_100MBS;
    }
    else
    {
        pDrvCtrl->phyInfo.phySpeed = MII_10MBS;
    }

#ifdef  DEBUG_TRACE
    printf("    MII_CTRL_REG:       0x%04X\n", pDrvCtrl->PHYREGS.phyCtrl);
    printf("    MII_STAT_REG:       0x%04X\n", pDrvCtrl->PHYREGS.phyStatus);
    printf("    MII_AN_ADS_REG:     0x%04X\n", pDrvCtrl->PHYREGS.phyAds);
    printf("    MII_AN_PRTN_REG:    0x%04X\n", pDrvCtrl->PHYREGS.phyPrtn);
    printf("    L80225_STAT_REG:    0x%04X\n", pDrvCtrl->l80225Status);
#endif  /* DEBUG_TRACE */

    return OK;
}

/*******************************************************************************
*
* s3c2510EthAnRestart - restart auto negotiation
*
* RETURNS: OK, or ERROR.
*/

STATUS s3c2510EthAnRestart(
    ETH_DRV_CTRL *pDrvCtrl                                  /* pointer to driver structure */
    )
{
    UINT16 phyAddr = pDrvCtrl->phyInfo.phyAddr;
    int timeout = MII_WAIT_MAX;

    /* Perserve selector. */
    pDrvCtrl->PHYREGS.phyAds &= MII_ADS_SEL_MASK;

    /* Set appropriate options. */
    pDrvCtrl->PHYREGS.phyAds |=
#ifdef  ETH_10BT
                                MII_TECH_10BASE_T |         /* 10T half-duplex capable */
#endif  /* ETH_10BT */
#ifdef  ETH_FULL_DUPLEX
                                MII_TECH_100BASE_TX_FD |    /* 100TX-FX full-duplex capable */
#ifdef  ETH_10BT
                                MII_TECH_10BASE_FD |        /* 10T full-duplex capable */
#endif  /* ETH_10BT */
#endif  /* ETH_FULL_DUPLEX */
                                MII_TECH_100BASE_TX;        /* 100TX-FX half-duplex capable */

    /* Initialize Auto Negotiation Advertisement Register. */
    s3c2510EthMiiWrite(pDrvCtrl, phyAddr, MII_AN_ADS_REG, pDrvCtrl->PHYREGS.phyAds);

    /* Enable and Start Auto Negotiation. */
    pDrvCtrl->PHYREGS.phyCtrl |= MII_CR_AUTO_EN |           /* Auto-Negotiation Enable */
                                 MII_CR_RESTART;            /* Restart Auto Negotiation */

    /* Start auto negotiation. */
    s3c2510EthMiiWrite(pDrvCtrl, phyAddr, MII_CTRL_REG, pDrvCtrl->PHYREGS.phyCtrl);

    /* Wait until start auto negotiation. */
    while (1)
    {
        s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_CTRL_REG, &pDrvCtrl->PHYREGS.phyCtrl);
        if (!(pDrvCtrl->PHYREGS.phyCtrl & MII_CR_RESTART))
        {
            break;
        }
    }

    /* Wait until complete auto negotiation. */
    while (1)
    {
        s3c2510EthMiiRead(pDrvCtrl, phyAddr, MII_STAT_REG, &pDrvCtrl->PHYREGS.phyStatus);
        if (pDrvCtrl->PHYREGS.phyStatus & MII_SR_AUTO_NEG)
        {
            break;
        }

        if (--timeout == 0)
        {
            printf("s3c2510Eth%d Error: MII auto negotiation timeout\n", pDrvCtrl->unit);

            return ERROR;
        }
    }

    return OK;
}

/**************************************************************************
*
* s3c2510EthMiiRead - read the MII interface
*
* This routine reads the register specified by <phyReg> in the PHY device whose
* address is <phyAddr>. The value read is returned in the location pointed to by
* <miiData>.
*
* RETURNS: OK, or ERROR.
*/

STATUS s3c2510EthMiiRead(
    ETH_DRV_CTRL *pDrvCtrl,                                 /* pointer to driver structure */
    UINT8 phyAddr,                                          /* the PHY being read */
    UINT8 regAddr,                                          /* the PHY's register being read */
    UINT16 *miiData                                         /* value read from the MII interface */
    )
{
    int unit = pDrvCtrl->unit;
    UINT16 val;
    int timeout = MII_WAIT_MAX;

#ifdef  DEBUG_TRACE
    printf("s3c2510Eth%d MiiRead, PHY%u, REG%u\n", unit, phyAddr, regAddr);
#endif  /* DEBUG_TRACE */

    val = (3 << S3C2510_STACON_MDCCLKRATE_SHIFT) |          /* MDC Clock Rate */
          (phyAddr << S3C2510_STACON_PHYADDR_SHIFT) |       /* PHY Address */
          (regAddr << S3C2510_STACON_PHYREGADDR_SHIFT) |    /* PHY Register Address */
          S3C2510_STACON_PHYREAD |                          /* Read */
          S3C2510_STACON_PHYBUSY;                           /* Start Operation */

    *S3C2510_STACON(unit) = val;

    /* Wait until complete operation. */
    while (1)
    {
        val = *S3C2510_STACON(unit);
        if (!(val & S3C2510_STACON_PHYBUSY))                /* End Operation */
        {
            break;
        }

        if (--timeout == 0)
        {
            printf("s3c2510Eth%d Error: MII read timeout\n", unit);

            return ERROR;
        }
    }

    *miiData = *S3C2510_STADATA(unit);

    return OK;
}

/**************************************************************************
*
* s3c2510EthMiiWrite - write to the MII register
*
* This routine writes the register specified by <phyReg> in the PHY device whose
* address is <phyAddr>, with the 16-bit value included in <miiData>.
*
* RETURNS: OK, or ERROR.
*/

STATUS s3c2510EthMiiWrite(
    ETH_DRV_CTRL *pDrvCtrl,                                 /* pointer to driver structure */
    UINT8 phyAddr,                                          /* the PHY being written */
    UINT8 regAddr,                                          /* the PHY's register being written */
    UINT16 miiData                                          /* value written to the MII interface */
    )
{
    int unit = pDrvCtrl->unit;
    UINT16 val;
    int timeout = MII_WAIT_MAX;

#ifdef  DEBUG_TRACE
    printf("s3c2510Eth%d MiiWrite, PHY%u, REG%u\n", unit, phyAddr, regAddr);
#endif  /* DEBUG_TRACE */

    *S3C2510_STADATA(unit) = miiData;

    val = (3 << S3C2510_STACON_MDCCLKRATE_SHIFT) |          /* MDC Clock Rate */
          (phyAddr << S3C2510_STACON_PHYADDR_SHIFT) |       /* PHY Address */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久夜色精品国产噜噜av| 亚洲电影在线播放| 欧美一级一级性生活免费录像| 亚洲午夜激情网页| 欧美一区二区三区免费观看视频| 亚洲图片有声小说| 日韩欧美国产精品一区| 久久99精品国产91久久来源| 欧美高清一级片在线观看| 成人黄色在线看| 日韩电影在线一区| 国产精品久久久久婷婷二区次| 欧美精品乱码久久久久久| 狠狠色丁香婷婷综合| 亚洲人成影院在线观看| 欧美一级视频精品观看| 丝袜美腿亚洲色图| 久久综合久久99| 91色在线porny| 全部av―极品视觉盛宴亚洲| 中文字幕亚洲视频| 欧美一区二区免费| 99视频一区二区| 麻豆成人免费电影| 日本一区二区不卡视频| 欧美影院一区二区三区| 国产中文字幕一区| 三级亚洲高清视频| 亚洲免费观看高清完整| 亚洲欧洲av一区二区三区久久| 欧美xxx久久| 26uuu久久综合| 精品理论电影在线| 日韩一区二区在线观看视频| 不卡视频一二三四| 日韩电影在线免费看| 亚洲一区免费视频| 亚洲伊人伊色伊影伊综合网| 久久先锋资源网| 欧美成人a∨高清免费观看| 色妞www精品视频| www.爱久久.com| 一本高清dvd不卡在线观看| 日本韩国欧美一区| 欧美日韩亚洲丝袜制服| 884aa四虎影成人精品一区| 日韩免费观看高清完整版| 欧美一级xxx| 国产精品久久久久一区| 一区二区三区免费观看| 麻豆精品视频在线观看免费| 免费人成精品欧美精品| 看片的网站亚洲| 国产精品影音先锋| 欧洲人成人精品| 26uuu欧美| 亚洲国产精品一区二区久久恐怖片| 亚洲18女电影在线观看| 亚洲欧美在线高清| 日本vs亚洲vs韩国一区三区| 国产一区二区三区观看| 99国产麻豆精品| 欧美性高清videossexo| 国产欧美日韩三级| 亚洲二区视频在线| 懂色av中文一区二区三区 | 国产做a爰片久久毛片| 欧美在线free| 中文字幕在线观看一区二区| 九九精品一区二区| 欧美一区国产二区| 偷偷要91色婷婷| 欧美电影在哪看比较好| 免费在线看一区| 欧美日本不卡视频| 一卡二卡三卡日韩欧美| 成人网页在线观看| 成人免费小视频| 色婷婷综合久色| 亚洲地区一二三色| 日韩免费电影网站| 国产.欧美.日韩| 亚洲香肠在线观看| 久久综合中文字幕| 99精品视频中文字幕| 亚洲激情自拍偷拍| 91麻豆精品国产综合久久久久久| 日韩av不卡在线观看| 欧美成人乱码一区二区三区| 国产精品2024| 日韩电影在线免费| 中文字幕一区二区三区不卡| 欧美日韩成人高清| 国产夫妻精品视频| 青青草原综合久久大伊人精品优势| 久久久久久久综合狠狠综合| 99久久精品国产一区二区三区| 五月激情六月综合| 一区二区三区加勒比av| 在线观看免费亚洲| 极品少妇一区二区三区精品视频| 亚洲国产电影在线观看| 欧美一区二区三区在线电影 | 精品久久久久久综合日本欧美| 色综合网站在线| 成人av第一页| 成人免费视频免费观看| 国产高清精品在线| 国产成人精品免费网站| 经典三级在线一区| 亚洲国产成人va在线观看天堂| 国产精品日韩成人| 久久久久九九视频| 欧美日韩大陆在线| av亚洲产国偷v产偷v自拍| 国产美女视频一区| 免费观看一级欧美片| 亚洲综合久久久久| 国产精品九色蝌蚪自拍| 日本一区二区三区在线观看| 精品欧美一区二区三区精品久久 | 日韩欧美国产精品| 欧美激情一区二区三区在线| 中文字幕一区二区三区在线播放| 亚洲国产岛国毛片在线| 亚洲色欲色欲www在线观看| 国产精品丝袜一区| 亚洲精品乱码久久久久久久久 | 欧美韩国日本一区| 国产欧美精品一区二区色综合朱莉| 综合久久综合久久| 综合婷婷亚洲小说| 亚洲国产精品久久不卡毛片| 国产综合色在线| 国产大陆亚洲精品国产| 国产69精品久久99不卡| 高清不卡在线观看av| 风流少妇一区二区| 99久久久精品| 欧美酷刑日本凌虐凌虐| 欧美精品久久一区| 国产色婷婷亚洲99精品小说| 一区二区三区四区不卡在线| 日韩成人一级片| 国产成人精品免费在线| 欧美日韩国产成人在线91| 亚洲精品一区二区三区蜜桃下载| 国产精品人人做人人爽人人添| 午夜视频一区在线观看| www.欧美精品一二区| 精品久久国产97色综合| 中文字幕日韩精品一区 | 日韩免费高清av| 亚洲精品一卡二卡| 美女精品自拍一二三四| 欧美精品自拍偷拍动漫精品| 亚洲国产精品人人做人人爽| av动漫一区二区| 亚洲黄色av一区| 色综合天天综合色综合av| 久久蜜桃av一区精品变态类天堂| 丝袜亚洲另类欧美综合| 欧美探花视频资源| 天使萌一区二区三区免费观看| 91精品国产综合久久久久| 久久成人免费网站| 久久精品视频一区| 成人福利在线看| 亚洲国产综合91精品麻豆| 欧美猛男gaygay网站| 亚洲高清久久久| 欧美肥妇毛茸茸| 一区二区日韩电影| 91在线视频在线| 一区二区三区波多野结衣在线观看| 成人激情视频网站| 亚洲国产aⅴ成人精品无吗| 欧美一卡二卡三卡四卡| 久久99久久久久久久久久久| 一区二区国产盗摄色噜噜| 538prom精品视频线放| 成人中文字幕合集| 蜜芽一区二区三区| 一区二区成人在线视频| 久久久久久久久岛国免费| 一本大道综合伊人精品热热| 奇米888四色在线精品| 国产精品久久久久影院亚瑟| 欧美精品久久久久久久多人混战| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产欧美1区2区3区| 日韩欧美高清一区| 欧美一区二区三区视频免费播放| 亚洲精品视频在线| 91精品国产91久久综合桃花| 91网站黄www| 色综合一区二区| 成人黄色777网| 国产a级毛片一区| 国产美女精品一区二区三区|