/* 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 
 |