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

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

?? s3c6410otgdevice.cpp

?? 6410BSP3
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
                        pContext->Ep0State = EP0_STATE_OUT_DATA_PHASE;
                    }
                    pContext->sendDataEnd = FALSE;
                }
                else
                {   // UDR.wLength == 0
                    // ClientDriver will issue a SendControlStatusHandshake to
                    // complete the transaction.
                    pContext->sendDataEnd = TRUE;
                    // Nothing left to do... stay in IDLE.
                    DEBUGCHK(pContext->Ep0State == EP0_STATE_IDLE);
                }
                fSendUDR = TRUE;
            }
        }
    }

    else if (pContext->Ep0State == EP0_STATE_OUT_DATA_PHASE)
    {
        DEBUGMSG(ZONE_TRANSFER, (_T("EP0_OUT_PHASE\r\n")));
    
           DWORD dwCountBytes = ReadReg(DOEPTSIZ0) & 0x7f;
        dwCountBytes = pContext->dwEp0MaxPktSize - dwCountBytes;
        peps->pTransfer->cbTransferred += dwCountBytes;

        DWORD dwRemainBytes = peps->pTransfer->cbBuffer - peps->pTransfer->cbTransferred;

        if (dwRemainBytes == 0)
        {                
            pContext->Ep0State = EP0_STATE_IDLE;
            pContext->sendDataEnd = TRUE;
               memcpy(peps->pTransfer->pvBuffer, pContext->pVAddrEP[0][OUT_EP] , peps->pTransfer->cbBuffer);
            dwStatus = UFN_NO_ERROR;
            fCompleted = TRUE;
            pContext->Ep0State = EP0_STATE_IDLE;
        }
        else
        {
            WriteReg(DOEPDMA0, pContext->pPAddrEP[0][OUT_EP] + peps->pTransfer->cbTransferred);
            WriteReg(DOEPTSIZ0, 1<<PACKET_COUTNT_IDX | pContext->dwEp0MaxPktSize);
            WriteReg(DOEPCTL0, EP_ENABLE | CLEAR_NAK | EP0_MAX_PK_SIZ);
        }
    }
    else
    {
        DEBUGMSG(ZONE_TRANSFER, (_T("EP0_IN_PHASE\r\n")));
        
        if(peps->pTransfer->cbBuffer >= (pContext->dwEp0MaxPktSize + peps->pTransfer->cbTransferred))
            peps->pTransfer->cbTransferred += pContext->dwEp0MaxPktSize;        
        else
            peps->pTransfer->cbTransferred = peps->pTransfer->cbBuffer;

        DWORD dwRemainBytes = peps->pTransfer->cbBuffer - peps->pTransfer->cbTransferred;

        if (dwRemainBytes == 0)
        {
            dwStatus = UFN_NO_ERROR;
            fCompleted = TRUE;
            pContext->Ep0State = EP0_STATE_IDLE;
        }
        else
        {
            WatiForTxFIFOEmpty(100);
            WriteReg(DIEPDMA0, pContext->pPAddrEP[0][IN_EP] + peps->pTransfer->cbTransferred);
            if (dwRemainBytes >= pContext->dwEp0MaxPktSize)
                WriteReg(DIEPTSIZ0, 1<<PACKET_COUTNT_IDX | pContext->dwEp0MaxPktSize);
            else
                  WriteReg(DIEPTSIZ0, 1<<PACKET_COUTNT_IDX | dwRemainBytes);      
            WriteReg(DIEPCTL0, EP_ENABLE | CLEAR_NAK | 1<<NEXT_EP_IDX | EP0_MAX_PK_SIZ);
        }
    }

    if (fCompleted)
    {
        CompleteTransfer(pContext, peps, dwStatus);
    }
    
    if (fSendUDR)
    {
        pContext->pfnNotify(pContext->pvMddContext, UFN_MSG_SETUP_PACKET, (DWORD) &pContext->UDR);
    }

    FUNCTION_LEAVE_MSG();
    UNLOCK_ENDPOINT(peps);
}


