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

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

?? cdio.cpp

?? WinCE5.0BSP for Renesas SH7770
?? CPP
?? 第 1 頁 / 共 3 頁
字號(hào):
//
//  Copyright(C) Renesas Technology Corp. 2005. All rights reserved.
//
// ATAPI(UDFS) driver for ITS-DS7
//
// FILE     : atamain.cpp
// CREATED  : 2005.02.10
// MODIFIED : 2005.04.14
// AUTHOR   : Renesas Technology Corp.
// HARDWARE : RENESAS ITS-DS7
// HISTORY  : 
//            2005.02.10
//            - Created release code.
//                (based on PUBLIC ATAPI driver for WCE5.0)
//            2005.04.14
//            - Modified adjustment of a timing.

//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
#include <atamain.h>
#include <atapishxcd.h>



DWORD CSHXDiskAndCD::AtapiIoctl(PIOREQ pIOReq)
{
    DWORD dwError = ERROR_SUCCESS;
    BOOL fIsDVD = FALSE;
    DEBUGMSG( ZONE_IOCTL, (TEXT("ATAPI:PerformIoctl: %x DeviceId: %x \r\n"),pIOReq->dwCode, m_dwDeviceId));

    switch( pIOReq->dwCode) {
///////////////////// ATAPI  /////////////////////////////////////                
        case IOCTL_CDROM_READ_SG:
            // Verify that the buffer is of valid size
            {
                if (!AtapiIsUnitReadyEx()) return ERROR_NOT_READY;
                if ((pIOReq->pInBuf == NULL) ||
                   (pIOReq->pBytesReturned == NULL) ||
                   !ValidateSg((CDROM_READ *)pIOReq->pInBuf,pIOReq->dwInBufSize)) {
                    dwError = ERROR_INVALID_PARAMETER;
                } else {
                    dwError = ReadCdRom((CDROM_READ *)pIOReq->pInBuf, pIOReq->pBytesReturned);
                }    
            }    
            break;
        case IOCTL_CDROM_RAW_READ:
            {
                if (!AtapiIsUnitReadyEx()) return ERROR_NOT_READY;
                RAW_READ_INFO *prri = (RAW_READ_INFO *)pIOReq->pInBuf;
                if (prri && (pIOReq->dwInBufSize == sizeof(RAW_READ_INFO)) && pIOReq->pOutBuf) {
                    CDROM_READ cdr;
                    cdr.StartAddr.Mode = CDROM_ADDR_LBA;
                    cdr.bRawMode = TRUE;
                    cdr.sgcount = 1;
                    cdr.TrackMode = CDDA;
                    cdr.StartAddr.Address.lba = prri->DiskOffset.LowPart;
                    cdr.TransferLength = (DWORD)(prri->SectorCount & 0xffffffff);
                    cdr.sglist[0].sb_buf = pIOReq->pOutBuf;
                    cdr.sglist[0].sb_len = pIOReq->dwOutBufSize;
                    dwError = ReadCdRom(&cdr, pIOReq->pBytesReturned);
                } else {
                    dwError = ERROR_INVALID_PARAMETER;
                }    
            }    
            break;
        case IOCTL_CDROM_TEST_UNIT_READY:
            if (!AtapiIsUnitReady(pIOReq)) {
                dwError = ERROR_NOT_READY;
            }
            break;   
        case IOCTL_CDROM_DISC_INFO:
            if (!AtapiIsUnitReadyEx()) return ERROR_NOT_READY;
            dwError = AtapiGetDiscInfo(pIOReq);
            break;    
        case IOCTL_CDROM_EJECT_MEDIA:
            dwError = AtapiLoadMedia(TRUE);
            break;
        case IOCTL_CDROM_LOAD_MEDIA:
            dwError = AtapiLoadMedia(FALSE);
            break;
        case IOCTL_CDROM_GET_SENSE_DATA:
            {
                CD_SENSE_DATA *pSenseData = (CD_SENSE_DATA *)pIOReq->pOutBuf;
                if ((pSenseData == NULL) || 
                    (pIOReq->dwOutBufSize < sizeof(CD_SENSE_DATA))) {
                    dwError = ERROR_INVALID_PARAMETER;
                } else {
                    dwError = AtapiGetSenseInfo(pSenseData)? ERROR_SUCCESS : ERROR_GEN_FAILURE;
                }    
            }    
            break;
        case IOCTL_CDROM_ISSUE_INQUIRY:
            {
                INQUIRY_DATA *pInquiryData = (INQUIRY_DATA *)pIOReq->pOutBuf;
                if ((pInquiryData == NULL) || 
                    (pIOReq->dwOutBufSize< sizeof(INQUIRY_DATA))) {
                    dwError = ERROR_INVALID_PARAMETER;
                } else {
                    dwError = AtapiIssueInquiry(pInquiryData)? ERROR_SUCCESS : ERROR_GEN_FAILURE;
                }  
            }
            break;
        case IOCTL_CDROM_READ_TOC:
            {
                if (!AtapiIsUnitReadyEx()) return ERROR_NOT_READY;
                CDROM_TOC *pTOC = NULL;
                if (pIOReq->pInBuf && (pIOReq->dwInBufSize == sizeof(CDROM_TOC))) {
                    pTOC = (CDROM_TOC *)pIOReq->pInBuf;
                } else 
                if (pIOReq->pOutBuf && (pIOReq->dwOutBufSize == sizeof(CDROM_TOC))) {
                    pTOC = (CDROM_TOC *)pIOReq->pOutBuf;
                }    
                if (pTOC == NULL) {
                    dwError = ERROR_INVALID_PARAMETER;
                } else {
                    dwError = AtapiGetToc(pTOC) ? ERROR_SUCCESS : ERROR_GEN_FAILURE;
                }  
            }
            break;                
///////////////////// DVD ///////////////////////////////////////                
        case IOCTL_DVD_START_SESSION:
        case IOCTL_DVD_READ_KEY:
            if (!AtapiIsUnitReadyEx()) return ERROR_NOT_READY;
            dwError = DVDReadKey(pIOReq);
            break;
        case IOCTL_DVD_END_SESSION:
        case IOCTL_DVD_SEND_KEY:
            if (!AtapiIsUnitReadyEx()) return ERROR_NOT_READY;
            dwError = DVDSendKey(pIOReq);
            break;
        case IOCTL_DVD_GET_REGION:
            dwError = DVDGetRegion(pIOReq);
            break;
        case IOCTL_DVD_SET_REGION:
            dwError = DVDSetRegion(pIOReq);
            break;    
///////////////////// CDAUDIO ///////////////////////////////////                
        case IOCTL_CDROM_READ_Q_CHANNEL:
            if (!AtapiIsUnitReadyEx()) return ERROR_NOT_READY;
            dwError = AtapiReadQChannel(pIOReq);
            break;
        case IOCTL_CDROM_PLAY_AUDIO_MSF:
        case IOCTL_CDROM_SEEK_AUDIO_MSF:
        case IOCTL_CDROM_RESUME_AUDIO:
        case IOCTL_CDROM_STOP_AUDIO:
        case IOCTL_CDROM_PAUSE_AUDIO:
        case IOCTL_CDROM_SCAN_AUDIO:
            if (!AtapiIsUnitReadyEx()) return ERROR_NOT_READY;
            dwError = ControlAudio(pIOReq);
            break;
        default:
            dwError = ERROR_NOT_SUPPORTED;
            break;
    }        
    return dwError;
}


