| /* |
| * Copyright (c) 2013 Texas Instruments Inc. |
| * |
| * David Griego, <dagriego@biglakesoftware.com> |
| * Dale Farnsworth, <dale@farnsworth.org> |
| * Archit Taneja, <archit@ti.com> |
| * |
| * This program is free software; you can redistribute it and/or modify it |
| * under the terms of the GNU General Public License version 2 as published by |
| * the Free Software Foundation. |
| */ |
| #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, |
| enum v4l2_colorspace src_colorspace, |
| enum v4l2_colorspace dst_colorspace); |
| struct csc_data *csc_create(struct platform_device *pdev, const char *res_name); |
| |
| #endif |