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

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

?? sdhceventhandlers.cpp

?? S3C2443 WINCE6.0 BSP
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
//
// 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.
//

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

// SD Host Controller Event Handlers

#include "SDbusdriver.h"

#define GET_HC_NAME_FROM_SLOT(s) (s)->pHostController->HostControllerName	// added by JJG 06.11.17
// macro to get the function number from an R4 response 
#define SD_GET_NUMBER_OF_FUNCTIONS(pResponse) (((pResponse)->ResponseBuffer[4] >> 4) & 0x7)
// macro to get the memory present bit from an R4 response
#define SD_MEMORY_PRESENT_WITH_IO(pResponse) (((pResponse)->ResponseBuffer[4] >> 3) &  0x1)
// macro to get the I/O ready flag from an R4 response
#define SD_IS_IO_READY(pResponse)             ((pResponse)->ResponseBuffer[4] & 0x80)
// macro to get the Memory card ready flag from an R3 response
#define SD_IS_MEM_READY(pResponse)            ((pResponse)->ResponseBuffer[4] & 0x80)

// macro to call slot option handler for power setting
#define SDSetSlotPower(pSlot,Setting) \
    (pSlot)->pHostController->pSlotOptionHandler((pSlot)->pHostController,  \
    (pSlot)->SlotIndex,        \
    SDHCDSetSlotPower,         \
    &(Setting),                \
    sizeof(Setting))

// macro for synchronous bus commands
#define SendSDCommand(hDevice, Command,Argument,ResponseType,pResponse) \
    SDSynchronousBusRequest__X(hDevice,         \
    Command,         \
    Argument,        \
    SD_COMMAND,      \
    ResponseType,    \
    pResponse,       \
    0,               \
    0,               \
    NULL,            \
    (DWORD)0)            


// macro to send an application specific command with no data transfer 
#define SendSDAppCommand(hDevice,AppCommand,Argument,ResponseType,pResponse) \
    SendSDAppCmd(hDevice,         \
    AppCommand,      \
    Argument,        \
    SD_COMMAND,      \
    ResponseType,    \
    pResponse,       \
    0,               \
    0,               \
    0)

#define GetDeviceVoltageRangeFromOCR(pVoltageRange, pDevice)            \
{                                                                       \
    *pVoltageRange = (DWORD)pDevice->CachedRegisters.OCR[0] & ~0xF;      \
    *pVoltageRange |= ((DWORD)pDevice->CachedRegisters.OCR[1]) << 8;     \
    *pVoltageRange |= ((DWORD)pDevice->CachedRegisters.OCR[2]) << 16;    \
}

#define GetDeviceVoltageRangeFromIO_OCR(pVoltageRange, pDevice)         \
{                                                                       \
    *pVoltageRange = (DWORD)pDevice->CachedRegisters.IO_OCR[0] & ~0xF;   \
    *pVoltageRange |= ((DWORD)pDevice->CachedRegisters.IO_OCR[1]) << 8;  \
    *pVoltageRange |= ((DWORD)pDevice->CachedRegisters.IO_OCR[2]) << 16; \
}

#define GetOEMIDFromCID(pOID, pDevice)                          \
{                                                               \
    *pOID = (USHORT)((pDevice)->CachedRegisters.CID[SD_CID_OID_OFFSET]); \
    *pOID |= ((USHORT)((pDevice)->CachedRegisters.CID[SD_CID_OID_OFFSET + 1])) << 8; \
}

#define CIS_CSA_BYTES (SD_IO_CIS_PTR_BYTES + SD_IO_CSA_PTR_BYTES)
#define CIS_OFFSET_BYTE_0 0
#define CIS_OFFSET_BYTE_1 1
#define CIS_OFFSET_BYTE_2 2
#define CSA_OFFSET_BYTE_0 3
#define CSA_OFFSET_BYTE_1 4
#define CSA_OFFSET_BYTE_2 5
#define UNKNOWN_PRODUCT_INFO_STRING_LENGTH 64

#define USE_MMCPLUS 1

#define IS_PARENT(p) (p == p->pParentDevice)