BOOL CSHXDiskAndCD::AtapiIsUnitReadyEx()
{
    DWORD dwCount;
    for (dwCount = 0; dwCount < 5; dwCount++) {
        if (AtapiIsUnitReady()) {
            m_dwLastCheckTime = GetTickCount();
            break;
        }    
        StallExecution(100);
    }
    if (dwCount == 5)
        return FALSE;
    return TRUE;
}

DWORD CSHXDiskAndCD::SetupCdRomRead(BOOL bRawMode, DWORD dwLBAAddr, DWORD dwTransferLength, PATAPI_COMMAND_PACKET pCmdPkt)
{
    BOOL fIsDVD = (m_dwDeviceFlags & DFLAGS_DEVICE_ISDVD);

    memset( pCmdPkt, 0, sizeof(ATAPI_COMMAND_PACKET));


    /**** Atapi Packet *****
    Byte 0 - Cmd/OpCode
    Byte 1 - N/A
    Byte 2 - Logical Block (MSB)
    Byte 2 - Logical Block 
    Byte 2 - Logical Block 
    Byte 2 - Logical Block (LSB)
    Byte 6 - Reserved
    Byte 7 - DataLength (MSB)
    Byte 8 - DataLength (LSB)
    Byte 9 - Control Byte
    ****** Atapi Packet ****/
    pCmdPkt->Byte_1 = 0x00;
    pCmdPkt->Byte_2 = LBA_MSB(&dwLBAAddr);
    pCmdPkt->Byte_3 = LBA_3rdLSB(&dwLBAAddr);
    pCmdPkt->Byte_4 = LBA_2ndLSB(&dwLBAAddr);
    pCmdPkt->Byte_5 = LBA_LSB(&dwLBAAddr);
    if (fIsDVD && !bRawMode) {
        pCmdPkt->Opcode = ATAPI_PACKET_CMD_READ_12;
        pCmdPkt->Byte_6 = (BYTE)( dwTransferLength >> 24);
        pCmdPkt->Byte_7 = (BYTE)( (dwTransferLength & 0x00ff0000) >> 16);
        pCmdPkt->Byte_8 = (BYTE)( (dwTransferLength & 0x0000ff00) >> 8);
        pCmdPkt->Byte_9 = (BYTE)( dwTransferLength);
    } else {
        pCmdPkt->Opcode = bRawMode ? ATAPI_PACKET_CMD_READ_CD : ATAPI_PACKET_CMD_READ;
        pCmdPkt->Byte_6 = 0x00; // Reserved
        pCmdPkt->Byte_7 = (BYTE)( (dwTransferLength & 0x0000ff00) >> 8);
        pCmdPkt->Byte_8 = (BYTE)( dwTransferLength);
        pCmdPkt->Byte_9 = 0x10;
    }

    pCmdPkt->Byte_10 = 0;          
    return ERROR_SUCCESS;
}

