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

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

?? signimage.c

?? 三星 ARM920T S3C2440A 400MHz bsp包
?? C
字號:
//
// 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.
//
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.

Module Name:  
    signimage.c
    
Abstract:  
        
Functions:


Notes: 

--*/
#include <windows.h>
#include <halether.h>
#include <minasn1.h>
#include <mincrypt.h>
#include <traverse.h>

// Matches BIB file EXTENSION area (note BIB file names are forced to lower case).
const unsigned char WHQLSigExtName[] = "whql_sig";

// Secure loader globals
extern DWORD g_dwROMOffset;
DWORD g_hHash;
BYTE rgbOID_Attr[] =
//OID (1.3.6.1.4.1.311.12.2.1) has the following encoding:
// "1.3.6.1.4.1.311.12.2.1"
{0x2B, 0x06, 0x01, 0x04, 0x01, 0x82, 0x37, 0x0C, 0x02, 0x01};

BYTE  rgbManufacturerTag[] = 
//"Manufacturer" as a BMP string
{ 0x00, 0x4D, 0x00, 0x61, 0x00, 0x6E, 0x00, 0x75, 0x00, 0x66, 0x00, 0x61, 0x00, 0x63, 0x00, 
0x74, 0x00, 0x75, 0x00, 0x72, 0x00, 0x65, 0x00, 0x72};

BYTE  rgbModelTag[] = 
//"Model" as a BMP string
{0x00, 0x4D, 0x00, 0x6F, 0x00, 0x64, 0x00, 0x65, 0x00, 0x6C};


BOOL UpdateHash(DWORD dwAddr, DWORD dwSize)
{
    CRYPT_DER_BLOB ScratchBlob;

    ScratchBlob.cbData = dwSize;
    ScratchBlob.pbData = (BYTE *)dwAddr;

    if (MinCryptUpdateHashMemory(CALG_SHA1, g_hHash, 1, &ScratchBlob))
    {
        return(FALSE);
    }

    return(TRUE);
}


