1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * Xilinx Controls Header 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (C) 2013-2015 Ideas on Board 6*4882a593Smuzhiyun * Copyright (C) 2013-2015 Xilinx, Inc. 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun * Contacts: Hyun Kwon <hyun.kwon@xilinx.com> 9*4882a593Smuzhiyun * Laurent Pinchart <laurent.pinchart@ideasonboard.com> 10*4882a593Smuzhiyun * 11*4882a593Smuzhiyun * This software is licensed under the terms of the GNU General Public 12*4882a593Smuzhiyun * License version 2, as published by the Free Software Foundation, and 13*4882a593Smuzhiyun * may be copied, distributed, and modified under those terms. 14*4882a593Smuzhiyun * 15*4882a593Smuzhiyun * This program is distributed in the hope that it will be useful, 16*4882a593Smuzhiyun * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*4882a593Smuzhiyun * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*4882a593Smuzhiyun * GNU General Public License for more details. 19*4882a593Smuzhiyun */ 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun #ifndef __UAPI_XILINX_V4L2_CONTROLS_H__ 22*4882a593Smuzhiyun #define __UAPI_XILINX_V4L2_CONTROLS_H__ 23*4882a593Smuzhiyun 24*4882a593Smuzhiyun #include <linux/v4l2-controls.h> 25*4882a593Smuzhiyun 26*4882a593Smuzhiyun #define V4L2_CID_XILINX_OFFSET 0xc000 27*4882a593Smuzhiyun #define V4L2_CID_XILINX_BASE (V4L2_CID_USER_BASE + V4L2_CID_XILINX_OFFSET) 28*4882a593Smuzhiyun 29*4882a593Smuzhiyun /* 30*4882a593Smuzhiyun * Private Controls for Xilinx Video IPs 31*4882a593Smuzhiyun */ 32*4882a593Smuzhiyun 33*4882a593Smuzhiyun /* 34*4882a593Smuzhiyun * Xilinx TPG Video IP 35*4882a593Smuzhiyun */ 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG (V4L2_CID_USER_BASE + 0xc000) 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun /* Draw cross hairs */ 40*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_CROSS_HAIRS (V4L2_CID_XILINX_TPG + 1) 41*4882a593Smuzhiyun /* Enable a moving box */ 42*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_MOVING_BOX (V4L2_CID_XILINX_TPG + 2) 43*4882a593Smuzhiyun /* Mask out a color component */ 44*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_COLOR_MASK (V4L2_CID_XILINX_TPG + 3) 45*4882a593Smuzhiyun /* Enable a stuck pixel feature */ 46*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_STUCK_PIXEL (V4L2_CID_XILINX_TPG + 4) 47*4882a593Smuzhiyun /* Enable a noisy output */ 48*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_NOISE (V4L2_CID_XILINX_TPG + 5) 49*4882a593Smuzhiyun /* Enable the motion feature */ 50*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_MOTION (V4L2_CID_XILINX_TPG + 6) 51*4882a593Smuzhiyun /* Configure the motion speed of moving patterns */ 52*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_MOTION_SPEED (V4L2_CID_XILINX_TPG + 7) 53*4882a593Smuzhiyun /* The row of horizontal cross hair location */ 54*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_CROSS_HAIR_ROW (V4L2_CID_XILINX_TPG + 8) 55*4882a593Smuzhiyun /* The colum of vertical cross hair location */ 56*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_CROSS_HAIR_COLUMN (V4L2_CID_XILINX_TPG + 9) 57*4882a593Smuzhiyun /* Set starting point of sine wave for horizontal component */ 58*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_ZPLATE_HOR_START (V4L2_CID_XILINX_TPG + 10) 59*4882a593Smuzhiyun /* Set speed of the horizontal component */ 60*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_ZPLATE_HOR_SPEED (V4L2_CID_XILINX_TPG + 11) 61*4882a593Smuzhiyun /* Set starting point of sine wave for vertical component */ 62*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_ZPLATE_VER_START (V4L2_CID_XILINX_TPG + 12) 63*4882a593Smuzhiyun /* Set speed of the vertical component */ 64*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_ZPLATE_VER_SPEED (V4L2_CID_XILINX_TPG + 13) 65*4882a593Smuzhiyun /* Moving box size */ 66*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_BOX_SIZE (V4L2_CID_XILINX_TPG + 14) 67*4882a593Smuzhiyun /* Moving box color */ 68*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_BOX_COLOR (V4L2_CID_XILINX_TPG + 15) 69*4882a593Smuzhiyun /* Upper limit count of generated stuck pixels */ 70*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_STUCK_PIXEL_THRESH (V4L2_CID_XILINX_TPG + 16) 71*4882a593Smuzhiyun /* Noise level */ 72*4882a593Smuzhiyun #define V4L2_CID_XILINX_TPG_NOISE_GAIN (V4L2_CID_XILINX_TPG + 17) 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun #endif /* __UAPI_XILINX_V4L2_CONTROLS_H__ */ 75