lineage_kernel_xcoverpro/drivers/media/platform/exynos/fimc-is2/fimc-is-time.h

140 lines
2.9 KiB
C
Executable File

/*
* Samsung Exynos5 SoC series FIMC-IS driver
*
*
* Copyright (c) 2011 Samsung Electronics Co., Ltd
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
#ifndef FIMC_IS_TIME_H
#define FIMC_IS_TIME_H
#include <linux/time.h>
#include <linux/sched/clock.h>
#define MEASURE_TIME
#define MONITOR_TIME
#define MONITOR_TIMEOUT 5000 /* 5ms */
/* #define EXTERNAL_TIME */
/* #define INTERFACE_TIME */
#define INSTANCE_MASK 0x3
#define TM_FLITE_STR 0
#define TM_FLITE_END 1
#define TM_SHOT 2
#define TM_SHOT_D 3
#define TM_META_D 4
#define TM_MAX_INDEX 5
extern int debug_time_launch;
extern int debug_time_queue;
extern int debug_time_shot;
struct fimc_is_monitor {
unsigned long long time;
bool check;
};
struct fimc_is_time {
u32 time_count;
unsigned long long t_dq[10];
unsigned long long t_dqq_max;
unsigned long long t_dqq_tot;
unsigned long long time1_max;
unsigned long long time1_tot;
unsigned long long time2_max;
unsigned long long time2_tot;
unsigned long long time3_max;
unsigned long long time3_tot;
unsigned long long time4_cur;
unsigned long long time4_old;
unsigned long long time4_tot;
};
struct fimc_is_interface_time {
u32 cmd;
u32 time_tot;
u32 time_min;
u32 time_max;
u32 time_cnt;
};
enum fimc_is_time_launch {
LAUNCH_DDK_LOAD,
LAUNCH_PREPROC_LOAD,
LAUNCH_SENSOR_INIT,
LAUNCH_SENSOR_START,
LAUNCH_FAST_AE,
LAUNCH_TOTAL,
};
enum fimc_is_time_queue {
TMQ_DQ,
TMQ_QS,
TMQ_QE,
TMQ_END,
};
enum fimc_is_time_shot {
TMS_Q,
TMS_SHOT1,
TMS_SHOT2,
TMS_SDONE,
TMS_DQ,
TMS_END,
};
void TIME_STR(unsigned int index);
void TIME_END(unsigned int index, const char *name);
void fimc_is_jitter(u64 timestamp);
u64 fimc_is_get_timestamp(void);
u64 fimc_is_get_timestamp_boot(void);
#define PROGRAM_COUNT(count) monitor_point(group, count)
void monitor_point(void *group_data, u32 mpoint);
void monitor_time_shot(void *group_data, void *frame_data, u32 mpoint);
void monitor_time_queue(void *vctx_data, u32 mpoint);
#ifdef MEASURE_TIME
#ifdef MONITOR_TIME
void monitor_init(struct fimc_is_time *time);
#endif
#ifdef INTERFACE_TIME
void measure_init(struct fimc_is_interface_time *time, u32 cmd);
void measure_time(struct fimc_is_interface_time *time,
u32 instance,
u32 group,
struct timeval *start,
struct timeval *end);
#endif
#endif
#define TIME_LAUNCH_STR(p) \
do { \
if (unlikely(debug_time_launch)) \
TIME_STR(p); \
} while (0)
#define TIME_LAUNCH_END(p) \
do { \
if (unlikely(debug_time_launch)) \
TIME_END(p, #p); \
} while (0)
#define TIME_SHOT(point) \
do { \
if (debug_time_shot > 0) \
monitor_time_shot(group, frame, point); \
} while (0)
#define TIME_QUEUE(point) \
do { \
if (debug_time_queue > 0) \
monitor_time_queue(vctx, point); \
} while (0)
#endif