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

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

?? s3c2510eth.c.bak

?? 三星vxworks的S3C2410 的BSP
?? BAK
?? 第 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 */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
2014亚洲片线观看视频免费| 国产精品久久国产精麻豆99网站 | 国产情人综合久久777777| 中文字幕一区二区视频| 免费日本视频一区| 色综合色综合色综合色综合色综合| 日韩精品中文字幕在线不卡尤物| 成人免费在线播放视频| 国产一区二区女| 欧美疯狂性受xxxxx喷水图片| 日韩一区欧美一区| 国产一区激情在线| 欧美一卡二卡三卡四卡| 一区二区三区视频在线观看| 国产99久久精品| 久久综合九色综合欧美亚洲| 视频在线观看91| 欧美系列在线观看| 亚洲美女免费在线| 99九九99九九九视频精品| 日本一区二区视频在线观看| 久久精品噜噜噜成人88aⅴ| 欧美日韩亚洲综合| 亚洲影院在线观看| 91福利资源站| 亚洲一二三四在线| 欧美综合在线视频| 亚洲影视在线播放| 欧美三级在线播放| 午夜视频一区二区| 欧美精品视频www在线观看| 亚洲高清一区二区三区| 欧美色视频一区| 亚洲成人高清在线| 欧美一区二区在线看| 琪琪一区二区三区| 日韩欧美黄色影院| 国产老肥熟一区二区三区| 久久综合av免费| 高清国产午夜精品久久久久久| 久久久久国产精品麻豆ai换脸| 国产一区欧美一区| 久久精品视频网| 成人免费电影视频| 一区二区三区中文在线| 欧美午夜精品久久久| 日韩专区欧美专区| 精品国产一区二区精华| 国产黄人亚洲片| 国产精品九色蝌蚪自拍| 91丨九色porny丨蝌蚪| 一区二区三区91| 日韩欧美国产三级电影视频| 国产一区二区精品在线观看| 国产精品入口麻豆原神| 色综合久久88色综合天天| 视频一区中文字幕| 久久久亚洲精品石原莉奈| 97久久精品人人做人人爽50路| 亚洲宅男天堂在线观看无病毒| 91精品国产高清一区二区三区蜜臀| 蜜桃视频第一区免费观看| 国产偷国产偷精品高清尤物| 色视频一区二区| 精品无人码麻豆乱码1区2区| 国产精品网站在线播放| 欧美猛男超大videosgay| 国产一级精品在线| 亚洲一区二区三区美女| 久久亚洲一级片| 色哟哟国产精品| 国内外成人在线| 亚洲午夜羞羞片| 国产亚洲欧美激情| 欧美高清视频一二三区| 岛国精品一区二区| 日本亚洲免费观看| 日韩理论在线观看| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 日本一区二区三区四区在线视频| 91美女视频网站| 韩国成人精品a∨在线观看| 一区二区在线免费观看| 国产亚洲自拍一区| 91精品国产福利在线观看 | 欧美国产成人精品| 在线观看91精品国产麻豆| 北条麻妃国产九九精品视频| 另类小说图片综合网| 亚洲精品videosex极品| 久久久久久久久岛国免费| 欧美精品少妇一区二区三区 | 国产精品国产三级国产有无不卡 | 久久99国产精品免费网站| 一区二区三区在线视频观看 | 欧美精品一区二区久久久| 欧美日韩在线综合| 91网上在线视频| 国产成人自拍网| 久久 天天综合| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲人精品午夜| 国产精品丝袜久久久久久app| 欧美电影免费观看高清完整版在线| 欧美三级电影精品| 在线精品视频一区二区| 高清日韩电视剧大全免费| 精品日韩在线一区| 欧美一级二级在线观看| 亚洲精品一二三区| 国产精品久久久久久久久晋中| 日韩午夜激情视频| 欧美一区二区成人6969| 欧美男人的天堂一二区| 欧美精品色综合| 欧美久久一区二区| 欧美视频在线一区| 欧美日韩国产一级| 91麻豆精品国产综合久久久久久 | 欧美主播一区二区三区美女| 91亚洲国产成人精品一区二区三| 成人综合激情网| 99国产精品国产精品毛片| 91麻豆蜜桃一区二区三区| 一本一本大道香蕉久在线精品 | 久久九九全国免费| 精品对白一区国产伦| 色综合久久久久综合体| 激情偷乱视频一区二区三区| 精品免费视频一区二区| 在线观看国产一区二区| 欧美在线观看一区| 欧美日韩国产成人在线91| 在线综合视频播放| 精品日韩在线一区| 国产精品欧美极品| 亚洲精品免费看| 男女视频一区二区| 国产成人三级在线观看| 91免费版在线看| 欧美日本在线观看| 日韩精品一区二区在线| 国产精品视频一二三区| 亚洲一区二区三区四区五区中文| 日产国产高清一区二区三区| 久久国产日韩欧美精品| av在线播放成人| 欧美日本在线看| 久久精品在这里| 一区二区三区蜜桃| 一区二区三区中文在线观看| 亚洲一级二级三级在线免费观看| 亚洲成人动漫av| av在线不卡网| 在线播放91灌醉迷j高跟美女| 国产视频一区在线播放| 91久久精品一区二区三区| 91精品国产综合久久久蜜臀图片| 久久精品水蜜桃av综合天堂| 亚洲精品国产精品乱码不99| 久久av资源站| 一本久久精品一区二区| 久久久久久久久99精品| 亚洲一级二级三级在线免费观看| 久久99精品久久久久久动态图| 91年精品国产| 久久久亚洲精品石原莉奈 | 美脚の诱脚舐め脚责91| 成人av小说网| 欧美成人一区二区| 亚洲一级二级在线| 99久久婷婷国产| 久久色在线视频| 青娱乐精品在线视频| 91亚洲精品乱码久久久久久蜜桃| 欧美大片国产精品| 亚洲va在线va天堂| 91首页免费视频| 26uuu国产在线精品一区二区| 欧美人动与zoxxxx乱| 国产精品久久久久久久第一福利| 五月天中文字幕一区二区| 99re在线视频这里只有精品| 久久久综合九色合综国产精品| 石原莉奈在线亚洲二区| 一本一本久久a久久精品综合麻豆| 久久久高清一区二区三区| 水野朝阳av一区二区三区| 在线免费观看日本一区| 综合在线观看色| 99久久久久免费精品国产| 欧美激情在线一区二区三区| 国产精品一区专区| 精品国产一二三区| 麻豆精品一区二区三区| 欧美精品电影在线播放| 亚洲一二三区在线观看| 欧美日韩免费观看一区三区| 亚洲国产日韩av| 欧美猛男gaygay网站|