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

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

?? dalcwdde.c

?? 此代碼為WCE5.0下顯示器的源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:

          // force these values to zero in case the caller is trying to read
          // so information out of these in a future version and we do not
          // support that future version.

          lpAdapterInfo->ulReserved1 = 0;
          lpAdapterInfo->ulReserved2 = 0;
        }
      }
      *lpInfoSize = sizeof(ADAPTERINFO);
      break;

    case CWDDEDI_AdapterGetCRTCOwned:
      {
        CRTCOWNED FAR *lpCrtcOwned;
        ULONG ulControllersUsed = 0;

        // used to return the controllers per driver
        if (lpCmd->ulDriverReserved >= MAX_NUMBER_CONTROLLERS)
        {
          ulReturn = CWDDE_ERR_BADINPUT;
        } else if (ulOutputSize < sizeof(CRTCOWNED))
        {
          // cannot return the version because there is insufficient room in
          // the output buffer for a OUTPUTULONG.

          ulReturn = CWDDE_ERR_BADOUTPUTSIZE;
        } else
        {
          // Return the mapped controllers for this driver.

          lpCrtcOwned                   = (CRTCOWNED FAR *) lpOutput;
          lpCrtcOwned->ulSize           = sizeof(CRTCOWNED);
          lpCrtcOwned->ulOwnedCRTCs     = lpHDE->aControllerMap[lpCmd->ulDriverReserved];
          lpCrtcOwned->ulAvailableCRTCs = 0;

          for (i = 0; i < MAX_NUMBER_CONTROLLERS; i++)
          {
            // Check which of the controllers are taken by the drivers
            // We don't check here if driver "i" is enabled, because
            // if not, lpHDE->aControllerMap[i] will be 0
            ulControllersUsed |= lpHDE->aControllerMap[i];
          }

          for( j = 0; j < lpHDE->ulControllersCount; j++)
          {      
            if(!(VECTORFROMINDEX(j) & ulControllersUsed))
            {
              lpCrtcOwned->ulAvailableCRTCs |= VECTORFROMINDEX(j);
            }
          }
        }
      }
      *lpInfoSize = sizeof(CRTCOWNED);
      break;

    case CWDDEDI_AdapterGetSavePath:
      {
        SAVEDATA FAR *lpSaveData;
        UCHAR aucRegPathName[256];
        ULONG ulRegPathNameSize;

        if (ulOutputSize < sizeof(SAVEDATA))
        {
          // cannot return the version because there is insufficient room in
          // the output buffer for a SAVEDATA structure

          ulReturn = CWDDE_ERR_BADOUTPUTSIZE;
        } else if (lpCmd->ulDriverReserved >= MAX_NUMBER_CONTROLLERS)
        {
          // driver index specified in the command block is invalid

          ulReturn = CWDDE_ERR_BADINPUT;
        } else
        {
          lpSaveData = (SAVEDATA FAR *)lpOutput;

          lpSaveData->ulSize = sizeof(SAVEDATA);

          ulRegPathNameSize = DDLGetRegistryPathName(lpHDE->hDDL, (LPUCHAR)aucRegPathName);

          MOVEMEMORY((LPVOID)lpSaveData->cStrName,
                     (LPVOID) aucRegPathName,
                     ulRegPathNameSize);

          ulReturn = CWDDE_OK;
        }
      }
      *lpInfoSize = sizeof(SAVEDATA);
      break;

    case CWDDEDI_AdapterFlushSaveData:
      {
        if (ulOutputSize < sizeof(SAVEDATA))
        {
          // cannot return the version because there is insufficient room in
          // the output buffer for a SAVEDATA structure

          ulReturn = CWDDE_ERR_BADOUTPUTSIZE;
        } else if (lpCmd->ulDriverReserved >= MAX_NUMBER_CONTROLLERS)
        {
          // driver index specified in the command block is invalid

          ulReturn = CWDDE_ERR_BADINPUT;
        } else
        {
          ulReturn = DALCWDDE_AdapterFlushData(lpHDE,
                                               lpCmd->ulDriverReserved,
                                               (SAVEDATA FAR *)lpOutput);
        }
      }
      *lpInfoSize = sizeof(SAVEDATA);
      break;

    case CWDDEDI_AdapterGetDisplayMapping:
      {
        DEVICESELECTION FAR       *lpDeviceSelection;
        OUTPUTULONG FAR           *lpOutputUlong;
        LPDEVGDO                  lpDisplay;
        ULONG                     ulObjectTypesSelected = 0;
        ULONG                     ulIndex;
        LPDAL_OBJECT_MAP          lpObjectMap;

        if (ulInputSize < (sizeof(CWDDECMD) + sizeof(DEVICESELECTION)))
        {
          // input size of the buffer is less than the command buffer and
          // enum refresh structure so fail the call.

          ulReturn = CWDDE_ERR_BADINPUTSIZE;
        } else if (ulOutputSize < sizeof(OUTPUTULONG))
        {
          // cannot return the version because there is insufficient room in
          // the output buffer for an OUTPUTULONG structure

          ulReturn = CWDDE_ERR_BADOUTPUTSIZE;
        } else if (lpCmd->ulIndex >= lpHDE->ulControllersCount)
        {
          ulReturn = CWDDE_ERR_BADINPUT;

          // we don't want to fail the call if the calling driver does not own the controller        
          // since it might acquire it later.
          
        } else
        {
          lpDeviceSelection      = (DEVICESELECTION FAR *)(lpCmd + 1);
          lpOutputUlong          = (OUTPUTULONG FAR *) lpOutput;
          lpOutputUlong->ulSize  = sizeof(OUTPUTULONG);
          lpOutputUlong->ulValue = 0;
          
          // use the lpDeviceSlection to index into the  DAL_OBJECT_MAP
          // lpDeviceSelection is a bit vector of index of devices                    
          for(i=0; (lpDeviceSelection->ulDeviceSelection >> i) && (i < lpHDE->ulDisplaysCount); i++)
          {          
            lpDisplay = (LPDEVGDO) &lpHDE->aDisplays[i];

            // loop through the list of connected displays, and generate the type 
            // mask.  The type mask can then be used to index into the DAL_OBJECT_MAP
            // structure.
            if (VECTORFROMINDEX(i) & lpDeviceSelection->ulDeviceSelection)
            {              
              // DFP bootup support, display types replaced with a mask - VG
              ulObjectTypesSelected |= (lpDisplay->lpHWED->ulDisplayType &
                                HW_DISPLAY_TYPES_MASK);
            }
          }
          
          // Since the second driver is disabled index is equal to ulObjectTypes
          ulIndex = ulObjectTypesSelected;

          // lookup the selected object map structure for above slot of active devices.
          lpObjectMap = (LPDAL_OBJECT_MAP) &lpHDE->asDriverSelectedObjectMap[ulIndex];
                    
          lpOutputUlong->ulValue = (ULONG)lpObjectMap->aDriverMap[lpCmd->ulDriverReserved].aucDisplayMap[lpCmd->ulIndex];

          ulReturn = CWDDE_OK;
        }
      }

      *lpInfoSize = sizeof(OUTPUTULONG);
      break;

    case CWDDEDI_AdapterGetDriverInfo:
      {
         DRIVERINFO FAR *lpDriverInfo;
         LPCHAR lpcDriverName;
         LPCHAR lpcDriver;

        if (ulOutputSize < sizeof(DRIVERINFO))
        {
          // cannot return the version because there is insufficient room in
          // the output buffer for an ADAPTERCAPS structure

          ulReturn = CWDDE_ERR_BADOUTPUTSIZE;
        } 
        else if ((lpCmd->ulDriverReserved >= MAX_NUMBER_CONTROLLERS) ||
                 (!(lpHDE->aDriverData[lpCmd->ulDriverReserved].ulFlags & DRIVERDATA_ENABLED)))
        {
          // driver index specified in the command block is invalid

          ulReturn = CWDDE_ERR_BADINPUT;
        } 
        else
        {
          ULONG cchDriverName = MAX_REGISTRY_PATH - 2;

          lpDriverInfo = (DRIVERINFO FAR *)lpOutput;
          ZEROMEMORY((LPVOID)lpDriverInfo, sizeof(DRIVERINFO));

          lpDriverInfo->ulSize = sizeof(DRIVERINFO);

          lpcDriverName = (LPCHAR) lpDriverInfo->cDriverID;

          lpcDriver = (LPCHAR)DALREGKEY_DRIVER;

          strncpy(lpcDriverName, lpcDriver, cchDriverName - 1);
          lpcDriverName[cchDriverName - 1] = 0;

          if (cchDriverName >= strlen(lpcDriver) + 2)
          {
            lpcDriverName += strlen(lpcDriver);

            *lpcDriverName++ = ((CHAR)lpCmd->ulDriverReserved + '0');

            *lpcDriverName++ = '\0';
          }

          DDLGetAdapterID(lpHDE->hDDL, (LPCHAR)lpDriverInfo->cAdapterID);

          ulReturn = CWDDE_OK;
        }
      }

      *lpInfoSize = sizeof(DRIVERINFO);
      break;

    case CWDDEDI_AdapterGetDefaultSetting:
    {
      if (ulInputSize < sizeof(CWDDECMD))
      {
        // input size of the buffer is less than the command buffer
        ulReturn = CWDDE_ERR_BADINPUTSIZE;
      } 
      else if (ulOutputSize < sizeof(ADAPTERSETTING))
      {
        // cannot return the version because there is insufficient room in
        // the output buffer

        ulReturn = CWDDE_ERR_BADOUTPUTSIZE;
      }
      else if ((lpCmd->ulDriverReserved >= MAX_NUMBER_CONTROLLERS) ||
               (!(lpHDE->aDriverData[lpCmd->ulDriverReserved].ulFlags & DRIVERDATA_ENABLED)))
      {

        ulReturn = CWDDE_ERR_BADINPUT;
      }
      else
      {
        ulReturn = ulGetAdapterDefaultSetting(lpHDE,
                                              lpCmd->ulDriverReserved,
                                              ulOutputSize,
                                              (ADAPTERSETTING FAR*)lpOutput);
      }

      *lpInfoSize = ulOutputSize;
      break;
    }

    case CWDDEDI_AdapterGetConfig:
    {
      if (ulInputSize < (sizeof(CWDDECMD)+sizeof(ADAPTERCONFIG)))
      {
        // input size of the buffer is less than the command buffer
        ulReturn = CWDDE_ERR_BADINPUTSIZE;
      } 
      else if (ulOutputSize < sizeof(ADAPTERCONFIG))
      {
        // cannot return the version because there is insufficient room in
        // the output buffer

        ulReturn = CWDDE_ERR_BADOUTPUTSIZE;
      }
      else
      {
        ADAPTERCONFIG FAR * lpOAdapterConfig = (ADAPTERCONFIG FAR *)lpOutput;
        ADAPTERCONFIG FAR * lpIAdapterConfig = (ADAPTERCONFIG FAR *)(lpCmd + 1);

        ZEROMEMORY(lpOAdapterConfig, sizeof(ADAPTERCONFIG));
        lpOAdapterConfig->ulSize   = sizeof(ADAPTERCONFIG);
        lpOAdapterConfig->ulConfig = lpIAdapterConfig->ulConfig;

        ulReturn = ulGetAdapterConfig(lpHDE,
                                      lpIAdapterConfig->ulConfig,
                                      (LPULONG)&lpOAdapterConfig->ulValue);
      }

      *lpInfoSize = sizeof(ADAPTERCONFIG);
      break;
    }

    case CWDDEDI_AdapterSetConfig:
    {
      if (ulInputSize < (sizeof(CWDDECMD) + sizeof(ADAPTERCONFIG)))
      {
        // input size of the buffer is less than the command buffer
        ulReturn = CWDDE_ERR_BADINPUTSIZE;
      } 
      else
      {
        ADAPTERCONFIG FAR * lpAdapterConfig = (ADAPTERCONFIG FAR *)(lpCmd + 1);

        ulReturn = ulSetAdapterConfig(lpHDE,
                                      lpAdapterConfig->ulConfig,
                                      lpAdapterConfig->ulValue);
      }

      *lpInfoSize = 0;
      break;
    }

    case CWDDEDI_AdapterGetPowerCaps:
    {

      if (ulOutputSize < sizeof(DI_ADAPTERPOWERCAPS))
      {
        // cannot return the version because there is insufficient room in
        // the output buffer
        ulReturn = CWDDE_ERR_BADOUTPUTSIZE;
      }
      else
      {
        if (lpHDE->bPowerPlaySupported)
        {

          DI_ADAPTERPOWERCAPS FAR * lpAdapterPowerCaps = (DI_ADAPTERPOWERCAPS FAR *)lpOutput;
          ZEROMEMORY(lpAdapterPowerCaps, sizeof(DI_ADAPTERPOWERCAPS));
          lpAdapterPowerCaps->ulSize   = sizeof(DI_ADAPTERPOWERCAPS);
          
          lpAdapterPowerCaps->ulAPIVersion = CWDDEDI_POWERPLAY_VERSION;
          lpAdapterPowerCaps->ulNumberofPowerStates = lpHDE->ulNumberOfPowerStates;

          for( i = 0; (i < lpHDE->ulNumberOfPowerStates) && (i < MAX_POWER_STATE) && (i < DAL_GCO_MAX_POWERSTATE); i++)
          {
            lpAdapterPowerCaps->sPowerState[i].ulFlags = 0;

            if (lpHDE->sAdapterPowerStates.sGCOPowerState[i].ulFlags & DAL_GCOPOWERSTATE_FLAGS_MEMORYSHARESCORECLK)
            {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天堂va蜜桃一区二区三区漫画版| 成人av电影免费在线播放| 久久综合久久综合久久综合| 国产伦精品一区二区三区视频青涩 | 久久99久久久欧美国产| 欧美成人r级一区二区三区| 国产老女人精品毛片久久| 国产日韩精品一区二区三区在线| 成人精品免费看| 亚洲男女一区二区三区| 欧美精品亚洲二区| 韩国v欧美v日本v亚洲v| 国产精品国产自产拍高清av王其| 91久久奴性调教| 日本不卡一区二区三区高清视频| 久久综合九色综合欧美亚洲| www.日韩大片| 日韩精品久久久久久| 久久久不卡网国产精品一区| 99精品1区2区| 青青草国产成人av片免费| 日本一区二区免费在线观看视频| 高清成人在线观看| 亚洲成人免费在线观看| 久久久影视传媒| 91美女在线视频| 蜜臀av性久久久久蜜臀aⅴ流畅| 久久久精品人体av艺术| 91福利资源站| 国产一区二区三区久久悠悠色av | 亚洲第一搞黄网站| 日韩欧美精品三级| av亚洲精华国产精华精| 日韩精品一级中文字幕精品视频免费观看 | 亚洲第一主播视频| 国产亚洲精品bt天堂精选| 一本到不卡免费一区二区| 日本一区中文字幕| 欧美国产精品一区二区三区| 欧美精品在线一区二区三区| 激情国产一区二区| 一区二区三区产品免费精品久久75| 91精品国产aⅴ一区二区| 99久久伊人精品| 免费成人结看片| 亚洲精品国产第一综合99久久| 91精品国产品国语在线不卡| 97久久人人超碰| 激情综合色综合久久| 亚洲激情成人在线| 久久免费偷拍视频| 欧美日韩国产另类一区| 成人不卡免费av| 奇米在线7777在线精品| 亚洲精品乱码久久久久久黑人 | 成人av第一页| 久久99精品国产| 亚洲综合精品久久| 国产欧美精品一区二区色综合 | 欧美sm极限捆绑bd| 精品污污网站免费看| 国产91精品精华液一区二区三区| 日韩精品一二三| 亚洲精品中文在线影院| 久久久99久久| 日韩午夜在线观看| 欧美日韩综合在线| 色综合久久天天| 高清视频一区二区| 精品一区二区三区视频在线观看 | 美腿丝袜在线亚洲一区| 亚洲欧美成aⅴ人在线观看| 久久精品一区二区三区av| 555夜色666亚洲国产免| 在线精品视频免费观看| 99久久久免费精品国产一区二区| 国产乱子伦视频一区二区三区 | 91在线观看下载| 国产精品夜夜嗨| 激情综合五月婷婷| 欧美a一区二区| 亚洲一区精品在线| 亚洲欧美另类图片小说| 亚洲国产精品激情在线观看| www国产精品av| 日韩欧美久久久| 91精品一区二区三区久久久久久| 欧美系列日韩一区| 91极品视觉盛宴| 色婷婷综合激情| 91啪九色porn原创视频在线观看| 国产成人自拍网| 国产成人在线色| 国产成人精品免费在线| 国产一本一道久久香蕉| 国产一区二区在线电影| 韩国一区二区在线观看| 激情图区综合网| 国产一区二区影院| 国产福利一区二区| 国产高清不卡一区二区| 国产成人自拍网| 成人午夜私人影院| av影院午夜一区| 91美女视频网站| 在线观看中文字幕不卡| 欧美午夜电影网| 欧美日韩小视频| 制服丝袜在线91| 日韩一级高清毛片| 日韩三级视频在线看| 日韩一区二区三区免费看| 精品美女一区二区| 久久久久青草大香线综合精品| 久久午夜国产精品| 久久亚洲精华国产精华液| 久久久99精品免费观看不卡| 中文字幕欧美激情一区| 成人欧美一区二区三区白人| 亚洲欧美日本韩国| 亚洲第一会所有码转帖| 免费看黄色91| 久久99精品久久久久久| 国产伦精品一区二区三区免费| 国产成人午夜电影网| 99国产精品久| 精品婷婷伊人一区三区三| 欧美一区二区免费视频| 精品国精品自拍自在线| 国产女人aaa级久久久级| 亚洲欧美在线aaa| 亚洲一区二区三区国产| 日韩福利电影在线| 国产在线视频不卡二| 成人久久18免费网站麻豆 | 狠狠色丁香婷婷综合| 成人免费福利片| 欧美亚洲免费在线一区| 日韩一区二区免费在线电影| 久久精品人人做人人爽97 | 亚洲男人的天堂在线观看| 亚洲国产精品人人做人人爽| 欧美aaaaaa午夜精品| 国内精品自线一区二区三区视频| 国产精品91一区二区| aaa欧美大片| 欧美日韩在线直播| 欧美成人r级一区二区三区| 欧美国产日韩在线观看| 亚洲图片欧美色图| 精品影院一区二区久久久| 成人免费毛片aaaaa**| 欧美三电影在线| 久久精品亚洲国产奇米99| 亚洲蜜臀av乱码久久精品| 青青草伊人久久| 成人动漫一区二区在线| 欧美福利电影网| 中文在线免费一区三区高中清不卡 | 国产精品午夜春色av| 午夜电影网亚洲视频| 国产酒店精品激情| 欧美性videosxxxxx| 久久精品亚洲国产奇米99| 一区二区成人在线观看| 精品系列免费在线观看| 一本大道av一区二区在线播放| 欧美一二三在线| 亚洲婷婷在线视频| 久久99国产精品麻豆| 一本一道久久a久久精品综合蜜臀| 日韩欧美高清dvd碟片| 曰韩精品一区二区| 国产精一区二区三区| 欧美日韩免费电影| 国产欧美一区二区三区在线老狼| 亚洲成人综合在线| 成人午夜短视频| 欧美一区二区三区电影| 亚洲三级小视频| 激情欧美一区二区| 欧美日韩一区三区四区| 国产精品久久久久久久久晋中| 日本欧美一区二区| 欧美自拍丝袜亚洲| 欧美极品aⅴ影院| 精品一区二区三区久久久| 在线观看不卡一区| 日本一区二区综合亚洲| 乱一区二区av| 欧美日韩国产精品成人| 亚洲日本乱码在线观看| 国产乱子轮精品视频| 欧美一区二区三区男人的天堂| 亚洲乱码国产乱码精品精小说| 黄色小说综合网站| 欧美二区在线观看| 一区二区三区高清在线| www.综合网.com| 国产亚洲短视频|