master
1/* SPDX-License-Identifier: GPL-2.0-only WITH Linux-syscall-note */
2/*
3 * RP1 PiSP Front End statistics definitions
4 *
5 * Copyright (C) 2021 - Raspberry Pi Ltd.
6 *
7 */
8#ifndef _PISP_FE_STATISTICS_H_
9#define _PISP_FE_STATISTICS_H_
10
11#include <linux/types.h>
12
13#define PISP_FLOATING_STATS_NUM_ZONES 4
14#define PISP_AGC_STATS_NUM_BINS 1024
15#define PISP_AGC_STATS_SIZE 16
16#define PISP_AGC_STATS_NUM_ZONES (PISP_AGC_STATS_SIZE * PISP_AGC_STATS_SIZE)
17#define PISP_AGC_STATS_NUM_ROW_SUMS 512
18
19struct pisp_agc_statistics_zone {
20 __u64 Y_sum;
21 __u32 counted;
22 __u32 pad;
23} __attribute__((packed));
24
25struct pisp_agc_statistics {
26 __u32 row_sums[PISP_AGC_STATS_NUM_ROW_SUMS];
27 /*
28 * 32-bits per bin means an image (just less than) 16384x16384 pixels
29 * in size can weight every pixel from 0 to 15.
30 */
31 __u32 histogram[PISP_AGC_STATS_NUM_BINS];
32 struct pisp_agc_statistics_zone floating[PISP_FLOATING_STATS_NUM_ZONES];
33} __attribute__((packed));
34
35#define PISP_AWB_STATS_SIZE 32
36#define PISP_AWB_STATS_NUM_ZONES (PISP_AWB_STATS_SIZE * PISP_AWB_STATS_SIZE)
37
38struct pisp_awb_statistics_zone {
39 __u32 R_sum;
40 __u32 G_sum;
41 __u32 B_sum;
42 __u32 counted;
43} __attribute__((packed));
44
45struct pisp_awb_statistics {
46 struct pisp_awb_statistics_zone zones[PISP_AWB_STATS_NUM_ZONES];
47 struct pisp_awb_statistics_zone floating[PISP_FLOATING_STATS_NUM_ZONES];
48} __attribute__((packed));
49
50#define PISP_CDAF_STATS_SIZE 8
51#define PISP_CDAF_STATS_NUM_FOMS (PISP_CDAF_STATS_SIZE * PISP_CDAF_STATS_SIZE)
52
53struct pisp_cdaf_statistics {
54 __u64 foms[PISP_CDAF_STATS_NUM_FOMS];
55 __u64 floating[PISP_FLOATING_STATS_NUM_ZONES];
56} __attribute__((packed));
57
58struct pisp_statistics {
59 struct pisp_awb_statistics awb;
60 struct pisp_agc_statistics agc;
61 struct pisp_cdaf_statistics cdaf;
62} __attribute__((packed));
63
64#endif /* _PISP_FE_STATISTICS_H_ */