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

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

?? sdhcslot.cpp

?? 6410BSP3
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this sample source code is subject to the terms of the Microsoft
// license agreement under which you licensed this sample source code. If
// you did not accept the terms of the license agreement, you are not
// authorized to use this sample source code. For the terms of the license,
// please see the license agreement between you and Microsoft or, if applicable,
// see the LICENSE.RTF on your install media or the root of your tools installation.
// THE SAMPLE SOURCE CODE IS PROVIDED "AS IS", WITH NO WARRANTIES OR INDEMNITIES.
//

// Copyright (c) 2002 BSQUARE Corporation.  All rights reserved.
// DO NOT REMOVE --- BEGIN EXTERNALLY DEVELOPED SOURCE CODE ID 40973--- DO NOT REMOVE

#include <bsp.h>

#include "SDHC.h"
#include "SDHCSlot.h"

static volatile BSP_ARGS *v_gBspArgs;
#define CARD_INSERTED 1
#define CARD_REMOVED 2

#define _SRCCLK_48MHZ_  // USB_PHY 48MHZ Clock. Keep sync with "hsmmc_s3c6410.cpp"

// Macros
#define DX_D1_OR_D2(cps)            ((cps) == D1 || (cps) == D2)
#define SETFNAME()  LPCTSTR pszFname = _T(__FUNCTION__) _T(":")

#ifdef DEBUG
// dump the current request info to the debugger
static 
VOID 
DumpRequest(
            PSD_BUS_REQUEST pRequest,
            DWORD dwZone
            )
{   
    PREFAST_DEBUGCHK(pRequest);

    if (dwZone) {
        DEBUGMSG(1, (TEXT("DumpCurrentRequest: 0x%08X\n"), pRequest)); 
        DEBUGMSG(1, (TEXT("\t Command: %d\n"),  pRequest->CommandCode));
        DEBUGMSG(1, (TEXT("\t Argument: 0x%08x\n"),  pRequest->CommandArgument));
        DEBUGMSG(1, (TEXT("\t ResponseType: %d\n"),  pRequest->CommandResponse.ResponseType)); 
        DEBUGMSG(1, (TEXT("\t NumBlocks: %d\n"),  pRequest->NumBlocks)); 
        DEBUGMSG(1, (TEXT("\t BlockSize: %d\n"),  pRequest->BlockSize)); 
        DEBUGMSG(1, (TEXT("\t HCParam: %d\n"),    pRequest->HCParam)); 
    }
}
#else
#define DumpRequest(ptr, dw)
#endif


CSDHCSlotBase::CSDHCSlotBase(
        )
{
    m_pregDevice = NULL;
    m_SlotDma = NULL;
    m_dwSlot = 0;
    m_pbRegisters = NULL;
    m_pHCDContext = NULL;
    m_dwSysIntr = 0;
    m_hBusAccess = NULL;
    m_interfaceType = InterfaceTypeUndefined;
    m_dwBusNumber = 0;  

    m_dwVddWindows = 0;
    m_dwMaxClockRate = 0;
    m_dwTimeoutControl = 0;
    m_dwMaxBlockLen = 0;

    m_wRegClockControl = 0; 
    m_wIntSignals = 0;
    m_cpsCurrent = D0;
    m_cpsAtPowerDown = D0;

    m_dwDefaultWakeupControl = 0;
    m_bWakeupControl = 0;

#ifdef DEBUG
    m_dwReadyInts = 0;
#endif
    m_fCommandCompleteOccurred = FALSE;

    m_fSleepsWithPower = FALSE;
    m_fPowerUpDisabledInts = FALSE;
    m_fIsPowerManaged = FALSE;
    m_fSDIOInterruptsEnabled = FALSE;
    m_fCardPresent = FALSE;
    m_fAutoCMD12Success = FALSE;
    m_fCheckSlot = TRUE;
    m_fCanWakeOnSDIOInterrupts = FALSE;
    m_f4BitMode = FALSE;
    m_fFakeCardRemoval = FALSE;

    m_pCurrentRequest = NULL;
    m_fCurrentRequestFastPath = FALSE;

    m_fCommandPolling = TRUE;
    m_fDisableDMA = FALSE;

    m_dwPollingModeSize = NUM_BYTE_FOR_POLLING_MODE ;
}


