1 /* 2 * Copyright (c) 2013 Texas Instruments Inc. 3 * 4 * David Griego, <dagriego@biglakesoftware.com> 5 * Dale Farnsworth, <dale@farnsworth.org> 6 * Archit Taneja, <archit@ti.com> 7 * 8 * This program is free software; you can redistribute it and/or modify it 9 * under the terms of the GNU General Public License version 2 as published by 10 * the Free Software Foundation. 11 */ 12 #ifndef TI_CSC_H 13 #define TI_CSC_H 14 15 /* VPE color space converter regs */ 16 #define CSC_CSC00 0x00 17 #define CSC_A0_MASK 0x1fff 18 #define CSC_A0_SHIFT 0 19 #define CSC_B0_MASK 0x1fff 20 #define CSC_B0_SHIFT 16 21 22 #define CSC_CSC01 0x04 23 #define CSC_C0_MASK 0x1fff 24 #define CSC_C0_SHIFT 0 25 #define CSC_A1_MASK 0x1fff 26 #define CSC_A1_SHIFT 16 27 28 #define CSC_CSC02 0x08 29 #define CSC_B1_MASK 0x1fff 30 #define CSC_B1_SHIFT 0 31 #define CSC_C1_MASK 0x1fff 32 #define CSC_C1_SHIFT 16 33 34 #define CSC_CSC03 0x0c 35 #define CSC_A2_MASK 0x1fff 36 #define CSC_A2_SHIFT 0 37 #define CSC_B2_MASK 0x1fff 38 #define CSC_B2_SHIFT 16 39 40 #define CSC_CSC04 0x10 41 #define CSC_C2_MASK 0x1fff 42 #define CSC_C2_SHIFT 0 43 #define CSC_D0_MASK 0x0fff 44 #define CSC_D0_SHIFT 16 45 46 #define CSC_CSC05 0x14 47 #define CSC_D1_MASK 0x0fff 48 #define CSC_D1_SHIFT 0 49 #define CSC_D2_MASK 0x0fff 50 #define CSC_D2_SHIFT 16 51 52 #define CSC_BYPASS (1 << 28) 53 54 struct csc_data { 55 void __iomem *base; 56 struct resource *res; 57 58 struct platform_device *pdev; 59 }; 60 61 void csc_dump_regs(struct csc_data *csc); 62 void csc_set_coeff_bypass(struct csc_data *csc, u32 *csc_reg5); 63 void csc_set_coeff(struct csc_data *csc, u32 *csc_reg0, 64 enum v4l2_colorspace src_colorspace, 65 enum v4l2_colorspace dst_colorspace); 66 struct csc_data *csc_create(struct platform_device *pdev, const char *res_name); 67 68 #endif 69