C++程序  |  120行  |  3.79 KB

/******************************************************************************
 *
 * Copyright (C) 2018 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at:
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 *****************************************************************************
 * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
*/

/**
******************************************************************************
* @file ihevce_profile.h
*
* @brief
*  This file contains profiling related definitions
*
* @author
*    Ittiam
******************************************************************************
*/

#ifndef _IHEVCE_PROFILE_H_
#define _IHEVCE_PROFILE_H_

/*****************************************************************************/
/* Constant Macros                                                           */
/*****************************************************************************/
#define PROFILE_ENABLE 0

typedef struct
{
    /* Note that time below will be in units of micro seconds */
    /* Time before process call */
    ULWORD64 u8_time_start;

    /* Time after process call */
    ULWORD64 u8_time_end;

    /* Time taken by the last process call */
    ULWORD64 u8_cur_time;

    /* Sum total of the time taken by process calls so far */
    ULWORD64 u8_total_time;

    /*Avg time taken by a process so far */
    ULWORD64 u8_avg_time;

    /* Peak time taken by a process so far */
    ULWORD64 u8_peak_time;

    /* Number of process calls so far.
     * Required for calc of avg time taken per process call */
    UWORD32 u4_num_profile_calls;

    /* This flag is present to check that every
     * profile_start() will have a corresponding
     * arm_profile_sample_time_end() */
    UWORD8 u1_sample_taken_flag;

} profile_database_t;

typedef struct
{
    WORD32 tv_sec; /* Time in seconds.                            */
    WORD32 tv_usec; /* Time in micro seconds.                      */
} timeval_t;

/*****************************************************************************/
/* Function Declarations                                                     */
/*****************************************************************************/
void profile_sample_time_start();
void profile_sample_time_end();
void profile_print_stats();
int profile_get_avg_time(profile_database_t *ps_profile_data);
int profile_get_peak_time(profile_database_t *ps_profile_data);
int profile_convert_to_milli_sec(profile_database_t *ps_profile_data);

ULWORD64 profile_sample_time();

/* Should be called after each process call */
void profile_stop(profile_database_t *ps_profile_data, char *msg);

/* Should be called before every process call */
void profile_start(profile_database_t *ps_profile_data);

/* Should be called after codec instance initialization */
void init_profiler(profile_database_t *ps_profile_data);

/* Should be called at the end of processing */
void profile_end(profile_database_t *ps_profile_data, char *msg);

#if PROFILE_ENABLE

#define PROFILE_INIT(x) init_profiler(x)
#define PROFILE_START(x) profile_start(x)
#define PROFILE_STOP(x, y) profile_stop(x, y)
#define PROFILE_END(x, y) profile_end(x, y)

#else /* #if PROFILE_ENABLE */

#define PROFILE_INIT(x)
#define PROFILE_START(x)
#define PROFILE_STOP(x, y)
#define PROFILE_END(x, y)

#endif /* #if PROFILE_ENABLE */

#endif /* _IHEVCE_PROFILE_H_ */