BOOL CheckSignature(DWORD dwStoreBase, DWORD dwRunBase, BOOL fTestSignature,
                    OPTIONAL IN BYTE* pbDeviceMakeData, OPTIONAL IN DWORD dwDeviceMakeSize,
                    OPTIONAL IN BYTE* pbDeviceModelData, OPTIONAL IN DWORD dwDeviceModelSize)
{
#define REBASE_ADDR(x)   (x + (dwStoreBase - dwRunBase))
    DWORD dwpTOC = 0;
    ROMHDR *pROMHdr = NULL;
    EXTENSION *pExt = NULL;
    BYTE *pSig = NULL;
    DWORD dwSigLen = 0;
    DWORD cbHash = 0;
    DWORD cbAttr = 0;
    LONG rglErr = 0;
    LONG lStatus = 0;
    BYTE rgbHash[MINCRYPT_MAX_HASH_LEN];
    CRYPT_HASH_BLOB rgHashBlob;
    MAP_CAT_INFO rgMapCatInfo;
    CRYPT_DATA_BLOB rgExtensionTagName;
    CRYPT_DATA_BLOB rgExtensionValue;
    CRYPT_DATA_BLOB rgAttrEncodedOIDBlob;


    // Check for TOC signature.
    //
    if (*(LPDWORD)(dwStoreBase + ROM_SIGNATURE_OFFSET) != ROM_SIGNATURE)
    {
        EdbgOutputDebugString ("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n");
        EdbgOutputDebugString ("! ERROR: Did not find pTOC signature.  ABORTING. !\r\n");
        EdbgOutputDebugString ("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\r\n");

        return(FALSE);
    }

    // Get pointer to TOC.
    //
    dwpTOC = *(LPDWORD)(dwStoreBase + ROM_SIGNATURE_OFFSET + sizeof(ULONG));

    // Locate the WHQL signature record via the ROMHDR extension pointer.
    //
    pROMHdr = (ROMHDR *)REBASE_ADDR(dwpTOC);

    if (!pROMHdr->pExtensions)
    {
        EdbgOutputDebugString("ERROR: No extensions list (NULL pointer).\r\n");
        return(FALSE);
    }

    pExt = (EXTENSION *)REBASE_ADDR((DWORD)pROMHdr->pExtensions);

    while(pExt && memcmp(pExt->name, WHQLSigExtName, strlen(WHQLSigExtName)))
    {
        if (!pExt->pNextExt)
        {
            pExt = NULL;
            break;
        }

        pExt = (EXTENSION *)REBASE_ADDR((DWORD)pExt->pNextExt);
    }

    if (!pExt)
    {
        EdbgOutputDebugString("ERROR: No signature record in extensions list (an extension block hasn't been reserved in this image)?\r\n");
        return(FALSE);
    }

    // Get location and length of the signature.
    //
    dwSigLen = pExt->length;
    pSig     = (BYTE *)REBASE_ADDR((DWORD)pExt->pdata);
    if (!dwSigLen)
    {
        EdbgOutputDebugString("ERROR: Signature length is zero.  Was this image stamped with a signature?\r\n");
        return(FALSE);
    }
    
    EdbgOutputDebugString("INFO: Found signature (Address=0x%x  Length=0x%x).\r\n", (DWORD)pSig, dwSigLen);

    // Hash memory initialization.
    //
    MinCryptCreateHashMemory(CALG_SHA1, &g_hHash);

    // Traverse the image and compute the hash.
    //
    if (!SigProcessImage((ROMHDR *)dwpTOC, (dwStoreBase - dwRunBase), UpdateHash))
    {
        return(FALSE);
    }

    // Finish computing the hash.
    //
    MinCryptGetHashParam(CALG_SHA1, g_hHash, rgbHash, &cbHash);
    
    rgHashBlob.cbData = cbHash;
    rgHashBlob.pbData = rgbHash;

    memset(&rgMapCatInfo, 0, sizeof(MAP_CAT_INFO));
    
    rgMapCatInfo.FileBlob.cbData = dwSigLen;
    rgMapCatInfo.FileBlob.pbData = pSig;

    rgAttrEncodedOIDBlob.cbData = sizeof(rgbOID_Attr);
    rgAttrEncodedOIDBlob.pbData = rgbOID_Attr;

    // Compute a CAT record for the hashed data and compare against the CAT record stamped in the image.
    //
    lStatus = MinCryptVerifyHashInCatalogBlob(CALG_SHA1, 1, &rgHashBlob, 1, &rgMapCatInfo, fTestSignature, &rglErr);
    if (lStatus || rglErr)
    {
        EdbgOutputDebugString("ERROR: MinCryptVerifyHashInCatalogs returned 0x%x (rglErr=0x%x).\r\n", lStatus, rglErr);
        return(FALSE);
    }

    // Optionally verify the Make attribute.    
    if (pbDeviceMakeData && dwDeviceMakeSize)
    {
        // Now check the Make string
        rgExtensionTagName.cbData = sizeof(rgbManufacturerTag);
        rgExtensionTagName.pbData = rgbManufacturerTag;
       
        rgExtensionValue.cbData = dwDeviceMakeSize;
        rgExtensionValue.pbData = pbDeviceMakeData;
        
        lStatus = MinCryptVerifyExtension(rgMapCatInfo, rgAttrEncodedOIDBlob, rgExtensionTagName, rgExtensionValue);
        if (lStatus)
        {
            EdbgOutputDebugString("ERROR: MinCryptVerifyExtension failed to verify manufacturer\r\n");
            return (FALSE);
        }
    }
    
    // Optionally verify the Model attribute.    
    if (pbDeviceModelData && dwDeviceModelSize)
    {
        rgExtensionTagName.cbData = sizeof(rgbModelTag);
        rgExtensionTagName.pbData = rgbModelTag;
       
        rgExtensionValue.cbData = dwDeviceModelSize;
        rgExtensionValue.pbData = pbDeviceModelData;
    
        lStatus = MinCryptVerifyExtension(rgMapCatInfo, rgAttrEncodedOIDBlob, rgExtensionTagName, rgExtensionValue);
        if (lStatus)
        {
            EdbgOutputDebugString("ERROR: MinCryptVerifyExtension failed to verify Model\r\n");
            return (FALSE);
        }
    }

    EdbgOutputDebugString("INFO: Signature check passed!\r\n");
    
    return(TRUE);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费欧美高清视频| 成人免费视频播放| 国产精品色哟哟网站| 精品视频在线免费看| 国产成人免费视频| 人人精品人人爱| 亚洲精选视频免费看| 国产日产精品1区| 这里只有精品免费| 欧美中文一区二区三区| 高清不卡一二三区| 激情图区综合网| 日韩av一级电影| 亚洲精品成人精品456| 国产精品国产三级国产有无不卡 | 欧美亚洲国产一卡| 成人黄色电影在线| 国产一区二区三区综合| 日韩国产高清影视| 日韩影院免费视频| 亚洲小说欧美激情另类| 亚洲色欲色欲www| 综合激情成人伊人| 一区在线观看视频| 国产精品麻豆网站| 国产精品欧美久久久久一区二区| www一区二区| 精品国产乱码久久久久久闺蜜| 欧美精品在线视频| 欧美日产在线观看| 在线成人高清不卡| 欧美一级二级三级蜜桃| 制服丝袜亚洲精品中文字幕| 欧美日韩国产综合一区二区| 欧美性生活久久| 欧美午夜理伦三级在线观看| 在线观看日韩精品| 欧美中文字幕一二三区视频| 91成人免费网站| 欧美日韩在线免费视频| 欧美无乱码久久久免费午夜一区| 在线免费精品视频| 欧美电影在线免费观看| 在线综合视频播放| 日韩你懂的在线观看| 精品对白一区国产伦| 久久青草国产手机看片福利盒子| 国产欧美一区二区精品仙草咪| 欧美激情综合网| 亚洲色欲色欲www在线观看| 亚洲精品乱码久久久久| 亚洲永久免费av| 日韩二区在线观看| 国内外精品视频| 国产1区2区3区精品美女| 99国产精品久久久| 欧美亚洲国产一区二区三区va| 56国语精品自产拍在线观看| 欧美一区二区观看视频| 国产亚洲一区字幕| 亚洲激情图片qvod| 日韩1区2区日韩1区2区| 国产麻豆91精品| 97久久精品人人做人人爽| 欧美午夜精品一区| 久久综合色综合88| 亚洲欧美韩国综合色| 午夜精品久久久久久久| 精东粉嫩av免费一区二区三区| 成人污视频在线观看| 91福利在线免费观看| 日韩欧美一区二区三区在线| 国产欧美日韩不卡| 亚洲高清免费一级二级三级| 国产在线播放一区| 91在线观看下载| 91精品国产色综合久久久蜜香臀| 久久免费午夜影院| 一级中文字幕一区二区| 精品亚洲国产成人av制服丝袜| 99久久精品99国产精品| 欧美精品18+| 欧美国产精品一区二区三区| 天堂va蜜桃一区二区三区 | 91福利在线免费观看| 精品国产百合女同互慰| 亚洲欧美日韩一区二区| 另类小说一区二区三区| 91麻豆免费在线观看| 日韩欧美成人一区| 亚洲自拍与偷拍| 国产美女视频91| 欧美美女一区二区在线观看| 国产欧美日韩在线观看| 日韩国产欧美在线视频| 99riav久久精品riav| 久久综合久色欧美综合狠狠| 亚洲一区二区在线视频| 成人三级在线视频| 欧美电影免费观看高清完整版在线观看| 中文字幕亚洲区| 久久99精品国产.久久久久久| 在线区一区二视频| 国产精品国产精品国产专区不蜜| 青青草国产成人99久久| 日本精品一区二区三区高清| 久久免费的精品国产v∧| 亚洲成人先锋电影| 色先锋资源久久综合| 日本一区二区三区在线观看| 麻豆成人久久精品二区三区红| 91黄视频在线| 一色屋精品亚洲香蕉网站| 国产大陆a不卡| 日韩精品专区在线影院观看| 午夜精品福利一区二区三区av| av在线播放一区二区三区| 久久久综合网站| 久久99精品国产.久久久久久| 777久久久精品| 亚洲v日本v欧美v久久精品| 色婷婷狠狠综合| 亚洲视频在线观看三级| 国产ts人妖一区二区| 久久亚洲精华国产精华液| 久久国产乱子精品免费女| 91精品婷婷国产综合久久竹菊| 亚洲第一综合色| 欧美日韩视频在线观看一区二区三区| 亚洲欧美另类久久久精品2019| 91丝袜美腿高跟国产极品老师| 欧美国产成人精品| 成人黄色av电影| 国产精品麻豆网站| 色综合久久中文综合久久牛| 亚洲人亚洲人成电影网站色| 99国产一区二区三精品乱码| 亚洲激情在线激情| 欧美日韩在线观看一区二区 | 日本一区二区综合亚洲| 成人黄色软件下载| 亚洲欧美一区二区三区极速播放| 99re亚洲国产精品| 亚洲国产综合色| 91精品国产免费久久综合| 免费人成精品欧美精品| 精品福利视频一区二区三区| 国产ts人妖一区二区| 综合中文字幕亚洲| 欧美日韩一区成人| 裸体一区二区三区| 久久免费精品国产久精品久久久久| 粉嫩一区二区三区性色av| 中文字幕制服丝袜一区二区三区 | 欧美在线观看禁18| 精品少妇一区二区三区在线视频| 欧美一区欧美二区| 福利电影一区二区三区| 蜜臀av一区二区在线免费观看 | 黄网站免费久久| 国产精品中文字幕欧美| 99视频一区二区三区| 欧美色偷偷大香| 国产丝袜在线精品| 日本女优在线视频一区二区| 欧美伊人久久大香线蕉综合69| 中文字幕一区二区日韩精品绯色| 国产综合久久久久影院| 亚洲精品在线网站| 国产精品一级片在线观看| 欧美一区二区三区在| 精品一区二区三区免费毛片爱 | 尤物在线观看一区| 亚洲久草在线视频| 成人夜色视频网站在线观看| 色狠狠av一区二区三区| 91精品国产麻豆| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲一区二区成人在线观看| 一区av在线播放| 亚洲人成人一区二区在线观看| 欧美日韩一级片网站| 国产福利91精品| 香港成人在线视频| 亚洲国产精品高清| 在线综合视频播放| 99久久99久久综合| 久久精品免费看| 亚洲综合一区在线| 欧美国产一区二区在线观看| 欧美在线观看视频一区二区| 国产aⅴ综合色| 人人精品人人爱| 亚洲精品菠萝久久久久久久| xfplay精品久久| 欧美日本一区二区| 色先锋久久av资源部| 国产成a人亚洲精品| 蜜臀av一区二区三区| 亚洲最快最全在线视频|