// Process an endpoint interrupt except endpoint0  
static
VOID
HandleOutEvent(
    PCTRLR_PDD_CONTEXT      pContext,
    DWORD                        dwEndpoint
    )
{
    SETFNAME();
    FUNCTION_ENTER_MSG();

    ValidateContext(pContext);
    DEBUGCHK(pContext->fRunning);
    DEBUGCHK(dwEndpoint != 0);

    EP_STATUS *peps = GetEpStatus(pContext, dwEndpoint);
    PREFAST_DEBUGCHK(peps);

    LOCK_ENDPOINT(peps);

    PSTransfer pTransfer = peps->pTransfer;
    
    DWORD dwCountBytes = ReadEPSpecificReg(dwEndpoint, DOEPTSIZ) & 0x7FFFF;
    pContext->dwPipelinedXfered[dwEndpoint][pContext->dwPipelinedStrIdx] = pContext->dwPipelinedXferSize - dwCountBytes;
    if(pContext->dwPipelinedXfered[dwEndpoint][pContext->dwPipelinedStrIdx] > pContext->dwPipelinedXferSize)
        pContext->dwPipelinedXfered[dwEndpoint][pContext->dwPipelinedStrIdx] = pContext->dwPipelinedXferSize;
    //For MSC compliance test : one of cases, A host send the data which is bigger than a device expect to get
    
    pContext->dwPipelinedStrIdx = GET_NEXT_PF_IDX(pContext->dwPipelinedStrIdx);
    
    if(pContext->dwUSBClassInfo != USB_MSF)
    {    
        if(pContext->dwPipelinedXfered[dwEndpoint][pContext->dwPipelinedStrIdx] == 0)
        {
            WriteEPSpecificReg(dwEndpoint, DOEPDMA, pContext->pPAddrEP[dwEndpoint][pContext->dwPipelinedStrIdx]);
            WriteEPSpecificReg(dwEndpoint, DOEPTSIZ, pContext->dwPipelinedPktCnt<<PACKET_COUTNT_IDX | pContext->dwPipelinedXferSize);
            WriteEPSpecificReg(dwEndpoint, DOEPCTL, EP_ENABLE | CLEAR_NAK | SET_TYPE_BULK | USB_ACT_EP | peps->dwPacketSizeAssigned);
        }
        else
        {
            RETAILMSG(UFN_ZONE_WARNING,(TEXT("RING BUFFER STATE : FULL\r\n")));
            DisableEndpointInterrupt(pContext, peps->dwEndpointNumber, peps->dwDirectionAssigned);
            pContext->bRingBufferFull = TRUE;
        }
    }

    if(pContext->dwPipelinedEP != 0)
    {
        memcpy(pTransfer->pvBuffer, \
                  pContext->pVAddrEP[dwEndpoint][pContext->dwPipelinedEndIdx] , \
                  pContext->dwPipelinedXfered[dwEndpoint][pContext->dwPipelinedEndIdx]); 

        pTransfer->cbTransferred += pContext->dwPipelinedXfered[dwEndpoint][pContext->dwPipelinedEndIdx];
        pContext->dwPipelinedXfered[dwEndpoint][pContext->dwPipelinedEndIdx] = 0;
        pContext->dwPipelinedEndIdx = GET_NEXT_PF_IDX(pContext->dwPipelinedEndIdx);
        pContext->dwPipelinedEP = 0;
        DisableEndpointInterrupt(pContext, peps->dwEndpointNumber, peps->dwDirectionAssigned);    
        CompleteTransfer(pContext, peps, UFN_NO_ERROR);
    }

    UNLOCK_ENDPOINT(peps);
    FUNCTION_LEAVE_MSG();
}


