hc
2024-10-22 8ac6c7a54ed1b98d142dce24b11c6de6a1e239a5
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
/* SPDX-License-Identifier: GPL-2.0 */
/* Copyright (c) 2019 Fuzhou Rockchip Electronics Co., Ltd. */
 
#ifndef _RKISPP_PARAMS_H
#define _RKISPP_PARAMS_H
 
#include <linux/fec-config.h>
#include <linux/rk-ispp-config.h>
#include "common.h"
 
enum rkispp_paramvdev_id {
   PARAM_VDEV_TNR = 0,
   PARAM_VDEV_NR,
   PARAM_VDEV_FEC,
   PARAM_VDEV_MAX
};
 
#define ISPP_PACK_4BYTE(a, b, c, d) \
   (((a) & 0xFF) << 0 | ((b) & 0xFF) << 8 | \
    ((c) & 0xFF) << 16 | ((d) & 0xFF) << 24)
 
#define ISPP_PACK_4BIT(a, b, c, d, e, f, g, h) \
   (((a) & 0xf) << 0 | ((b) & 0xf) << 4 | \
    ((c) & 0xf) << 8 | ((d) & 0xf) << 12 | \
    ((e) & 0xf) << 16 | ((f) & 0xf) << 20 | \
    ((g) & 0xf) << 24 | ((h) & 0xf) << 28)
 
#define ISPP_PACK_4BYTE(a, b, c, d) \
   (((a) & 0xFF) << 0 | ((b) & 0xFF) << 8 | \
    ((c) & 0xFF) << 16 | ((d) & 0xFF) << 24)
 
#define ISPP_PACK_2SHORT(a, b) \
   (((a) & 0xFFFF) << 0 | ((b) & 0xFFFF) << 16)
 
#define ISPP_NOBIG_OVERFLOW_SIZE    (2560 * 1440)
 
/* rkispp parameters device
 * config_lock: lock to protect config
 * params: queued buffer list
 * cur_buf: current buf of parameters
 * first_params: the first params should take effect immediately
 */
struct rkispp_params_vdev {
   struct rkispp_vdev_node vnode;
   struct rkispp_device *dev;
   struct rkispp_params_ops *params_ops;
 
   spinlock_t config_lock;
   struct list_head params;
   struct rkispp_buffer *cur_buf;
 
   struct v4l2_format vdev_fmt;
   bool streamon;
   bool first_params;
   bool is_subs_evt;
 
   struct rkispp_dummy_buffer buf_fec[FEC_MESH_BUF_MAX];
   u32 buf_fec_idx;
   u32 buf_cnt;
   enum rkispp_paramvdev_id vdev_id;
};
 
struct rkispp_params_ops {
   void (*rkispp_params_cfg)(struct rkispp_params_vdev *params_vdev, u32 frame_id);
   void (*rkispp_params_vb2_buf_queue)(struct vb2_buffer *vb);
};
 
int rkispp_register_params_vdevs(struct rkispp_device *dev);
void rkispp_unregister_params_vdevs(struct rkispp_device *dev);
void rkispp_params_get_fecbuf_inf(struct rkispp_params_vdev *params_vdev,
                 struct rkispp_fecbuf_info *fecbuf);
void rkispp_params_set_fecbuf_size(struct rkispp_params_vdev *params_vdev,
                  struct rkispp_fecbuf_size *fecsize);
 
#endif