File: mfx_timing.h

package info (click to toggle)
onevpl-intel-gpu 26.1.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 58,920 kB
  • sloc: cpp: 1,444,019; ansic: 29,778; asm: 17,754; makefile: 6
file content (114 lines) | stat: -rw-r--r-- 3,812 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
// Copyright (c) 2008-2018 Intel Corporation
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in all
// copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.

#ifndef __MFX_TIMING_H__
#define __MFX_TIMING_H__

//uncomment this define for timing instrumentation
//#define MFX_TIMING

#define MFX_TIMING_CHECK_REGISTRY   0x10000000
#define MFX_TIMING_PROXY_LIBSW      0x20000000
#define MFX_TIMING_PROXY_LIBHW      0x40000000

#define MFX_INVALID_STATUS_CODE     (int)0xffff

// for SetInput/SetOutput
enum
{
    MFX_COMP_DECODE  = 1,
    MFX_COMP_VPP     = 2,
    MFX_COMP_ENCODE  = 3,
};

#ifndef NULL
#ifdef __cplusplus
#define NULL    0
#else
#define NULL    ((void *)0)
#endif
#endif

namespace MFX
{

#ifndef MFX_TIMING

// empty declaration for normal build
class AutoTimer
{
public:
    static int Init(const void * /*filename*/, int /*level = -1*/) { return 0; }
    static unsigned int CreateUniqTaskId() {return 0;}

    AutoTimer(const char * /*name*/) {}
    AutoTimer(const char * /*name*/, const char * /*param*/, int /*parami = 0*/)    {}
    AutoTimer(const char * /*name*/, bool /*bCreateId*/, unsigned int /*child_of*/, unsigned int /*parent_of*/)  {}
    ~AutoTimer() {};
    AutoTimer() {};

    void SetInput(void * /*handle*/, int /*component_index = -1*/) {};
    void SetOutput(void * /*handle*/, int /*component_index = -1*/) {};
    void AddParam(const char * /*param_name*/, const char * /*param_value*/) {};
    void AddParam(const char * /*param_name*/, int /*param_value*/) {};
    void Start(const char * /*name*/) {};
    void Stop(int /*return_code = MFX_INVALID_STATUS_CODE*/) {};
};

#else // MFX_TIMING

class AutoTimer
{
public:
    // static method to initialize timing capture
    static int Init(const void *filename, int level = -1);
    //returned uniq task ID
    static unsigned int CreateUniqTaskId();

    AutoTimer(const char *name); // start timer
    AutoTimer(const char *name, const char *param, int parami = 0); // start timer
    AutoTimer(const char *name, bool bCreateId, unsigned int child_of, unsigned int parent_of); // start timer
    ~AutoTimer(); // stop timer
    AutoTimer(); // default constructor. Aftewards call SetInput/SetOutput/AddParam, then Start


    void SetInput(void *handle, int component_index = -1);
    void SetOutput(void *handle, int component_index = -1);
    void AddParam(const char *param_name, const char *param_value);
    void AddParam(const char *param_name, int param_value);
    void Start(const char *name);
    void Stop(int return_code = MFX_INVALID_STATUS_CODE);
    unsigned int ID(){return m_timerid;}

protected:
    void Reset();
    void SendNamedEvent(int opcode);

    const char  *m_Name;
    unsigned int m_timerid;
    unsigned int m_parentid;
    unsigned int m_childid;
};

#endif // MFX_TIMING

} // namespace UMC

#endif // __MFX_TIMING_H__