DWORD CSHXDiskAndCD::ReadCdRom(CDROM_READ *pReadInfo, PDWORD pBytesReturned)
{
    ATAPI_COMMAND_PACKET    CmdPkt;
    CDROM_ADDR              CurAddr;
    WORD                    wSectorSize;
    DWORD                   dwError=ERROR_SUCCESS;
    PSGX_BUF                pSgBuf;
    
    GetBaseStatus(); // Clear Interrupt if it is already set 
    
    CurAddr = pReadInfo->StartAddr;

    // The request must either be in MSF format or LBA format
    DEBUGCHK(pReadInfo->StartAddr.Mode == CDROM_ADDR_MSF || pReadInfo->StartAddr.Mode == CDROM_ADDR_LBA);
    
    DEBUGMSG( ZONE_IO | ZONE_CDROM, (TEXT("ATAPI:ReadCdRom Address=%ld Mode=%02X Length=%ld TrackMode=%02X\r\n"), CurAddr.Address, CurAddr.Mode, pReadInfo->TransferLength, pReadInfo->TrackMode));

    // If in MSF format then convert it to LBA
    if (CurAddr.Mode == CDROM_ADDR_MSF) {
        CDROM_MSF_TO_LBA(&CurAddr);
    }    
    // Verify that the transfer count is not 0
    if ((pReadInfo->TransferLength == 0) || 
       (pReadInfo->sgcount == 0)) {
       return ERROR_INVALID_PARAMETER;
    }

    if( pReadInfo->bRawMode) {
        wSectorSize = CDROM_RAW_SECTOR_SIZE;
    } else {
        wSectorSize = CDROM_SECTOR_SIZE;
    }

    pSgBuf = &(pReadInfo->sglist[0]);

    if (IsDMASupported()) {
        dwError = ReadCdRomDMA(CurAddr.Address.lba, pReadInfo->TransferLength, wSectorSize, pReadInfo->sgcount, pSgBuf);
        if (dwError == ERROR_SUCCESS) {
            *(pBytesReturned) = pReadInfo->TransferLength * wSectorSize;
        }
    } else {
        SetupCdRomRead(pReadInfo->bRawMode, CurAddr.Address.lba, pReadInfo->TransferLength, &CmdPkt);
        
        if (AtapiSendCommand(&CmdPkt, wSectorSize, IsDMASupported())) {
            if (!AtapiReceiveData(pSgBuf, pReadInfo->sgcount,pBytesReturned)) {
                dwError = ERROR_READ_FAULT;
            }
        } else {
             dwError = ERROR_READ_FAULT;
        }
    }    
    return dwError;
}