#if USE_MMCPLUS
UINT32 g_bIsHSMMC=FALSE;
UINT32 g_bIsMMC = FALSE;
#endif

///////////////////////////////////////////////////////////////////////////////
//  FormatProductString - format a raw CISPTPL_VERS_1 data buffer into a 
//                        displayable string
//  Input:  pAsciiString  - raw product string buffer retreived from VERS_1 tuple
//                    the tuple is stored as ASCII characters
//          pString - the wide char string to store the version 1 tuple
//          
//  Output:
//  Return:
//  Notes:  
//         This function converts the raw version tuple data buffer
//         into a wide char displayable string 
//         All non-displayable characters and spaces are converted to 
//         an underscore.  
///////////////////////////////////////////////////////////////////////////////
VOID FormatProductString(PCHAR pAsciiString, PWCHAR pString ) 
{
    ULONG  ii;  // loop variable

    for (ii = 0; ii < strlen(pAsciiString); ii++) {
        // convert to Wide char
        pString[ii] = (WCHAR)pAsciiString[ii];

        // if the character is outside the range of displayable characters
        // then substitute with an under score
        if ((pAsciiString[ii] <= 0x20) || (pAsciiString[ii] > 0x7E)) {
            pString[ii] = TEXT('_');
        }
    }

    // terminate
    pString[ii] = NULL;
}

///////////////////////////////////////////////////////////////////////////////
//  SDSetCardInterfaceForSlot - set Card interface for the slot
//  Input:  pSlot - the slot to set the card interface for
//          pSetting - card interface settings
//  Output:
//  Return: SD_API_STATUS
//  Notes:  
//         this function calls the slot option handler in the host controller
//         driver
//         
///////////////////////////////////////////////////////////////////////////////
SD_API_STATUS SDSetCardInterfaceForSlot(PSDBUS_HC_SLOT_CONTEXT   pSlot, 
                                        PSD_CARD_INTERFACE       pSetting)
{
    SD_API_STATUS   status;             // intermediate status
    DWORD           origClockSetting;   // original clock setting upon entry

    origClockSetting = pSetting->ClockRate;

    status = pSlot->pHostController->pSlotOptionHandler(pSlot->pHostController,
        pSlot->SlotIndex, 
        SDHCDSetSlotInterface,
        pSetting,                
        sizeof(SD_CARD_INTERFACE));

    if (SD_API_SUCCESS(status)) {
        if (origClockSetting != pSetting->ClockRate){
            DEBUGMSG(SDCARD_ZONE_WARN, (TEXT("SDSetCardInterfaceForSlot - HC ClockRate differs desired setting: desired: %d Hz, Actual : %d Hz \n"),
                origClockSetting, pSetting->ClockRate));
        }

    }

    return status;
}