CSDHCSlotBase::~CSDHCSlotBase(
        )
{
    if (m_SlotDma)
        delete m_SlotDma;
}


BOOL
CSDHCSlotBase::Init(
        DWORD               dwSlot,
        volatile BYTE      *pbRegisters,
        PSDCARD_HC_CONTEXT  pHCDContext,
        DWORD               dwSysIntr,
        HANDLE              hBusAccess,
        INTERFACE_TYPE      interfaceType, 
        DWORD               dwBusNumber,
        CReg               *pregDevice
        )
{
    BOOL fRet = TRUE;

    DEBUGCHK(dwSlot < SDHC_MAX_SLOTS);
    DEBUGCHK(pbRegisters);
    DEBUGCHK(pHCDContext);
    DEBUGCHK(hBusAccess);
    PREFAST_DEBUGCHK(pregDevice && pregDevice->IsOK());
    PREFAST_DEBUGCHK(m_SlotDma==NULL);

    m_dwSlot = dwSlot;
    m_pbRegisters = pbRegisters;
    m_pHCDContext = pHCDContext;
    m_dwSysIntr = dwSysIntr;
    m_hBusAccess = hBusAccess;
    m_interfaceType = interfaceType;
    m_dwBusNumber = dwBusNumber;
    m_pregDevice = pregDevice;

    fRet = SoftwareReset(SOFT_RESET_ALL);
    if (fRet) { 
        Sleep(10); // Allow time for card to power down after a device reset

        SSDHC_CAPABILITIES caps = GetCapabilities();

        DEBUGMSG(SDCARD_ZONE_INIT && caps.bits.SDMA,
                (_T("SDHC Will use DMA for slot %u\n"), m_dwSlot));

        m_dwVddWindows = DetermineVddWindows();
        m_dwMaxClockRate = DetermineMaxClockRate();
        m_dwMaxBlockLen = DetermineMaxBlockLen();
        m_dwTimeoutControl = DetermineTimeoutControl();
        m_dwDefaultWakeupControl = DetermineWakeupSources();
        m_fCanWakeOnSDIOInterrupts = m_pregDevice->ValueDW(SDHC_CAN_WAKE_ON_INT_KEY);
        m_dwPollingModeSize = m_pregDevice->ValueDW(SDHC_POLLINGMODE_SIZE, NUM_BYTE_FOR_POLLING_MODE);
        m_dwFastPathTimeoutTicks = m_pregDevice->ValueDW(SDHC_POLLINGMODE_TIMEOUT,POLLING_MODE_TIMEOUT_DEFAULT);
        m_fDisableDMA = (m_pregDevice->ValueDW(SDHC_DISABLE_DMA_KEY,0)!=0);
        Validate();

        DumpRegisters();
    }

    PHYSICAL_ADDRESS    ioPhysicalBase = {0,0};
    // Below code lines are needed for working as a mass storage device
    if (v_gBspArgs == NULL)
    {
        ioPhysicalBase.LowPart = IMAGE_SHARE_ARGS_PA_START;
        v_gBspArgs = (volatile BSP_ARGS *)MmMapIoSpace(ioPhysicalBase, sizeof(BSP_ARGS), FALSE);    
        if (v_gBspArgs == NULL)
        {
            RETAILMSG(TRUE, (TEXT("[HSMMC0] HSMMC MmMapIoSpace: FAILED\r\n"),sizeof(BSP_ARGS)));
            if (v_gBspArgs)
            {
                MmUnmapIoSpace((PVOID) v_gBspArgs, sizeof(BSP_ARGS));    
                v_gBspArgs = NULL;
            }
            return FALSE;
        }

        v_gBspArgs->g_SDCardState = CARD_REMOVED;    //initialize
        v_gBspArgs->g_SDCardDetectEvent = CreateEvent(NULL, FALSE, FALSE,NULL);
    }

    return fRet;
}


