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

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

?? s3c2510eth.c

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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品免费av| 免费不卡在线观看| 国产亚洲精品免费| 精品电影一区二区| 久久久久久久久岛国免费| 久久综合五月天婷婷伊人| 久久久不卡网国产精品一区| 亚洲精品综合在线| 亚洲成人av资源| 蜜桃av噜噜一区| 国产一区不卡在线| 99热精品一区二区| 欧美理论电影在线| 精品久久久久久久久久久久包黑料| 日韩精品一区国产麻豆| 久久久精品黄色| 视频一区视频二区中文字幕| 久久精工是国产品牌吗| 成人小视频在线| 精品视频1区2区| 精品国产凹凸成av人导航| 亚洲18影院在线观看| 91丨九色porny丨蝌蚪| 91精品国产入口| 亚洲国产精品高清| 日本一区中文字幕| 99精品欧美一区二区三区小说| 欧美午夜视频网站| 久久久亚洲高清| 国产一区日韩二区欧美三区| 欧美精品在线视频| 美女一区二区久久| 欧美一区二区视频免费观看| 日本欧美一区二区| 日韩网站在线看片你懂的| 中文字幕国产精品一区二区| 国产电影一区二区三区| 欧美日韩在线亚洲一区蜜芽| 亚洲影院在线观看| 高清久久久久久| 亚洲精品在线电影| 国产一区二区美女诱惑| 久久久精品黄色| 99热这里都是精品| 亚洲一区在线观看视频| 欧美日韩久久不卡| 亚洲黄色小说网站| 欧美日韩亚洲综合一区| 蓝色福利精品导航| 国产人成一区二区三区影院| 天天综合天天做天天综合| 91视频在线观看免费| 亚洲免费色视频| 99久久99久久精品国产片果冻| 亚洲精品欧美专区| 777欧美精品| 亚洲bt欧美bt精品| 久久久噜噜噜久噜久久综合| 99精品视频免费在线观看| 午夜欧美一区二区三区在线播放| 欧美一区二区三区免费| 风间由美一区二区三区在线观看 | 欧美性生交片4| 天天av天天翘天天综合网色鬼国产| 91精品国产免费| 成人一区二区三区| 亚洲 欧美综合在线网络| 久久精品一二三| 91福利小视频| 亚洲欧美日韩中文播放| 在线不卡中文字幕播放| 国产99久久久国产精品免费看| 亚洲免费毛片网站| 精品国产欧美一区二区| 色综合久久久久久久久| 一区二区三区精品在线| 欧美性xxxxxxxx| 国产成人午夜精品影院观看视频| 亚洲精选视频免费看| 久久久久久久久久美女| 欧洲精品在线观看| 视频精品一区二区| 自拍偷拍国产精品| 欧美日韩免费电影| 成人黄色在线视频| 一区二区三区在线观看国产| 久久综合久久鬼色| 91精品一区二区三区在线观看| caoporn国产一区二区| 六月丁香婷婷色狠狠久久| 亚洲黄色性网站| 国产精品每日更新在线播放网址| 欧美一区二区黄色| 欧美另类一区二区三区| 色久优优欧美色久优优| 成人一级黄色片| 国内久久精品视频| 亚洲视频小说图片| 欧美国产精品中文字幕| 久久综合九色综合欧美98| 欧美日韩精品福利| 在线欧美日韩国产| 99久久夜色精品国产网站| 色一情一伦一子一伦一区| 国产mv日韩mv欧美| 国产成a人亚洲精品| 国产在线观看一区二区| 蜜臀va亚洲va欧美va天堂| 午夜免费久久看| 亚洲一区在线观看视频| 一区二区三区精密机械公司| 亚洲欧美偷拍卡通变态| 亚洲人成在线观看一区二区| 国产精品国产精品国产专区不片| 欧美伊人久久久久久久久影院| 99久久99久久免费精品蜜臀| 99久久综合色| 色综合天天综合色综合av| 麻豆国产欧美日韩综合精品二区| 日韩成人一区二区三区在线观看| 午夜久久久久久| 日韩精品一卡二卡三卡四卡无卡| 亚洲大片精品永久免费| 日本中文字幕一区二区有限公司| 日韩av二区在线播放| 青青草国产精品亚洲专区无| 美女视频黄 久久| 国产一区高清在线| 成人高清在线视频| 91浏览器在线视频| 欧美日韩精品专区| 精品毛片乱码1区2区3区| 欧美高清在线一区二区| 亚洲天堂精品视频| 亚洲一区二区三区在线看| 午夜久久福利影院| 精品一区二区国语对白| 日本中文字幕一区| 国产精品一级在线| 美女任你摸久久| 99视频国产精品| 宅男噜噜噜66一区二区66| 久久夜色精品国产噜噜av| 日韩伦理电影网| 婷婷综合久久一区二区三区| 韩国精品久久久| 91国偷自产一区二区开放时间 | 国产精品99久| 99久久99久久精品免费观看 | 天天色综合成人网| 国产精品资源网| 色呦呦国产精品| 欧美一级片在线看| 中文字幕一区二区三区精华液| 国产丝袜在线精品| 亚洲国产一二三| 日韩国产精品久久久久久亚洲| 国内精品写真在线观看| 在线国产电影不卡| 久久免费午夜影院| 一区二区三区精品| 国产.精品.日韩.另类.中文.在线.播放| 色综合久久久久久久| 久久精品无码一区二区三区 | 国产精品欧美一级免费| 天天影视网天天综合色在线播放| 国产一区二区三区| 欧美日韩免费电影| 亚洲乱码中文字幕综合| 久久99精品久久久久久动态图| 91免费观看在线| 久久久电影一区二区三区| 天堂一区二区在线| 波多野结衣在线aⅴ中文字幕不卡| 欧美一级片在线看| 亚洲成人三级小说| 91一区二区三区在线观看| 久久人人超碰精品| 蜜桃av噜噜一区| 欧美日本在线观看| 亚洲另类色综合网站| 成人黄色小视频| 久久综合九色综合欧美98| 蜜臂av日日欢夜夜爽一区| 欧美精选一区二区| 亚洲成人免费视| 欧美四级电影在线观看| 亚洲欧美国产高清| 不卡的av中国片| 欧美高清在线精品一区| 国产成人在线视频播放| 精品噜噜噜噜久久久久久久久试看| 天堂久久一区二区三区| 欧美日韩中文字幕精品| 亚洲精品国产视频| 色一情一伦一子一伦一区| 尤物视频一区二区| 在线看国产日韩| 午夜电影久久久| 欧美大度的电影原声|