///////////////////////////////////////////////////////////////////////////////
//  SDGetSDIOPnpInformation - Get SDIO PnP information for an SDIO device function
//  Input:  pDevice - the device context
//          Parent - this is the parent device
//  Output:
//  Return: SD_API_STATUS code
//  Notes:  
//         This function collects SDIO Pnp information for the device.
//         
///////////////////////////////////////////////////////////////////////////////
SD_API_STATUS SDGetSDIOPnpInformation(PSDCARD_DEVICE_CONTEXT pDevice, BOOL Parent) 
{

    SD_API_STATUS          status;           // intermediate status
    UCHAR                  regValue[4];      // most tuples are 4 bytes
    UCHAR                  CSA_CISBuffer[CIS_CSA_BYTES]; // CIS and CSA are in contiguous locations
    DWORD                  FBROffset;        // calculated FBR offset
    DWORD                  manFid;           // manufacturer ID
    ULONG                  length;           // buffer length
    BOOL                   found;            // CIS found flag
    PCHAR                  pVersionBuffer;   // tuple buffer for vers1 info

    status = SD_API_STATUS_SUCCESS;

    // for the parent device save the common information
    if (Parent) {

        // allocate the common information
        pDevice->SDCardInfo.SDIOInformation.pCommonInformation = (PSDIO_COMMON_INFORMATION)
            SDAllocateMemoryWithTag(sizeof(SDIO_COMMON_INFORMATION),
            SD_BUS_DRIVER_TAG);

        if (NULL == pDevice->SDCardInfo.SDIOInformation.pCommonInformation) {
            return SD_API_STATUS_INSUFFICIENT_RESOURCES;
        }

        // get the CCCR
        status = SDReadWriteRegistersDirect__X((SD_DEVICE_HANDLE)pDevice,
            SD_IO_READ,          
            0,      // all from function 0
            SD_IO_REG_CCCR,
            FALSE,
            regValue,
            1); 

        if (!SD_API_SUCCESS(status)) {
            DEBUGMSG(SDCARD_ZONE_ERROR, (TEXT("SDBusDriver: Failed to get CCCR \n")));
            return status;
        }

        pDevice->SDCardInfo.SDIOInformation.pCommonInformation->CCCRRev = regValue[0];

        // get the card capabilities register
        status = SDReadWriteRegistersDirect__X((SD_DEVICE_HANDLE)pDevice,
            SD_IO_READ,          
            0,      // all from function 0
            SD_IO_REG_CARD_CAPABILITY,
            FALSE,
            regValue,
            1); 

        if (!SD_API_SUCCESS(status)) {
            DEBUGMSG(SDCARD_ZONE_ERROR, (TEXT("SDBusDriver: Failed to get CARD CAPABILITY register \n")));
            return status;
        }

        pDevice->SDCardInfo.SDIOInformation.pCommonInformation->CardCapability = regValue[0];

        // get the SD Spec rev
        status = SDReadWriteRegistersDirect__X((SD_DEVICE_HANDLE)pDevice,
            SD_IO_READ,          
            0,      // all from function 0
            SD_IO_REG_SPEC_REV,
            FALSE,
            regValue,
            1); 

        if (!SD_API_SUCCESS(status)) {
            DEBUGMSG(SDCARD_ZONE_ERROR, (TEXT("SDBusDriver: Failed to get SD Spec revision \n")));
            return status;
        }

        pDevice->SDCardInfo.SDIOInformation.pCommonInformation->SDSpec = regValue[0];

        DEBUGMSG(SDBUS_ZONE_DEVICE, (TEXT("SDBusDriver: SDIO Card Function %d, CCCR 0x%02X , Card Caps: 0x%02X, Spec Ver: %d \n"), 
            pDevice->SDCardInfo.SDIOInformation.Function,
            pDevice->SDCardInfo.SDIOInformation.pCommonInformation->CCCRRev,
            pDevice->SDCardInfo.SDIOInformation.pCommonInformation->CardCapability,
            pDevice->SDCardInfo.SDIOInformation.pCommonInformation->SDSpec)); 


        // get the CIS pointer
        // function 0 only has a CIS, no CSA
        status = SDReadWriteRegistersDirect__X((SD_DEVICE_HANDLE)pDevice,
            SD_IO_READ,          
            0,      // all from function 0
            SD_IO_REG_COMMON_CIS_POINTER,
            FALSE,
            CSA_CISBuffer,
            SD_IO_CIS_PTR_BYTES); 
        if (!SD_API_SUCCESS(status)) {
            return status;
        }

        pDevice->SDCardInfo.SDIOInformation.pCommonInformation->CommonCISPointer = CSA_CISBuffer[CIS_OFFSET_BYTE_0] | 
            (CSA_CISBuffer[CIS_OFFSET_BYTE_1] << 8) |
            (CSA_CISBuffer[CIS_OFFSET_BYTE_2] << 16);    

#if 0
        // for Debugging a bad CIS only
        {
            UCHAR tupleBuffer[256];
            status = SDReadWriteRegistersDirect((SD_DEVICE_HANDLE)pDevice,
                SD_IO_READ,          
                0,      // all from function 0
                pDevice->SDCardInfo.SDIOInformation.pCommonInformation->CommonCISPointer,
                FALSE,
                tupleBuffer,
                256); 
            if (SD_API_SUCCESS(status)) {
                DEBUGMSG(SDCARD_ZONE_ERROR, (TEXT("SDBusDriver:  Common CIS Pointer: 0x%08X \n"),
                    pDevice->SDCardInfo.SDIOInformation.pCommonInformation->CommonCISPointer));     
                SDOutputBuffer(tupleBuffer, 256);         
            }

        }

#endif
        length = SD_CISTPL_MANFID_BODY_SIZE;

        // for function 0 get the Manufacturer ID (this is not the same as the VER1 string)
        status = SDGetTuple__X((SD_DEVICE_HANDLE)pDevice,
            SD_CISTPL_MANFID,
            (PUCHAR)&manFid,
            &length,
            TRUE);

        if (!SD_API_SUCCESS(status)) {
            return status;
        }

        if (0 == length) {
            DEBUGMSG(SDCARD_ZONE_ERROR, (TEXT("SDBusDriver:  Card is missing CISTPL_MANFID \n")));
            status = SD_API_STATUS_DEVICE_UNSUPPORTED;
            return status;   
        }
        // set Manufacturer and CardID 
        pDevice->SDCardInfo.SDIOInformation.pCommonInformation->ManufacturerID = (USHORT)manFid;
        pDevice->SDCardInfo.SDIOInformation.pCommonInformation->CardID = (USHORT)(manFid >> 16);

        // retrieve the ver_1 tuple to retrieve the manufacturer string
        length = 0;


        // query the size of the tuple from the common CIS
        // the VERS_1 tuple is a variable length tuple
        status = SDGetTuple__X((SD_DEVICE_HANDLE)pDevice,
            SD_CISTPL_VERS_1,
            NULL,
            &length,
            TRUE);

        if (!SD_API_SUCCESS(status)) {
            return status;
        }

        if (0 != length ) {
            found = TRUE;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产cao| 在线观看亚洲a| 欧美性受xxxx黑人xyx| 精品欧美一区二区久久| 亚洲女子a中天字幕| 久久成人免费日本黄色| 色婷婷精品久久二区二区蜜臂av | 成人午夜av电影| 在线综合+亚洲+欧美中文字幕| 国产拍欧美日韩视频二区| 日韩福利视频导航| 欧美在线观看一区二区| 国产精品久久二区二区| 精品制服美女久久| 欧美一区二区视频在线观看2022| 亚洲伦理在线精品| 成人激情免费网站| 久久噜噜亚洲综合| 国产精品一二三在| 精品国产1区二区| 麻豆传媒一区二区三区| 欧美日韩三级视频| 性做久久久久久免费观看| 一本一道久久a久久精品| 国产精品三级av| 成人高清免费在线播放| 久久精品视频一区二区| 国产乱码精品一品二品| 久久精品在这里| 福利一区在线观看| 亚洲国产精品激情在线观看| 国产精品乡下勾搭老头1| 久久午夜免费电影| 国产一区二区三区免费看| 日韩精品一区二区三区在线 | 国产一区二三区| 日韩欧美国产成人一区二区| 麻豆免费看一区二区三区| 日韩亚洲欧美综合| 久久91精品国产91久久小草| 日韩精品中文字幕在线一区| 国产一区二区网址| 国产喷白浆一区二区三区| 国产mv日韩mv欧美| 亚洲人快播电影网| 欧美三区在线观看| 毛片基地黄久久久久久天堂| 久久人人爽爽爽人久久久| 国产成人av一区二区| 亚洲欧洲日产国产综合网| 92精品国产成人观看免费 | 国产精品欧美久久久久无广告 | 国产精品久久久久毛片软件| 99免费精品视频| 午夜精彩视频在线观看不卡| 欧美一区二区三区免费在线看| 蜜桃av一区二区| 国产欧美精品国产国产专区 | 亚洲视频一区在线观看| 欧美性猛交xxxx黑人交| 日韩高清不卡一区二区三区| 久久综合久久99| 97久久超碰精品国产| 三级影片在线观看欧美日韩一区二区| 欧美成人a视频| www.欧美日韩| 男女视频一区二区| 国产精品福利影院| 欧美日韩高清一区二区三区| 狠狠色丁香九九婷婷综合五月| 国产精品日产欧美久久久久| 欧美色爱综合网| 成人一区二区三区在线观看| 天天色图综合网| 国产精品黄色在线观看| 欧美一级生活片| 91蝌蚪porny九色| 精品一区二区三区免费毛片爱| 国产精品久久久久影院| 日韩精品一区二区三区视频 | 日韩女优毛片在线| av资源站一区| 国产一区999| 日韩国产精品大片| 亚洲另类一区二区| 国产午夜精品久久久久久免费视| 在线观看日韩国产| 粉嫩av亚洲一区二区图片| 日韩黄色免费电影| 一区二区三区在线免费视频| 国产午夜三级一区二区三| 3atv一区二区三区| 91成人在线精品| 豆国产96在线|亚洲| 久久成人免费网站| 免费欧美在线视频| 图片区小说区国产精品视频| 亚洲男女一区二区三区| 中文字幕乱码一区二区免费| 欧美一区二区福利在线| 欧美日韩在线精品一区二区三区激情 | 欧美一区二区三区四区久久| 91麻豆国产精品久久| 成人免费视频caoporn| 国产中文字幕精品| 久久国内精品视频| 免费成人美女在线观看.| 日本不卡一二三| 日韩精品视频网站| 首页国产欧美久久| 三级在线观看一区二区| 日韩av中文字幕一区二区| 午夜不卡av在线| 日韩不卡在线观看日韩不卡视频| 亚洲一区在线播放| 午夜电影一区二区| 美国三级日本三级久久99 | 久久久综合九色合综国产精品| 91精品国产手机| 欧美一级一区二区| 精品少妇一区二区三区在线播放| 91精品国产综合久久久蜜臀粉嫩 | 精品综合免费视频观看| 久久福利资源站| 国产91在线看| av网站免费线看精品| 日本丶国产丶欧美色综合| 在线视频国内一区二区| 欧美日本免费一区二区三区| 91麻豆精品国产无毒不卡在线观看 | www国产成人| 国产午夜精品福利| 一区二区三区欧美日| 亚洲午夜私人影院| 日韩在线一区二区| 国模冰冰炮一区二区| 成人动漫在线一区| 欧美精品一二三区| 2023国产精品| 伊人色综合久久天天| 亚欧色一区w666天堂| 国产一区二区毛片| 一本久道久久综合中文字幕| 欧美日韩国产精品成人| 久久中文娱乐网| 亚洲精品第1页| 精品一区二区三区免费毛片爱| 不卡av在线网| 91精品国产欧美日韩| 国产亚洲精品福利| 亚洲1区2区3区4区| 福利一区二区在线观看| 欧美日韩精品久久久| 久久久亚洲国产美女国产盗摄 | 色偷偷成人一区二区三区91| 欧美久久久久免费| 久久久久久久久久看片| 亚洲图片欧美综合| 国产成人啪免费观看软件| 欧美影院午夜播放| 欧美国产日本视频| 日本在线观看不卡视频| 99国产欧美另类久久久精品| 日韩欧美在线网站| 一区二区三区日本| 成人免费视频播放| 欧美mv日韩mv亚洲| 午夜视黄欧洲亚洲| 99久久精品一区| 国产日产精品1区| 日本不卡一区二区三区 | 国产精品1区2区3区| 欧美日韩日日骚| 亚洲欧美另类久久久精品| 黑人精品欧美一区二区蜜桃| 欧美三级电影一区| 亚洲视频网在线直播| 色综合久久久网| 日韩免费视频一区| 视频一区二区不卡| 欧美日韩在线亚洲一区蜜芽| 亚洲人成影院在线观看| 成人av网在线| 国产亚洲短视频| 国产乱码精品一区二区三区五月婷 | 色综合婷婷久久| 中文字幕精品—区二区四季| 久久精工是国产品牌吗| 日韩一区二区三区视频| 午夜欧美视频在线观看| 欧美日韩国产bt| 视频在线观看91| 4438x亚洲最大成人网| 亚洲v中文字幕| 欧美日韩国产综合视频在线观看| 一区二区三区小说| 欧洲精品中文字幕| 五月婷婷欧美视频| 91精品在线一区二区| 强制捆绑调教一区二区|