DWORD CSHXDiskAndCD::ReadCdRomDMA(DWORD dwLBAAddr, DWORD dwTransferLength, WORD wSectorSize, DWORD dwSgCount, SGX_BUF *pSgBuf)
{
    ATAPI_COMMAND_PACKET    CmdPkt;
    DWORD                   dwError=ERROR_SUCCESS;
    DWORD               dwSectorsToTransfer;
    SG_BUF              CurBuffer[MAX_SG_BUF];
    WORD                wCount;
    SG_BUF                  SgBufTemp;

    DWORD dwStartBufferNum = 0, dwEndBufferNum = 0, dwEndBufferOffset = 0;
    DWORD dwNumSectors = dwTransferLength;
    DWORD dwStartSector = dwLBAAddr;
	DWORD dwSectorsToTransferMax = ATAPI_BUFFER_SIZE / wSectorSize;

    // Process the SG buffers in blocks of MAX_CD_SECT_PER_COMMAND.  Each DMA request will have a new SG_BUF array 
    // which will be a subset of the original request, and may start/stop in the middle of the original buffer.
    while (dwNumSectors) {
        dwSectorsToTransfer = (dwNumSectors > dwSectorsToTransferMax) ? dwSectorsToTransferMax : dwNumSectors;
    
        DWORD dwBufferLeft = dwSectorsToTransfer * wSectorSize;
        DWORD dwNumSg = 0;

        while (dwBufferLeft) {
            DWORD dwCurBufferLen = pSgBuf[dwEndBufferNum].sb_len - dwEndBufferOffset;

            if (dwBufferLeft < dwCurBufferLen) {
                // The buffer left for this block is less than the current SG buffer length
                CurBuffer[dwEndBufferNum - dwStartBufferNum].sb_buf = pSgBuf[dwEndBufferNum].sb_buf + dwEndBufferOffset;
                CurBuffer[dwEndBufferNum - dwStartBufferNum].sb_len = dwBufferLeft;
                dwEndBufferOffset += dwBufferLeft;
                dwBufferLeft = 0;
            } else {
                // The buffer left for this block is greater than or equal to the current SG buffer length.  Move on to the next SG buffer.
                CurBuffer[dwEndBufferNum - dwStartBufferNum].sb_buf = pSgBuf[dwEndBufferNum].sb_buf + dwEndBufferOffset;
                CurBuffer[dwEndBufferNum - dwStartBufferNum].sb_len = dwCurBufferLen;
                dwEndBufferOffset = 0;
                dwEndBufferNum++;
                dwBufferLeft -= dwCurBufferLen;
            }    
            dwNumSg++;
        }
	    SgBufTemp.sb_len = dwSectorsToTransfer * wSectorSize;
	    SgBufTemp.sb_buf = NULL;

        SetupCdRomRead( wSectorSize == CDROM_RAW_SECTOR_SIZE ? TRUE : FALSE, dwStartSector, dwSectorsToTransfer, &CmdPkt);

        wCount = (SHORT)(SgBufTemp.sb_len >> 1);

        if (AtapiSendCommand(&CmdPkt, wCount, IsDMASupported())) {
			if (!SetupDMA( &SgBufTemp, 1, TRUE)) {
			    dwError = ERROR_READ_FAULT;
			    goto ExitFailure;
			}

	        BeginDMA(TRUE);

            if (m_fInterruptSupported) {
                if (!WaitForInterrupt(m_dwDiskIoTimeOut)) {  
                    DEBUGMSG( ZONE_IO, (TEXT("ATAPI:ReadCdRom- WaitforInterrupt failed (DevId %x) \r\n"),m_dwDeviceId));
                    dwError = ERROR_READ_FAULT;
                    goto ExitFailure;
                }
            }    
            if (EndDMA()) {
                WaitOnBusy(FALSE);
                CompleteDMA( CurBuffer, dwNumSg, TRUE);
            } else {
                dwError = ERROR_READ_FAULT;
                goto ExitFailure;
            }    
        }

        dwStartSector += dwSectorsToTransfer;
        dwStartBufferNum = dwEndBufferNum;
        dwNumSectors -= dwSectorsToTransfer;        
    }    


ExitFailure:
    if (dwError != ERROR_SUCCESS) {
        AbortDMA();
    }    
    return dwError;
}