static
VOID
HandleInEvent(
    PCTRLR_PDD_CONTEXT    pContext,
    DWORD                        dwEndpoint
    )
{
    SETFNAME();
    FUNCTION_ENTER_MSG();

    ValidateContext(pContext);
    DEBUGCHK(pContext->fRunning);
    DEBUGCHK(dwEndpoint != 0);

    EP_STATUS *peps = GetEpStatus(pContext, dwEndpoint);
    PREFAST_DEBUGCHK(peps);

    LOCK_ENDPOINT(peps);

    if(pContext->dwInEPRunning[dwEndpoint])
    {
        pContext->dwInEPRunning[dwEndpoint] = 0;
        pContext->dwXmitReadyCnt--;
        pContext->dwXmittingEP |= (1<<dwEndpoint);

        if (pContext->dwXmitReadyCnt == 0)
        {
            WriteReg(DIEPMSK, TIMEOUT_CONDITION | XFER_COMPLETE);
        }

        PSTransfer pTransfer = peps->pTransfer;

        DWORD dwPktcnt, dwBytes;

        if (pTransfer->cbBuffer == 0)
        {
            dwPktcnt = 1;
        }
        else
        {
            dwPktcnt = pTransfer->cbBuffer / peps->dwPacketSizeAssigned;
            dwBytes = pTransfer->cbBuffer % peps->dwPacketSizeAssigned;
            if (dwBytes) dwPktcnt++;
        }

        WatiForTxFIFOEmpty(100);
        WriteEPSpecificReg(dwEndpoint, DIEPDMA, pContext->pPAddrEP[dwEndpoint][IN_EP]);
        WriteEPSpecificReg(dwEndpoint, DIEPTSIZ, dwPktcnt<<PACKET_COUTNT_IDX | pTransfer->cbBuffer);


        if (pContext->dwUSBClassInfo == USB_RNDIS)
        {
            if (dwEndpoint == 1)
                WriteEPSpecificReg(dwEndpoint, DIEPCTL, EP_ENABLE | CLEAR_NAK | SET_TYPE_BULK | USB_ACT_EP | 2<<NEXT_EP_IDX | peps->dwPacketSizeAssigned);     
            else
                WriteEPSpecificReg(dwEndpoint, DIEPCTL, EP_ENABLE | CLEAR_NAK | SET_TYPE_BULK | USB_ACT_EP | 0<<NEXT_EP_IDX | peps->dwPacketSizeAssigned);     
        }
        else
        {
            WriteEPSpecificReg(dwEndpoint, DIEPCTL, EP_ENABLE | CLEAR_NAK | SET_TYPE_BULK | USB_ACT_EP | 0<<NEXT_EP_IDX | peps->dwPacketSizeAssigned);     
        }
    }

    UNLOCK_ENDPOINT(peps);
    FUNCTION_LEAVE_MSG();
}


static
VOID
SetEndpoint(
    PCTRLR_PDD_CONTEXT    pContext
    )
{
    DWORD dwEndpoint;

     // Clear all device endpoint interrupt
    for(dwEndpoint=0; dwEndpoint<ENDPOINT_COUNT; dwEndpoint++)
    {
        WriteEPSpecificReg(dwEndpoint, DIEPINT, 0x3f);
        WriteEPSpecificReg(dwEndpoint, DOEPINT, 0x3f);
    }
}


inline
static
VOID
SetAllOutEpNak()
{
    DWORD dwEndpoint;

    for(dwEndpoint=0; dwEndpoint<ENDPOINT_COUNT; dwEndpoint++)
    {
        SetClearEPSpecificReg(dwEndpoint, DOEPCTL, SET_NAK, SET);
    }
}


inline
static
VOID
ClearAllOutEpNak()
{
    DWORD dwEndpoint;

    for(dwEndpoint=0; dwEndpoint<ENDPOINT_COUNT; dwEndpoint++)
    {
           SetClearEPSpecificReg(dwEndpoint, DOEPCTL, CLEAR_NAK, SET);
    }
}


