// SPDX-License-Identifier: GPL-2.0 /* * Support for Intel Camera Imaging ISP subsystem. * Copyright (c) 2015, Intel Corporation. * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU General Public License, * version 2, as published by the Free Software Foundation. * * This program is distributed in the hope it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. */ #include "ia_css_types.h" #include "sh_css_defs.h" #ifndef IA_CSS_NO_DEBUG /* FIXME: See BZ 4427 */ #include "ia_css_debug.h" #endif #include "ia_css_csc.host.h" const struct ia_css_cc_config default_cc_config = { 8, {255, 29, 120, 0, -374, -342, 0, -672, 301}, }; void ia_css_encode_cc( struct sh_css_isp_csc_params *to, const struct ia_css_cc_config *from, unsigned int size) { (void)size; #ifndef IA_CSS_NO_DEBUG ia_css_debug_dtrace(IA_CSS_DEBUG_TRACE_PRIVATE, "ia_css_encode_cc() enter:\n"); #endif to->m_shift = (int16_t)from->fraction_bits; to->m00 = (int16_t)from->matrix[0]; to->m01 = (int16_t)from->matrix[1]; to->m02 = (int16_t)from->matrix[2]; to->m10 = (int16_t)from->matrix[3]; to->m11 = (int16_t)from->matrix[4]; to->m12 = (int16_t)from->matrix[5]; to->m20 = (int16_t)from->matrix[6]; to->m21 = (int16_t)from->matrix[7]; to->m22 = (int16_t)from->matrix[8]; #ifndef IA_CSS_NO_DEBUG ia_css_debug_dtrace(IA_CSS_DEBUG_TRACE_PRIVATE, "ia_css_encode_cc() leave:\n"); #endif } void ia_css_csc_encode( struct sh_css_isp_csc_params *to, const struct ia_css_cc_config *from, unsigned int size) { ia_css_encode_cc(to, from, size); } #ifndef IA_CSS_NO_DEBUG void ia_css_cc_dump( const struct sh_css_isp_csc_params *csc, unsigned int level, const char *name) { if (!csc) return; ia_css_debug_dtrace(level, "%s\n", name); ia_css_debug_dtrace(level, "\t%-32s = %d\n", "m_shift", csc->m_shift); ia_css_debug_dtrace(level, "\t%-32s = %d\n", "m00", csc->m00); ia_css_debug_dtrace(level, "\t%-32s = %d\n", "m01", csc->m01); ia_css_debug_dtrace(level, "\t%-32s = %d\n", "m02", csc->m02); ia_css_debug_dtrace(level, "\t%-32s = %d\n", "m10", csc->m10); ia_css_debug_dtrace(level, "\t%-32s = %d\n", "m11", csc->m11); ia_css_debug_dtrace(level, "\t%-32s = %d\n", "m12", csc->m12); ia_css_debug_dtrace(level, "\t%-32s = %d\n", "m20", csc->m20); ia_css_debug_dtrace(level, "\t%-32s = %d\n", "m21", csc->m21); ia_css_debug_dtrace(level, "\t%-32s = %d\n", "m22", csc->m22); } void ia_css_csc_dump( const struct sh_css_isp_csc_params *csc, unsigned int level) { ia_css_cc_dump(csc, level, "Color Space Conversion"); } void ia_css_cc_config_debug_dtrace( const struct ia_css_cc_config *config, unsigned int level) { ia_css_debug_dtrace(level, "config.m[0]=%d, config.m[1]=%d, config.m[2]=%d, config.m[3]=%d, config.m[4]=%d, config.m[5]=%d, config.m[6]=%d, config.m[7]=%d, config.m[8]=%d\n", config->matrix[0], config->matrix[1], config->matrix[2], config->matrix[3], config->matrix[4], config->matrix[5], config->matrix[6], config->matrix[7], config->matrix[8]); } #endif