1f5fbb83fSMauro Carvalho Chehab // SPDX-License-Identifier: GPL-2.0
29d4fa1a1SMauro Carvalho Chehab /*
39d4fa1a1SMauro Carvalho Chehab  * Support for Intel Camera Imaging ISP subsystem.
49d4fa1a1SMauro Carvalho Chehab  * Copyright (c) 2015, Intel Corporation.
59d4fa1a1SMauro Carvalho Chehab  *
69d4fa1a1SMauro Carvalho Chehab  * This program is free software; you can redistribute it and/or modify it
79d4fa1a1SMauro Carvalho Chehab  * under the terms and conditions of the GNU General Public License,
89d4fa1a1SMauro Carvalho Chehab  * version 2, as published by the Free Software Foundation.
99d4fa1a1SMauro Carvalho Chehab  *
109d4fa1a1SMauro Carvalho Chehab  * This program is distributed in the hope it will be useful, but WITHOUT
119d4fa1a1SMauro Carvalho Chehab  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
129d4fa1a1SMauro Carvalho Chehab  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
139d4fa1a1SMauro Carvalho Chehab  * more details.
149d4fa1a1SMauro Carvalho Chehab  */
159d4fa1a1SMauro Carvalho Chehab 
169d4fa1a1SMauro Carvalho Chehab #include "ia_css_types.h"
179d4fa1a1SMauro Carvalho Chehab #include "sh_css_defs.h"
189d4fa1a1SMauro Carvalho Chehab #ifndef IA_CSS_NO_DEBUG
199d4fa1a1SMauro Carvalho Chehab /* FIXME: See BZ 4427 */
209d4fa1a1SMauro Carvalho Chehab #include "ia_css_debug.h"
219d4fa1a1SMauro Carvalho Chehab #endif
229d4fa1a1SMauro Carvalho Chehab 
239d4fa1a1SMauro Carvalho Chehab #include "ia_css_csc.host.h"
249d4fa1a1SMauro Carvalho Chehab 
259d4fa1a1SMauro Carvalho Chehab const struct ia_css_cc_config default_cc_config = {
269d4fa1a1SMauro Carvalho Chehab 	8,
279d4fa1a1SMauro Carvalho Chehab 	{255, 29, 120, 0, -374, -342, 0, -672, 301},
289d4fa1a1SMauro Carvalho Chehab };
299d4fa1a1SMauro Carvalho Chehab 
309d4fa1a1SMauro Carvalho Chehab void
ia_css_encode_cc(struct sh_css_isp_csc_params * to,const struct ia_css_cc_config * from,unsigned int size)319d4fa1a1SMauro Carvalho Chehab ia_css_encode_cc(
329d4fa1a1SMauro Carvalho Chehab     struct sh_css_isp_csc_params *to,
339d4fa1a1SMauro Carvalho Chehab     const struct ia_css_cc_config *from,
349d4fa1a1SMauro Carvalho Chehab     unsigned int size)
359d4fa1a1SMauro Carvalho Chehab {
369d4fa1a1SMauro Carvalho Chehab 	(void)size;
379d4fa1a1SMauro Carvalho Chehab #ifndef IA_CSS_NO_DEBUG
389d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(IA_CSS_DEBUG_TRACE_PRIVATE, "ia_css_encode_cc() enter:\n");
399d4fa1a1SMauro Carvalho Chehab #endif
409d4fa1a1SMauro Carvalho Chehab 
419d4fa1a1SMauro Carvalho Chehab 	to->m_shift    = (int16_t)from->fraction_bits;
429d4fa1a1SMauro Carvalho Chehab 	to->m00 = (int16_t)from->matrix[0];
439d4fa1a1SMauro Carvalho Chehab 	to->m01 = (int16_t)from->matrix[1];
449d4fa1a1SMauro Carvalho Chehab 	to->m02 = (int16_t)from->matrix[2];
459d4fa1a1SMauro Carvalho Chehab 	to->m10 = (int16_t)from->matrix[3];
469d4fa1a1SMauro Carvalho Chehab 	to->m11 = (int16_t)from->matrix[4];
479d4fa1a1SMauro Carvalho Chehab 	to->m12 = (int16_t)from->matrix[5];
489d4fa1a1SMauro Carvalho Chehab 	to->m20 = (int16_t)from->matrix[6];
499d4fa1a1SMauro Carvalho Chehab 	to->m21 = (int16_t)from->matrix[7];
509d4fa1a1SMauro Carvalho Chehab 	to->m22 = (int16_t)from->matrix[8];
519d4fa1a1SMauro Carvalho Chehab 
529d4fa1a1SMauro Carvalho Chehab #ifndef IA_CSS_NO_DEBUG
539d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(IA_CSS_DEBUG_TRACE_PRIVATE, "ia_css_encode_cc() leave:\n");
549d4fa1a1SMauro Carvalho Chehab #endif
559d4fa1a1SMauro Carvalho Chehab }
569d4fa1a1SMauro Carvalho Chehab 
579d4fa1a1SMauro Carvalho Chehab void
ia_css_csc_encode(struct sh_css_isp_csc_params * to,const struct ia_css_cc_config * from,unsigned int size)589d4fa1a1SMauro Carvalho Chehab ia_css_csc_encode(
599d4fa1a1SMauro Carvalho Chehab     struct sh_css_isp_csc_params *to,
609d4fa1a1SMauro Carvalho Chehab     const struct ia_css_cc_config *from,
619d4fa1a1SMauro Carvalho Chehab     unsigned int size)
629d4fa1a1SMauro Carvalho Chehab {
639d4fa1a1SMauro Carvalho Chehab 	ia_css_encode_cc(to, from, size);
649d4fa1a1SMauro Carvalho Chehab }
659d4fa1a1SMauro Carvalho Chehab 
669d4fa1a1SMauro Carvalho Chehab #ifndef IA_CSS_NO_DEBUG
679d4fa1a1SMauro Carvalho Chehab void
ia_css_cc_dump(const struct sh_css_isp_csc_params * csc,unsigned int level,const char * name)689d4fa1a1SMauro Carvalho Chehab ia_css_cc_dump(
699d4fa1a1SMauro Carvalho Chehab     const struct sh_css_isp_csc_params *csc,
709d4fa1a1SMauro Carvalho Chehab     unsigned int level,
719d4fa1a1SMauro Carvalho Chehab     const char *name)
729d4fa1a1SMauro Carvalho Chehab {
739d4fa1a1SMauro Carvalho Chehab 	if (!csc) return;
749d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "%s\n", name);
759d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "\t%-32s = %d\n",
769d4fa1a1SMauro Carvalho Chehab 			    "m_shift",
779d4fa1a1SMauro Carvalho Chehab 			    csc->m_shift);
789d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "\t%-32s = %d\n",
799d4fa1a1SMauro Carvalho Chehab 			    "m00",
809d4fa1a1SMauro Carvalho Chehab 			    csc->m00);
819d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "\t%-32s = %d\n",
829d4fa1a1SMauro Carvalho Chehab 			    "m01",
839d4fa1a1SMauro Carvalho Chehab 			    csc->m01);
849d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "\t%-32s = %d\n",
859d4fa1a1SMauro Carvalho Chehab 			    "m02",
869d4fa1a1SMauro Carvalho Chehab 			    csc->m02);
879d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "\t%-32s = %d\n",
889d4fa1a1SMauro Carvalho Chehab 			    "m10",
899d4fa1a1SMauro Carvalho Chehab 			    csc->m10);
909d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "\t%-32s = %d\n",
919d4fa1a1SMauro Carvalho Chehab 			    "m11",
929d4fa1a1SMauro Carvalho Chehab 			    csc->m11);
939d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "\t%-32s = %d\n",
949d4fa1a1SMauro Carvalho Chehab 			    "m12",
959d4fa1a1SMauro Carvalho Chehab 			    csc->m12);
969d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "\t%-32s = %d\n",
979d4fa1a1SMauro Carvalho Chehab 			    "m20",
989d4fa1a1SMauro Carvalho Chehab 			    csc->m20);
999d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "\t%-32s = %d\n",
1009d4fa1a1SMauro Carvalho Chehab 			    "m21",
1019d4fa1a1SMauro Carvalho Chehab 			    csc->m21);
1029d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level, "\t%-32s = %d\n",
1039d4fa1a1SMauro Carvalho Chehab 			    "m22",
1049d4fa1a1SMauro Carvalho Chehab 			    csc->m22);
1059d4fa1a1SMauro Carvalho Chehab }
1069d4fa1a1SMauro Carvalho Chehab 
1079d4fa1a1SMauro Carvalho Chehab void
ia_css_csc_dump(const struct sh_css_isp_csc_params * csc,unsigned int level)1089d4fa1a1SMauro Carvalho Chehab ia_css_csc_dump(
1099d4fa1a1SMauro Carvalho Chehab     const struct sh_css_isp_csc_params *csc,
1109d4fa1a1SMauro Carvalho Chehab     unsigned int level)
1119d4fa1a1SMauro Carvalho Chehab {
1129d4fa1a1SMauro Carvalho Chehab 	ia_css_cc_dump(csc, level, "Color Space Conversion");
1139d4fa1a1SMauro Carvalho Chehab }
1149d4fa1a1SMauro Carvalho Chehab 
1159d4fa1a1SMauro Carvalho Chehab void
ia_css_cc_config_debug_dtrace(const struct ia_css_cc_config * config,unsigned int level)1169d4fa1a1SMauro Carvalho Chehab ia_css_cc_config_debug_dtrace(
1179d4fa1a1SMauro Carvalho Chehab     const struct ia_css_cc_config *config,
1189d4fa1a1SMauro Carvalho Chehab     unsigned int level)
1199d4fa1a1SMauro Carvalho Chehab {
1209d4fa1a1SMauro Carvalho Chehab 	ia_css_debug_dtrace(level,
1219d4fa1a1SMauro Carvalho Chehab 			    "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",
1229d4fa1a1SMauro Carvalho Chehab 			    config->matrix[0],
1239d4fa1a1SMauro Carvalho Chehab 			    config->matrix[1], config->matrix[2],
1249d4fa1a1SMauro Carvalho Chehab 			    config->matrix[3], config->matrix[4],
1259d4fa1a1SMauro Carvalho Chehab 			    config->matrix[5], config->matrix[6],
1269d4fa1a1SMauro Carvalho Chehab 			    config->matrix[7], config->matrix[8]);
1279d4fa1a1SMauro Carvalho Chehab }
1289d4fa1a1SMauro Carvalho Chehab #endif
129