hc
2023-02-13 e440ec23c5a540cdd3f7464e8779219be6fd3d95
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
/* SPDX-License-Identifier: ((GPL-2.0+ WITH Linux-syscall-note) OR MIT)
 *
 * Copyright (C) 2019 Rockchip Electronics Co., Ltd.
 */
 
#ifndef _UAPI_RKCIF_CONFIG_H
#define _UAPI_RKCIF_CONFIG_H
 
#include <linux/types.h>
#include <linux/v4l2-controls.h>
 
#define RKCIF_API_VERSION        KERNEL_VERSION(0, 1, 0xa)
 
#define RKCIF_CMD_GET_CSI_MEMORY_MODE \
   _IOR('V', BASE_VIDIOC_PRIVATE + 0, int)
 
#define RKCIF_CMD_SET_CSI_MEMORY_MODE \
   _IOW('V', BASE_VIDIOC_PRIVATE + 1, int)
 
#define RKCIF_CMD_GET_RESET_INFO \
   _IOR('V', BASE_VIDIOC_PRIVATE + 5, struct rkcif_reset_info)
 
#define RKCIF_CMD_SET_RESET \
   _IOW('V', BASE_VIDIOC_PRIVATE + 6, int)
 
/* cif memory mode
 * 0: raw12/raw10/raw8 8bit memory compact
 * 1: raw12/raw10 16bit memory one pixel
 *    low align for rv1126/rv1109/rk356x
 *    |15|14|13|12|11|10| 9| 8| 7| 6| 5| 4| 3| 2| 1| 0|
 *    | -| -| -| -|11|10| 9| 8| 7| 6| 5| 4| 3| 2| 1| 0|
 * 2: raw12/raw10 16bit memory one pixel
 *    high align for rv1126/rv1109/rk356x
 *    |15|14|13|12|11|10| 9| 8| 7| 6| 5| 4| 3| 2| 1| 0|
 *    |11|10| 9| 8| 7| 6| 5| 4| 3| 2| 1| 0| -| -| -| -|
 *
 * note: rv1109/rv1126/rk356x dvp only support uncompact mode,
 *       and can be set low align or high align
 */
 
enum cif_csi_lvds_memory {
   CSI_LVDS_MEM_COMPACT = 0,
   CSI_LVDS_MEM_WORD_LOW_ALIGN = 1,
   CSI_LVDS_MEM_WORD_HIGH_ALIGN = 2,
};
 
struct rkcif_reset_info {
   int is_need_reset;
   int reset_src;
};
 
#endif