static
VOID
HandleReset(
    PCTRLR_PDD_CONTEXT    pContext
    )
{
    DWORD dwGOTGCTL = ReadReg(GOTGCTL);

    if (pContext->attachedState == UFN_DETACH)
    {
        if(dwGOTGCTL & (B_SESSION_VALID|A_SESSION_VALID))
        {
            if (pContext->IsFirstReset == TRUE)
            {
                Sleep(2000);        // For Sleep Wake Up Connection issue.
            }
            pContext->IsFirstReset = FALSE;            

            SetAllOutEpNak();

            // Below function(ResetDevice) make USB compliance Test(chir timimg) fail. 
            // So If your usb H/W have usb plug detect signal, This function should be moved to Plug thread fucntion.
            ResetDevice(pContext);          
            
            ClearAllOutEpNak();                    

            pContext->fSpeedReported = FALSE;
            pContext->Ep0State = EP0_STATE_IDLE;
            pContext->attachedState = UFN_ATTACH;
            pContext->pfnNotify(pContext->pvMddContext, UFN_MSG_BUS_EVENTS, UFN_ATTACH);

            RETAILMSG(UFN_ZONE_USB_EVENTS,(_T("[UFNPDD] OTG Cable Attached\r\n")));
        }
        else
        {
            pContext->pfnNotify(pContext->pvMddContext, UFN_MSG_BUS_EVENTS, UFN_DETACH);
            pContext->attachedState = UFN_DETACH;                
            RETAILMSG(UFN_ZONE_USB_EVENTS,(_T("[UFNPDD] RESET Exeption \r\n")));
        }
    }
    else
    {
        if(!(dwGOTGCTL & (B_SESSION_VALID|A_SESSION_VALID)))
        {
            pContext->pfnNotify(pContext->pvMddContext, UFN_MSG_BUS_EVENTS, UFN_DETACH);
            pContext->attachedState = UFN_DETACH;                
        }
        else
        {        
            // USB Device Address field should be cleared per every reset time.
            // If not, USB Compliance Frame work test(EnumerationTest) make a fail.
            volatile DWORD wDCFG = ReadReg(DCFG);
            WriteReg(DCFG, (wDCFG & ~(DEVICE_ADDRESS_MSK)));    
            
            InitDevice(pContext);
            InitPDDContext(pContext);

            // Initialize EP0 Out DMA to get a SetUp packet
            WriteReg(DOEPDMA0, pContext->pPAddrEP[0][OUT_EP]);
            WriteReg(DOEPTSIZ0, 1<<SETUP_PKT_CNT_IDX | 1<<PACKET_COUTNT_IDX | 8);
            WriteReg(DOEPCTL0, EP_ENABLE | CLEAR_NAK | EP0_MAX_PK_SIZ);
        
            RETAILMSG(UFN_ZONE_USB_EVENTS,(_T("[UFNPDD] RESET Again \r\n")));
        }
    }
}


// Process USB Bus interrupt
static
VOID
HandleUSBBusIrq(
    PCTRLR_PDD_CONTEXT    pContext,
    DWORD               bUSBBusIrqStat
    )
{
    SETFNAME();
    FUNCTION_ENTER_MSG();

    ValidateContext(pContext);

    if (bUSBBusIrqStat & INT_RESET)
    {
        HandleReset(pContext);
        WriteReg(GINTSTS, INT_RESET);
        DEBUGMSG(ZONE_USB_EVENTS, (_T("%s Reset\r\n"), pszFname));
        pContext->pfnNotify(pContext->pvMddContext, UFN_MSG_BUS_EVENTS, UFN_RESET);
    }

    // for Transmit data holding issue in RNDIS ++ //
    if (bUSBBusIrqStat & INT_EPMIS)
    {
        WriteReg(GINTSTS, INT_EPMIS);
        ClearAllOutEpNak();
        SetClearReg(DCTL, CLEAR_GOUTNAK, SET);
    }
    // for Transmit data holding issue in RNDIS -- //

    if (bUSBBusIrqStat & INT_SDE)
    {
        WriteReg(GINTSTS, INT_SDE);
        DWORD dwDSTS = ReadReg(DSTS);
        if (((dwDSTS & ENUM_SPEED_MSK)>>1) == USB_HIGH)
        {
            pContext->dwDetectedSpeed = USB_HIGH;
            pContext->dwEp0MaxPktSize = EP_0_PACKET_SIZE;
        }
        else if(((dwDSTS & ENUM_SPEED_MSK)>>1) == USB_FULL)
        {
            pContext->dwDetectedSpeed = USB_FULL;
            pContext->dwEp0MaxPktSize = EP_0_PACKET_SIZE;
        }
        else
        {
            RETAILMSG(UFN_ZONE_ERROR,(_T("[UFNPDD] INT_SDE_EXEPTION Occured! \r\n")));
        }
        SetEndpoint(pContext);
    }

    if (bUSBBusIrqStat & INT_RESUME)
    {
        WriteReg(GINTSTS, INT_RESUME);
        pContext->pfnNotify(pContext->pvMddContext, UFN_MSG_BUS_EVENTS, UFN_RESUME);
    }

    if (bUSBBusIrqStat & INT_SUSPEND)
    {
        WriteReg(GINTSTS, INT_SUSPEND);
        pContext->pfnNotify(pContext->pvMddContext, UFN_MSG_BUS_EVENTS, UFN_SUSPEND);
    }

    if (bUSBBusIrqStat & INT_OTG)
    {
        DWORD dwGotgint = ReadReg(GOTGINT);
        if (dwGotgint & SesEndDet)
        {    
            RETAILMSG(UFN_ZONE_USB_EVENTS,(_T("[UFNPDD] OTG Cable Detached\r\n")));
            pContext->pfnNotify(pContext->pvMddContext, UFN_MSG_BUS_EVENTS, UFN_DETACH);
            pContext->attachedState = UFN_DETACH;
            pContext->IsFirstReset = TRUE;
            pContext->bOutEPDMAStartFlag = FALSE;
        }
        else
        {
            DEBUGMSG(ZONE_ERROR,(_T("[UFNPDD] OTG Interrupt Exeption %x\r\n"),dwGotgint));
        }
        WriteReg(GOTGINT, dwGotgint);
    }
    FUNCTION_LEAVE_MSG();
}


