⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 perfcomm.c

📁 三星2440原版bsp
💻 C
字号:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// This source code is licensed under Microsoft Shared Source License
// Version 1.0 for Windows CE.
// For a copy of the license visit http://go.microsoft.com/fwlink/?LinkId=3223.
//
/*++

Module Name:

    perfcomm.c

Abstract:

    CEPerf header file defining symbols used in comm OS tree.
    Performance Measurement Definitions.

Environment:

    Kernel mode driver

--*/


#ifdef CEPERF_ENABLE

#include <perfcomm.h>

LPVOID pCePerfInternal;   // Instantiate required CePerf global
static HANDLE g_hCePerfSession = INVALID_HANDLE_VALUE;  // Handle to coredll session

CEPERF_BASIC_ITEM_DESCRIPTOR g_rgPerfItems[PERFCOMM_NUM_IDS] = {
    PERFCOMM_LIST
};

VOID PerfCommInit()
{
    CEPERF_SESSION_INFO info;
    int                 i; 

    RETAILMSG (1, (TEXT("PERFCOMM:: Registering session [%s] for [%d]  perf items.\r\n"),
        PERFCOMM_SESSION_NAME,
        PERFCOMM_NUM_IDS));

    for (i = 0 ; i < PERFCOMM_NUM_IDS ; i++)
    {
        RETAILMSG (1, (TEXT("PERFCOMM:: Perf item[%d] \t [%s]\r\n"),
        i,
        g_rgPerfItems[i].lpszItemName));
    }
        

    
    CePerfControlCPU(CEPERF_CPU_ENABLE
                     | CEPERF_CPU_ICACHE_MISSES | CEPERF_CPU_ICACHE_HITS
                     | CEPERF_CPU_DCACHE_MISSES | CEPERF_CPU_DCACHE_HITS,
                     NULL, 0);

    // Session setup
    memset(&info, 0, sizeof(CEPERF_SESSION_INFO));
    info.wVersion = 1;
    info.dwStorageFlags = CEPERF_STORE_DEBUGOUT | CEPERF_STORE_TEXT;
    CePerfOpenSession(&g_hCePerfSession, PERFCOMM_SESSION_NAME,
              CEPERF_STATUS_RECORDING_ENABLED | CEPERF_STATUS_STORAGE_ENABLED | CEPERF_STATUS_NOT_THREAD_SAFE,
              &info);

    // Register Statistic and Duration items
    CePerfRegisterBulk(g_hCePerfSession, g_rgPerfItems, PERFCOMM_NUM_IDS, 0);
}

VOID PerfCommDeInit()
{
    // Write results to debugout
    CePerfFlushSession(g_hCePerfSession, NULL, CEPERF_FLUSH_DESCRIPTORS | CEPERF_FLUSH_DATA, 0);
    
    // Session cleanup (would also be cleaned up on process exit)
    CePerfDeregisterBulk(g_rgPerfItems, PERFCOMM_NUM_IDS);
    CePerfCloseSession(g_hCePerfSession);
}


#endif // CEPERF_ENABLE

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -