66 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0-only */
 | |
| /*
 | |
|  * Copyright (c) 2013 Texas Instruments Inc.
 | |
|  *
 | |
|  * David Griego, <dagriego@biglakesoftware.com>
 | |
|  * Dale Farnsworth, <dale@farnsworth.org>
 | |
|  * Archit Taneja, <archit@ti.com>
 | |
|  */
 | |
| #ifndef TI_CSC_H
 | |
| #define TI_CSC_H
 | |
| 
 | |
| /* VPE color space converter regs */
 | |
| #define CSC_CSC00		0x00
 | |
| #define CSC_A0_MASK		0x1fff
 | |
| #define CSC_A0_SHIFT		0
 | |
| #define CSC_B0_MASK		0x1fff
 | |
| #define CSC_B0_SHIFT		16
 | |
| 
 | |
| #define CSC_CSC01		0x04
 | |
| #define CSC_C0_MASK		0x1fff
 | |
| #define CSC_C0_SHIFT		0
 | |
| #define CSC_A1_MASK		0x1fff
 | |
| #define CSC_A1_SHIFT		16
 | |
| 
 | |
| #define CSC_CSC02		0x08
 | |
| #define CSC_B1_MASK		0x1fff
 | |
| #define CSC_B1_SHIFT		0
 | |
| #define CSC_C1_MASK		0x1fff
 | |
| #define CSC_C1_SHIFT		16
 | |
| 
 | |
| #define CSC_CSC03		0x0c
 | |
| #define CSC_A2_MASK		0x1fff
 | |
| #define CSC_A2_SHIFT		0
 | |
| #define CSC_B2_MASK		0x1fff
 | |
| #define CSC_B2_SHIFT		16
 | |
| 
 | |
| #define CSC_CSC04		0x10
 | |
| #define CSC_C2_MASK		0x1fff
 | |
| #define CSC_C2_SHIFT		0
 | |
| #define CSC_D0_MASK		0x0fff
 | |
| #define CSC_D0_SHIFT		16
 | |
| 
 | |
| #define CSC_CSC05		0x14
 | |
| #define CSC_D1_MASK		0x0fff
 | |
| #define CSC_D1_SHIFT		0
 | |
| #define CSC_D2_MASK		0x0fff
 | |
| #define CSC_D2_SHIFT		16
 | |
| 
 | |
| #define CSC_BYPASS		(1 << 28)
 | |
| 
 | |
| struct csc_data {
 | |
| 	void __iomem		*base;
 | |
| 	struct resource		*res;
 | |
| 
 | |
| 	struct platform_device	*pdev;
 | |
| };
 | |
| 
 | |
| void csc_dump_regs(struct csc_data *csc);
 | |
| void csc_set_coeff_bypass(struct csc_data *csc, u32 *csc_reg5);
 | |
| void csc_set_coeff(struct csc_data *csc, u32 *csc_reg0,
 | |
| 		   struct v4l2_format *src_fmt, struct v4l2_format *dst_fmt);
 | |
| 
 | |
| struct csc_data *csc_create(struct platform_device *pdev, const char *res_name);
 | |
| 
 | |
| #endif
 |