SD_API_STATUS
CSDHCSlotBase::Start(
        )
{
    Validate();

    SD_API_STATUS status;

    if (SoftwareReset(SOFT_RESET_ALL)) {
        // timeout control
        WriteByte(SDHC_TIMEOUT_CONTROL, (BYTE) m_dwTimeoutControl);

        // Enable error interrupt status and signals for all but the vendor
        // errors. This allows any normal error to generate an interrupt.
        WriteWord(SDHC_ERROR_INT_STATUS_ENABLE, ~0 & ~ERR_INT_STATUS_VENDOR);
        WriteWord(SDHC_ERROR_INT_SIGNAL_ENABLE, ~0 & ~ERR_INT_STATUS_VENDOR);

        // disable the interrupt signals on the FIFO.
        WriteWord(SDHC_NORMAL_INT_SIGNAL_ENABLE, 0x1FF);
        WriteWord(SDHC_NORMAL_INT_STATUS_ENABLE,
                NORMAL_INT_ENABLE_CARD_INSERTION | NORMAL_INT_ENABLE_CARD_REMOVAL);

        status = SD_API_STATUS_SUCCESS;
    }
    else {
        status = SD_API_STATUS_DEVICE_NOT_RESPONDING;
    }

    return status;
}


SD_API_STATUS
CSDHCSlotBase::Stop(
        )
{    
    if (m_fCardPresent) {
        // Remove device
        HandleRemoval(FALSE);
    }

    SoftwareReset(SOFT_RESET_ALL);

    if(NULL != v_gBspArgs->g_SDCardDetectEvent) 
    {
        CloseHandle(v_gBspArgs->g_SDCardDetectEvent);
        v_gBspArgs->g_SDCardDetectEvent = NULL;
    }
    if (v_gBspArgs)
    {
        MmUnmapIoSpace((PVOID) v_gBspArgs, sizeof(BSP_ARGS));    
        v_gBspArgs = NULL;
    }

    return SD_API_STATUS_SUCCESS;
}


SD_API_STATUS 
CSDHCSlotBase::GetSlotInfo(
        PSDCARD_HC_SLOT_INFO pSlotInfo
        )
{
    PREFAST_DEBUGCHK(pSlotInfo);
    DEBUGCHK(m_pregDevice->IsOK());

    // set the slot capabilities
    DWORD dwCap = SD_SLOT_SD_4BIT_CAPABLE | 
        SD_SLOT_SD_1BIT_CAPABLE | 
        SD_SLOT_SDIO_CAPABLE    |
        SD_SLOT_SDIO_INT_DETECT_4BIT_MULTI_BLOCK;

    if (GetCapabilities().bits.HighSpeed){
        dwCap |= SD_SLOT_HIGH_SPEED_CAPABLE;
    }

    SDHCDSetSlotCapabilities(pSlotInfo,dwCap );

    SDHCDSetVoltageWindowMask(pSlotInfo, m_dwVddWindows); 

    // Set optimal voltage
    SDHCDSetDesiredSlotVoltage(pSlotInfo, GetDesiredVddWindow());     

    // Controller may be able to clock at higher than the max SD rate,
    // but we should only report the highest rate in the range.
    DWORD dwMaxClockRateInSDRange = SD_FULL_SPEED_RATE;
    SetClockRate(&dwMaxClockRateInSDRange);
    SDHCDSetMaxClockRate(pSlotInfo, dwMaxClockRateInSDRange);

    // Set power up delay. We handle this in SetVoltage().
    SDHCDSetPowerUpDelay(pSlotInfo, 1);

    return SD_API_STATUS_SUCCESS;
}


