19d4fa1a1SMauro Carvalho Chehab /* 29d4fa1a1SMauro Carvalho Chehab * Support for Intel Camera Imaging ISP subsystem. 39d4fa1a1SMauro Carvalho Chehab * Copyright (c) 2015, Intel Corporation. 49d4fa1a1SMauro Carvalho Chehab * 59d4fa1a1SMauro Carvalho Chehab * This program is free software; you can redistribute it and/or modify it 69d4fa1a1SMauro Carvalho Chehab * under the terms and conditions of the GNU General Public License, 79d4fa1a1SMauro Carvalho Chehab * version 2, as published by the Free Software Foundation. 89d4fa1a1SMauro Carvalho Chehab * 99d4fa1a1SMauro Carvalho Chehab * This program is distributed in the hope it will be useful, but WITHOUT 109d4fa1a1SMauro Carvalho Chehab * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 119d4fa1a1SMauro Carvalho Chehab * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 129d4fa1a1SMauro Carvalho Chehab * more details. 139d4fa1a1SMauro Carvalho Chehab */ 149d4fa1a1SMauro Carvalho Chehab 159d4fa1a1SMauro Carvalho Chehab #ifndef __IA_CSS_SDIS2_HOST_H 169d4fa1a1SMauro Carvalho Chehab #define __IA_CSS_SDIS2_HOST_H 179d4fa1a1SMauro Carvalho Chehab 189d4fa1a1SMauro Carvalho Chehab #include "ia_css_sdis2_types.h" 199d4fa1a1SMauro Carvalho Chehab #include "ia_css_binary.h" 209d4fa1a1SMauro Carvalho Chehab #include "ia_css_stream.h" 219d4fa1a1SMauro Carvalho Chehab #include "sh_css_params.h" 229d4fa1a1SMauro Carvalho Chehab 239d4fa1a1SMauro Carvalho Chehab extern const struct ia_css_dvs2_coefficients default_sdis2_config; 249d4fa1a1SMauro Carvalho Chehab 259d4fa1a1SMauro Carvalho Chehab /* Opaque here, since size is binary dependent. */ 269d4fa1a1SMauro Carvalho Chehab struct sh_css_isp_sdis_hori_coef_tbl; 279d4fa1a1SMauro Carvalho Chehab struct sh_css_isp_sdis_vert_coef_tbl; 289d4fa1a1SMauro Carvalho Chehab struct sh_css_isp_sdis_hori_proj_tbl; 299d4fa1a1SMauro Carvalho Chehab struct sh_css_isp_sdis_vert_proj_tbl; 309d4fa1a1SMauro Carvalho Chehab 319d4fa1a1SMauro Carvalho Chehab void ia_css_sdis2_horicoef_vmem_encode( 329d4fa1a1SMauro Carvalho Chehab struct sh_css_isp_sdis_hori_coef_tbl *to, 339d4fa1a1SMauro Carvalho Chehab const struct ia_css_dvs2_coefficients *from, 349d4fa1a1SMauro Carvalho Chehab unsigned int size); 359d4fa1a1SMauro Carvalho Chehab 369d4fa1a1SMauro Carvalho Chehab void ia_css_sdis2_vertcoef_vmem_encode( 379d4fa1a1SMauro Carvalho Chehab struct sh_css_isp_sdis_vert_coef_tbl *to, 389d4fa1a1SMauro Carvalho Chehab const struct ia_css_dvs2_coefficients *from, 399d4fa1a1SMauro Carvalho Chehab unsigned int size); 409d4fa1a1SMauro Carvalho Chehab 419d4fa1a1SMauro Carvalho Chehab void ia_css_sdis2_horiproj_encode( 429d4fa1a1SMauro Carvalho Chehab struct sh_css_isp_sdis_hori_proj_tbl *to, 439d4fa1a1SMauro Carvalho Chehab const struct ia_css_dvs2_coefficients *from, 449d4fa1a1SMauro Carvalho Chehab unsigned int size); 459d4fa1a1SMauro Carvalho Chehab 469d4fa1a1SMauro Carvalho Chehab void ia_css_sdis2_vertproj_encode( 479d4fa1a1SMauro Carvalho Chehab struct sh_css_isp_sdis_vert_proj_tbl *to, 489d4fa1a1SMauro Carvalho Chehab const struct ia_css_dvs2_coefficients *from, 499d4fa1a1SMauro Carvalho Chehab unsigned int size); 509d4fa1a1SMauro Carvalho Chehab 519d4fa1a1SMauro Carvalho Chehab void ia_css_get_isp_dvs2_coefficients( 529d4fa1a1SMauro Carvalho Chehab struct ia_css_stream *stream, 539d4fa1a1SMauro Carvalho Chehab short *hor_coefs_odd_real, 549d4fa1a1SMauro Carvalho Chehab short *hor_coefs_odd_imag, 559d4fa1a1SMauro Carvalho Chehab short *hor_coefs_even_real, 569d4fa1a1SMauro Carvalho Chehab short *hor_coefs_even_imag, 579d4fa1a1SMauro Carvalho Chehab short *ver_coefs_odd_real, 589d4fa1a1SMauro Carvalho Chehab short *ver_coefs_odd_imag, 599d4fa1a1SMauro Carvalho Chehab short *ver_coefs_even_real, 609d4fa1a1SMauro Carvalho Chehab short *ver_coefs_even_imag); 619d4fa1a1SMauro Carvalho Chehab 629d4fa1a1SMauro Carvalho Chehab void ia_css_sdis2_clear_coefficients( 639d4fa1a1SMauro Carvalho Chehab struct ia_css_dvs2_coefficients *dvs2_coefs); 649d4fa1a1SMauro Carvalho Chehab 659d4fa1a1SMauro Carvalho Chehab enum ia_css_err 669d4fa1a1SMauro Carvalho Chehab ia_css_get_dvs2_statistics( 679d4fa1a1SMauro Carvalho Chehab struct ia_css_dvs2_statistics *host_stats, 689d4fa1a1SMauro Carvalho Chehab const struct ia_css_isp_dvs_statistics *isp_stats); 699d4fa1a1SMauro Carvalho Chehab 709d4fa1a1SMauro Carvalho Chehab void 719d4fa1a1SMauro Carvalho Chehab ia_css_translate_dvs2_statistics( 729d4fa1a1SMauro Carvalho Chehab struct ia_css_dvs2_statistics *host_stats, 739d4fa1a1SMauro Carvalho Chehab const struct ia_css_isp_dvs_statistics_map *isp_stats); 749d4fa1a1SMauro Carvalho Chehab 759d4fa1a1SMauro Carvalho Chehab struct ia_css_isp_dvs_statistics * 769d4fa1a1SMauro Carvalho Chehab ia_css_isp_dvs2_statistics_allocate( 779d4fa1a1SMauro Carvalho Chehab const struct ia_css_dvs_grid_info *grid); 789d4fa1a1SMauro Carvalho Chehab 799d4fa1a1SMauro Carvalho Chehab void 809d4fa1a1SMauro Carvalho Chehab ia_css_isp_dvs2_statistics_free( 819d4fa1a1SMauro Carvalho Chehab struct ia_css_isp_dvs_statistics *me); 829d4fa1a1SMauro Carvalho Chehab 839d4fa1a1SMauro Carvalho Chehab void ia_css_sdis2_horicoef_debug_dtrace( 849d4fa1a1SMauro Carvalho Chehab const struct ia_css_dvs2_coefficients *config, unsigned int level); 859d4fa1a1SMauro Carvalho Chehab 869d4fa1a1SMauro Carvalho Chehab void ia_css_sdis2_vertcoef_debug_dtrace( 879d4fa1a1SMauro Carvalho Chehab const struct ia_css_dvs2_coefficients *config, unsigned int level); 889d4fa1a1SMauro Carvalho Chehab 899d4fa1a1SMauro Carvalho Chehab void ia_css_sdis2_horiproj_debug_dtrace( 909d4fa1a1SMauro Carvalho Chehab const struct ia_css_dvs2_coefficients *config, unsigned int level); 919d4fa1a1SMauro Carvalho Chehab 929d4fa1a1SMauro Carvalho Chehab void ia_css_sdis2_vertproj_debug_dtrace( 939d4fa1a1SMauro Carvalho Chehab const struct ia_css_dvs2_coefficients *config, unsigned int level); 949d4fa1a1SMauro Carvalho Chehab 959d4fa1a1SMauro Carvalho Chehab #endif /* __IA_CSS_SDIS2_HOST_H */ 96