1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* Copyright (c) 2020 Rockchip Electronics Co., Ltd. */
3
4 #ifndef _RKISP_ISP_STATS_V3X_H
5 #define _RKISP_ISP_STATS_V3X_H
6
7 #include <linux/rkisp1-config.h>
8 #include <linux/interrupt.h>
9 #include <linux/kfifo.h>
10 #include "common.h"
11
12 #define ISP3X_RD_STATS_BUF_SIZE 0x10000
13
14 struct rkisp_isp_stats_vdev;
15 struct rkisp_stats_ops_v3x {
16 int (*get_rawawb_meas)(struct rkisp_isp_stats_vdev *stats_vdev,
17 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
18 int (*get_rawaf_meas)(struct rkisp_isp_stats_vdev *stats_vdev,
19 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
20 int (*get_rawae0_meas)(struct rkisp_isp_stats_vdev *stats_vdev,
21 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
22 int (*get_rawhst0_meas)(struct rkisp_isp_stats_vdev *stats_vdev,
23 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
24 int (*get_rawae1_meas)(struct rkisp_isp_stats_vdev *stats_vdev,
25 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
26 int (*get_rawhst1_meas)(struct rkisp_isp_stats_vdev *stats_vdev,
27 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
28 int (*get_rawae2_meas)(struct rkisp_isp_stats_vdev *stats_vdev,
29 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
30 int (*get_rawhst2_meas)(struct rkisp_isp_stats_vdev *stats_vdev,
31 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
32 int (*get_rawae3_meas)(struct rkisp_isp_stats_vdev *stats_vdev,
33 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
34 int (*get_rawhst3_meas)(struct rkisp_isp_stats_vdev *stats_vdev,
35 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
36 int (*get_bls_stats)(struct rkisp_isp_stats_vdev *stats_vdev,
37 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
38 int (*get_dhaz_stats)(struct rkisp_isp_stats_vdev *stats_vdev,
39 struct rkisp3x_isp_stat_buffer *pbuf, u32 id);
40 };
41
42 #if IS_ENABLED(CONFIG_VIDEO_ROCKCHIP_ISP_VERSION_V30)
43 void rkisp_stats_first_ddr_config_v3x(struct rkisp_isp_stats_vdev *stats_vdev);
44 void rkisp_init_stats_vdev_v3x(struct rkisp_isp_stats_vdev *stats_vdev);
45 void rkisp_uninit_stats_vdev_v3x(struct rkisp_isp_stats_vdev *stats_vdev);
46 #else
rkisp_stats_first_ddr_config_v3x(struct rkisp_isp_stats_vdev * stats_vdev)47 static inline void rkisp_stats_first_ddr_config_v3x(struct rkisp_isp_stats_vdev *stats_vdev) {}
rkisp_init_stats_vdev_v3x(struct rkisp_isp_stats_vdev * stats_vdev)48 static inline void rkisp_init_stats_vdev_v3x(struct rkisp_isp_stats_vdev *stats_vdev) {}
rkisp_uninit_stats_vdev_v3x(struct rkisp_isp_stats_vdev * stats_vdev)49 static inline void rkisp_uninit_stats_vdev_v3x(struct rkisp_isp_stats_vdev *stats_vdev) {}
50 #endif
51
52 #endif /* _RKISP_ISP_STATS_V3X_H */
53