SD_API_STATUS
CSDHCSlotBase::SlotOptionHandler(
        SD_SLOT_OPTION_CODE   sdOption, 
        PVOID                 pData,
        DWORD                 cbData
        )
{
    SD_API_STATUS status = SD_API_STATUS_SUCCESS;

    switch (sdOption) {
        case SDHCDSetSlotPower: {
                                    DEBUGCHK(cbData == sizeof(DWORD));
                                    PDWORD pdwVddSetting = (PDWORD) pData;
                                    SetVoltage(*pdwVddSetting);
                                    break;
                                }

        case SDHCDSetSlotInterface: {
                                        DEBUGCHK(cbData == sizeof(SD_CARD_INTERFACE));
                                        PSD_CARD_INTERFACE pInterface = (PSD_CARD_INTERFACE) pData;

                                        DEBUGMSG(SDCARD_ZONE_INFO, 
                                                (TEXT("CSDHCSlotBase::SlotOptionHandler: Clock Setting: %d\n"), 
                                                 pInterface->ClockRate));
                                        SD_CARD_INTERFACE_EX sdCardInterfaceEx;
                                        memset(&sdCardInterfaceEx,0, sizeof(sdCardInterfaceEx));

                                        sdCardInterfaceEx.InterfaceModeEx.bit.sd4Bit = (((pInterface->InterfaceMode) == SD_INTERFACE_SD_4BIT)? 1:0);
                                        // An interface for DAT 8-Bit on MMCplus is added.
                                        sdCardInterfaceEx.InterfaceModeEx.bit.hsmmc8Bit = (((pInterface->InterfaceMode) == SD_INTERFACE_MMC_8BIT)? 1:0);

                                        sdCardInterfaceEx.ClockRate = pInterface->ClockRate;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99精品视频| 亚洲精品国产成人久久av盗摄| 亚洲综合久久久| 99re成人精品视频| 亚洲另类在线一区| 欧美性受xxxx黑人xyx| 日韩精品成人一区二区三区| 日韩一区二区三区视频| 国内外成人在线视频| 中文欧美字幕免费| 在线精品国精品国产尤物884a| 亚洲福利视频导航| xnxx国产精品| 成人高清视频在线观看| 亚洲精品菠萝久久久久久久| 欧美日韩免费观看一区二区三区 | 亚洲麻豆国产自偷在线| 欧美婷婷六月丁香综合色| 青草av.久久免费一区| 久久精品一区二区三区不卡| 91麻豆免费在线观看| 日韩电影网1区2区| 国产精品色眯眯| 欧美片网站yy| 国产91精品久久久久久久网曝门| 亚洲色图都市小说| 91精品国产品国语在线不卡| 国产成人免费视| 亚洲综合色噜噜狠狠| 精品国产免费久久| 欧美亚洲自拍偷拍| 久久激情五月激情| 亚洲欧美日韩国产一区二区三区 | 精品一区二区影视| 亚洲激情男女视频| 精品国产麻豆免费人成网站| 成人午夜激情在线| 免费观看在线综合色| 中文字幕一区日韩精品欧美| 国产三级三级三级精品8ⅰ区| 久久精品免费看| 亚洲人成亚洲人成在线观看图片| 日韩欧美中文一区二区| 99久久99久久精品免费观看 | 国产亚洲欧美在线| 欧美日韩极品在线观看一区| 不卡电影免费在线播放一区| 免费高清不卡av| 亚洲无线码一区二区三区| 国产精品日日摸夜夜摸av| 日韩亚洲欧美一区二区三区| 欧美中文字幕亚洲一区二区va在线 | 91精品中文字幕一区二区三区| av午夜精品一区二区三区| 另类小说欧美激情| 丝袜美腿高跟呻吟高潮一区| 亚洲人成7777| 中文字幕永久在线不卡| 国产亚洲欧洲997久久综合| 日韩欧美国产一二三区| 欧美日韩一区久久| 欧美亚洲日本国产| jiyouzz国产精品久久| 国产美女一区二区| 狠狠色丁香婷婷综合久久片| 天天色 色综合| 午夜视频在线观看一区二区| 自拍偷拍国产亚洲| **性色生活片久久毛片| 久久久久国产精品麻豆 | 精品动漫一区二区三区在线观看| 91蜜桃在线免费视频| 99久久99久久精品免费看蜜桃| 国产不卡高清在线观看视频| 丰满少妇久久久久久久| 国产精品中文字幕一区二区三区| 韩国精品久久久| 国产不卡在线视频| 粉嫩aⅴ一区二区三区四区五区| 国产精品一区2区| 久久精品网站免费观看| 色综合久久天天| 色8久久人人97超碰香蕉987| 91久久人澡人人添人人爽欧美| 91国产免费观看| 欧美三级视频在线播放| 欧美日韩精品一区二区三区蜜桃| 欧美中文字幕一区二区三区亚洲 | 亚洲bt欧美bt精品| 婷婷久久综合九色综合绿巨人| 亚洲成年人网站在线观看| 亚洲自拍都市欧美小说| 日韩精品乱码免费| 精品一区二区三区欧美| 国产乱理伦片在线观看夜一区| 国产成人久久精品77777最新版本| 国产成人啪午夜精品网站男同| 99视频在线观看一区三区| 欧美在线观看视频在线| 91精品蜜臀在线一区尤物| 精品国产免费一区二区三区四区 | 91麻豆蜜桃一区二区三区| 欧洲另类一二三四区| 欧美一区二区三区精品| 国产丝袜美腿一区二区三区| 中文字幕一区在线| 舔着乳尖日韩一区| 国产成人av在线影院| 欧美视频第二页| 精品88久久久久88久久久| 国产精品传媒视频| 天天综合日日夜夜精品| 国产精品亚洲第一区在线暖暖韩国| jizz一区二区| 欧美变态凌虐bdsm| 亚洲欧洲日产国码二区| 日日夜夜一区二区| 丁香桃色午夜亚洲一区二区三区| 99精品国产热久久91蜜凸| 欧美一级久久久| 亚洲欧洲精品成人久久奇米网| 日本在线观看不卡视频| 99re亚洲国产精品| 亚洲精品在线电影| 一级日本不卡的影视| 激情丁香综合五月| 欧美性videosxxxxx| 国产精品视频一区二区三区不卡| 午夜精品久久久久影视| 成人免费的视频| 欧美成人高清电影在线| 一区二区三区在线免费观看| 韩国毛片一区二区三区| 欧美疯狂做受xxxx富婆| 中文字幕在线视频一区| 老司机免费视频一区二区三区| 色偷偷久久人人79超碰人人澡 | 日韩一区二区电影在线| 中文字幕中文字幕在线一区| 喷水一区二区三区| 欧美在线观看一区二区| 综合欧美一区二区三区| 国产精品88888| 日韩欧美在线123| 亚洲成人综合在线| 一本大道久久a久久精品综合| 国产日产欧产精品推荐色| 麻豆精品在线视频| 欧美日韩精品欧美日韩精品一 | 欧美精品在线一区二区三区| 136国产福利精品导航| 成人a免费在线看| 久久午夜老司机| 国产在线精品一区二区三区不卡 | 国产一区视频在线看| 日韩一区二区三区高清免费看看| 亚洲激情图片一区| 色婷婷精品久久二区二区蜜臀av| 亚洲欧美在线aaa| 成人动漫视频在线| 国产精品日韩成人| 成人av网在线| 一区精品在线播放| 91论坛在线播放| 亚洲免费在线电影| jlzzjlzz欧美大全| 中文字幕一区二区不卡| aaa国产一区| 中文字幕字幕中文在线中不卡视频| 国产成人免费xxxxxxxx| 国产精品蜜臀av| 9l国产精品久久久久麻豆| 国产精品不卡视频| 在线亚洲高清视频| 亚洲高清中文字幕| 欧美一区二区三区色| 蜜桃免费网站一区二区三区| 欧美电影免费观看完整版| 国产美女一区二区| 国产精品超碰97尤物18| 91国偷自产一区二区三区观看| 亚洲大片在线观看| 日韩视频一区在线观看| 国产一区二区三区国产| 国产视频不卡一区| 91美女片黄在线| 日韩av成人高清| 久久亚洲私人国产精品va媚药| 国产成a人无v码亚洲福利| 亚洲视频资源在线| 欧美日韩精品免费观看视频| 麻豆精品在线看| 国产精品久线观看视频| 欧美综合在线视频| 久久精品国产久精国产| 亚洲国产经典视频| 欧美日韩三级一区| 国产精品自在欧美一区| 樱花草国产18久久久久| 日韩一区二区三区在线观看|