static
VOID
HandleUSBEvent(
    PCTRLR_PDD_CONTEXT    pContext
    )
{
    SETFNAME();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩av高清在线观看| 欧美男女性生活在线直播观看| av电影在线观看完整版一区二区| 欧美日韩一区高清| 国产亚洲va综合人人澡精品| 日韩精品国产精品| 91免费视频网| 亚洲国产精品成人综合色在线婷婷| 亚洲精品国产成人久久av盗摄 | 黄色成人免费在线| 91国偷自产一区二区三区观看| 久久精品亚洲国产奇米99| 日韩高清不卡一区二区三区| 欧美亚洲免费在线一区| 亚洲欧洲精品一区二区三区不卡| 秋霞国产午夜精品免费视频| 欧美性欧美巨大黑白大战| 国产精品欧美久久久久一区二区| 久久99最新地址| 91精品在线观看入口| 亚洲综合丝袜美腿| 色94色欧美sute亚洲线路二| 国产情人综合久久777777| 久久福利资源站| 日韩女优av电影| 免费一级欧美片在线观看| 欧美精品777| 日韩激情中文字幕| 欧美电影影音先锋| 日本免费在线视频不卡一不卡二| 欧美精品久久一区二区三区| 香蕉久久一区二区不卡无毒影院 | 欧美成人精品3d动漫h| 五月天中文字幕一区二区| 欧美色网一区二区| 婷婷夜色潮精品综合在线| 欧美日韩在线精品一区二区三区激情| 亚洲最大色网站| 欧美日韩国产综合久久| 婷婷综合另类小说色区| 日韩亚洲电影在线| 国产麻豆成人精品| 国产日本欧洲亚洲| 99精品久久99久久久久| 亚洲国产va精品久久久不卡综合| 欧美久久一二区| 天堂蜜桃一区二区三区| 国产精品久久久久影视| 一本久久a久久精品亚洲 | 国产精品欧美经典| 色综合久久综合网97色综合| 亚洲成人动漫在线观看| 91精品福利在线一区二区三区| 免费在线观看不卡| 欧美国产丝袜视频| 欧美偷拍一区二区| 精品一区二区三区的国产在线播放| 亚洲精品一线二线三线| av电影在线观看不卡| 五月激情综合婷婷| 国产亚洲成av人在线观看导航| 91女人视频在线观看| 舔着乳尖日韩一区| 久久久激情视频| 日本久久精品电影| 麻豆精品视频在线观看免费| 国产精品天美传媒| 欧美日韩精品久久久| 国产激情视频一区二区在线观看| 1区2区3区国产精品| 欧美一区二区三区四区五区| 国产99久久久精品| 亚洲午夜久久久| 国产精品欧美久久久久一区二区| 欧美日韩一区二区三区四区| 国产麻豆视频精品| 日产国产欧美视频一区精品| 欧美韩国日本一区| 欧美va日韩va| 欧美色爱综合网| 国产不卡视频在线播放| 男男视频亚洲欧美| 亚洲综合男人的天堂| 国产午夜亚洲精品不卡| 91精品国产品国语在线不卡| 99久久精品情趣| 黄页网站大全一区二区| 亚洲a一区二区| 亚洲男女一区二区三区| 欧美国产欧美亚州国产日韩mv天天看完整| 在线观看91精品国产入口| 高清不卡在线观看| 毛片av一区二区| 亚洲444eee在线观看| 亚洲精品乱码久久久久久久久| 国产午夜一区二区三区| ww久久中文字幕| 91精品国产一区二区三区蜜臀| 在线看日本不卡| 色网站国产精品| jlzzjlzz欧美大全| av午夜精品一区二区三区| 国产成人在线影院| 国产精品中文字幕一区二区三区| 秋霞午夜鲁丝一区二区老狼| 亚洲成va人在线观看| 亚洲一区二区视频在线观看| 中文字幕人成不卡一区| 国产精品国产馆在线真实露脸| 欧美韩日一区二区三区四区| 国产日产欧美一区二区三区 | 亚洲欧洲www| 国产色一区二区| 国产亚洲欧美日韩俺去了| 精品国产一区二区三区av性色| 宅男噜噜噜66一区二区66| 在线播放视频一区| 欧美精品一卡二卡| 91精品国产综合久久久蜜臀粉嫩| 欧美日韩一区在线| 日韩一区二区三区视频在线观看| 欧美二区乱c少妇| 日韩欧美国产一区二区在线播放 | 国产精品99久久久久| 国产成人鲁色资源国产91色综 | 亚洲黄色av一区| 一区二区三区精品视频| 天堂久久久久va久久久久| 免费成人你懂的| 国产福利精品一区二区| 99精品偷自拍| 欧美三电影在线| 日韩欧美国产一区在线观看| 国产丝袜美腿一区二区三区| 国产精品久久久久久久久动漫 | 亚洲在线中文字幕| 日本欧美一区二区三区| 国产老肥熟一区二区三区| aaa欧美色吧激情视频| 欧洲一区在线电影| 日韩一区二区在线观看视频| 国产亚洲欧美在线| 一区二区三区色| 另类成人小视频在线| 成人免费视频一区二区| 欧美性猛交一区二区三区精品| 欧美tickle裸体挠脚心vk| 国产精品人成在线观看免费| 亚洲午夜私人影院| 国产综合久久久久久久久久久久| av电影在线观看完整版一区二区| 欧美精品丝袜久久久中文字幕| 久久亚洲春色中文字幕久久久| 亚洲美女一区二区三区| 精品综合久久久久久8888| 色妞www精品视频| 日韩美女一区二区三区| 亚洲视频免费观看| 久草精品在线观看| 色婷婷精品大视频在线蜜桃视频| 精品国产一区二区三区不卡 | 日韩视频国产视频| 亚洲欧洲精品一区二区三区不卡| 蜜桃传媒麻豆第一区在线观看| www.av亚洲| 欧美不卡一区二区三区四区| 亚洲免费观看高清完整版在线观看 | 亚洲欧美一区二区三区国产精品 | 亚洲男人都懂的| 国产成人午夜高潮毛片| 欧美人狂配大交3d怪物一区| 国产精品二三区| 黄色日韩网站视频| 7777精品久久久大香线蕉| 亚洲三级视频在线观看| 国产一区二区剧情av在线| 欧美一区二区视频在线观看| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆 | 一区二区在线观看免费| 成人永久免费视频| 欧美不卡一区二区三区| 午夜a成v人精品| 欧美专区日韩专区| 国产精品国产三级国产| 丰满少妇久久久久久久| 久久在线观看免费| 青草av.久久免费一区| 欧美影院午夜播放| 亚洲资源在线观看| 91精彩视频在线| 亚洲人成7777| 一本到高清视频免费精品| 国产精品激情偷乱一区二区∴| 国产精品69毛片高清亚洲| 久久久国产一区二区三区四区小说 | 国产一区二区福利| 久久综合国产精品| 国产精品自在在线| 久久精品亚洲国产奇米99| 国产精品一线二线三线|