/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
//---------------------------------------------------------------------------
//
//  Send command to ATA Device.
//
//---------------------------------------------------------------------------

BOOL CSHXDiskAndCD::AtapiSendCommand(PATAPI_COMMAND_PACKET pCmdPkt, WORD wCount, BOOL fDMA)
{
    // Set the Drive/Head registers 
    SelectDevice();
    GetBaseStatus();

    SelectDevice();
     if (WaitOnBusy(FALSE))
     {  
         if (GetError() & ATA_STATUS_ERROR)
         {      
            return FALSE;
         }
     }
#if 1
//    for( DWORD dwCount = 0; dwCount < 10; dwCount++)   {
//        if( WaitForInterrupt(0)) {
//            break;
//        }    
//    }
#endif 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产电影一区二区| 日韩亚洲欧美在线| 久久99精品久久久| 亚洲国产精品传媒在线观看| 欧美精品自拍偷拍动漫精品| 成人黄色小视频| 麻豆国产精品视频| 亚洲亚洲人成综合网络| 国产拍揄自揄精品视频麻豆| 欧美顶级少妇做爰| 91在线高清观看| 国产米奇在线777精品观看| 亚洲国产一二三| 国产精品久久久久久一区二区三区 | 91精品黄色片免费大全| av一区二区不卡| 狠狠色综合日日| 日韩电影在线一区| 亚洲综合另类小说| 《视频一区视频二区| www激情久久| 日韩一级欧美一级| 51精品视频一区二区三区| 一本色道久久综合亚洲aⅴ蜜桃 | 日韩欧美一区二区在线视频| 色老头久久综合| 99这里只有久久精品视频| 国产伦理精品不卡| 麻豆精品久久精品色综合| 欧美aaaaa成人免费观看视频| 亚洲午夜精品久久久久久久久| 亚洲欧美日韩在线不卡| 国产精品高潮呻吟| 最新日韩在线视频| 中文字幕中文乱码欧美一区二区| 国产区在线观看成人精品| 精品国产a毛片| 97精品超碰一区二区三区| 成人精品视频一区| 国产馆精品极品| 另类欧美日韩国产在线| 天堂一区二区在线| 一个色在线综合| 亚洲色图清纯唯美| 欧美韩日一区二区三区四区| 精品国产免费一区二区三区香蕉 | 日韩一区二区免费高清| 日本乱码高清不卡字幕| 99久久久久久| 国产999精品久久| 国产精品中文字幕一区二区三区| 免费看欧美女人艹b| 免费精品视频在线| 免费观看成人av| 亚洲第一会所有码转帖| 亚洲韩国精品一区| 水野朝阳av一区二区三区| 亚洲国产色一区| 婷婷综合在线观看| 日韩不卡免费视频| 久久成人羞羞网站| 蜜桃视频在线观看一区| 久久草av在线| 国产精品一区二区不卡| 国产福利一区二区三区在线视频| 黄一区二区三区| 国产成人在线免费观看| 国产精品影视在线观看| 国产成人高清在线| 成人avav影音| 欧洲亚洲国产日韩| 欧美日韩亚洲综合在线| 91精品国产综合久久精品图片 | 国产视频一区在线播放| 久久久天堂av| 中文字幕精品一区二区精品绿巨人| 国产精品入口麻豆原神| 日韩av网站在线观看| 婷婷亚洲久悠悠色悠在线播放| 日本欧美在线看| 国模无码大尺度一区二区三区| 国产在线视频不卡二| 成人黄动漫网站免费app| 99riav一区二区三区| 欧美日韩高清不卡| 欧美精品一区二区三区四区 | 91浏览器打开| 欧美日韩大陆在线| 久久亚洲精品小早川怜子| 欧美精彩视频一区二区三区| 亚洲精品乱码久久久久久黑人| 亚洲精品国产品国语在线app| 一区二区三区免费观看| 精品一区二区三区免费毛片爱| 99久久99久久综合| 欧美久久婷婷综合色| 欧美精品一区二区三区很污很色的| 欧美国产精品一区二区三区| 一区二区三区在线观看视频| 麻豆一区二区99久久久久| 不卡一区二区在线| 欧美日韩不卡视频| 国产午夜亚洲精品不卡| 亚洲在线视频网站| 国产一区二区不卡| 欧美吞精做爰啪啪高潮| 欧美日韩成人一区| 亚洲精品福利视频网站| 亚洲国产aⅴ天堂久久| 国内成人免费视频| 欧美日韩国产小视频| 日本一区二区电影| 蜜桃91丨九色丨蝌蚪91桃色| 91色在线porny| 久久久一区二区三区| 亚洲成av人在线观看| 国产suv一区二区三区88区| 制服丝袜激情欧洲亚洲| 亚洲人成网站在线| 国产在线国偷精品产拍免费yy| 在线观看国产日韩| 国产精品黄色在线观看| 经典三级视频一区| 欧美视频一区在线观看| 国产精品欧美综合在线| 久久99久久99小草精品免视看| 欧美性色综合网| 久久久久久99精品| 国产毛片精品视频| 91精品国产综合久久久蜜臀粉嫩| 一区二区三区免费| www.欧美日韩| 久久久久久夜精品精品免费| 日韩成人精品在线观看| 欧美日韩在线电影| 一区二区三区在线观看欧美| 国产精品一二三区| 久久久久久亚洲综合影院红桃| 久国产精品韩国三级视频| 欧美一区二区三区视频免费| 亚洲国产一区视频| 欧美丝袜丝交足nylons| 亚洲与欧洲av电影| 欧美一a一片一级一片| 亚洲女女做受ⅹxx高潮| 国产在线精品一区二区不卡了| 欧美成人性战久久| 久久不见久久见免费视频7| 日韩女优制服丝袜电影| 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲精品国产视频| 色婷婷亚洲一区二区三区| 欧美国产激情一区二区三区蜜月 | 国产精品美女久久久久久2018| 国产九色精品成人porny| 久久免费视频色| 国内精品伊人久久久久av影院 | 久久久久久一二三区| 成人免费三级在线| 中文字幕日本不卡| 国产精品综合一区二区三区| 国产午夜亚洲精品理论片色戒| 成人中文字幕合集| 亚洲欧洲av在线| 97精品电影院| 婷婷综合另类小说色区| 日韩欧美中文一区| 国产高清不卡一区二区| 中文字幕中文字幕一区二区| 国产三级三级三级精品8ⅰ区| 精品亚洲国内自在自线福利| 久久精品日韩一区二区三区| 粉嫩aⅴ一区二区三区四区 | 亚洲国产精品一区二区久久恐怖片 | 激情欧美一区二区| 欧美国产精品劲爆| 91在线小视频| 亚洲国产aⅴ成人精品无吗| 欧美一级片在线看| 国产一区在线视频| 亚洲天堂成人网| 欧美午夜片在线看| 国产精一区二区三区| 亚洲欧美另类图片小说| 91精品国产高清一区二区三区蜜臀 | 欧美在线短视频| 久久99久久99小草精品免视看| 国产精品污www在线观看| 色综合av在线| 亚洲国产精品一区二区www在线| 日韩午夜电影av| 成熟亚洲日本毛茸茸凸凹| 国产精品国产三级国产三级人妇| 欧美精品色综合| 成人午夜视频网站| 午夜影院久久久| 国产精品区一区二区三区| 欧美亚洲日本国产| 韩国一区二区三区| 亚洲一区二区高清|