1f5fbb83fSMauro Carvalho Chehab /* SPDX-License-Identifier: GPL-2.0 */ 29d4fa1a1SMauro Carvalho Chehab /* 39d4fa1a1SMauro Carvalho Chehab * Support for Clovertrail PNW Camera Imaging ISP subsystem. 49d4fa1a1SMauro Carvalho Chehab * 59d4fa1a1SMauro Carvalho Chehab * Copyright (c) 2012 Intel Corporation. All Rights Reserved. 69d4fa1a1SMauro Carvalho Chehab * 79d4fa1a1SMauro Carvalho Chehab * This program is free software; you can redistribute it and/or 89d4fa1a1SMauro Carvalho Chehab * modify it under the terms of the GNU General Public License version 99d4fa1a1SMauro Carvalho Chehab * 2 as published by the Free Software Foundation. 109d4fa1a1SMauro Carvalho Chehab * 119d4fa1a1SMauro Carvalho Chehab * This program is distributed in the hope that it will be useful, 129d4fa1a1SMauro Carvalho Chehab * but WITHOUT ANY WARRANTY; without even the implied warranty of 139d4fa1a1SMauro Carvalho Chehab * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 149d4fa1a1SMauro Carvalho Chehab * GNU General Public License for more details. 159d4fa1a1SMauro Carvalho Chehab * 169d4fa1a1SMauro Carvalho Chehab * 179d4fa1a1SMauro Carvalho Chehab */ 189d4fa1a1SMauro Carvalho Chehab 199d4fa1a1SMauro Carvalho Chehab #ifndef __ATOMISP_COMPAT_H__ 209d4fa1a1SMauro Carvalho Chehab #define __ATOMISP_COMPAT_H__ 219d4fa1a1SMauro Carvalho Chehab 229d4fa1a1SMauro Carvalho Chehab #include "atomisp_compat_css20.h" 239d4fa1a1SMauro Carvalho Chehab 249d4fa1a1SMauro Carvalho Chehab #include "../../include/linux/atomisp.h" 259d4fa1a1SMauro Carvalho Chehab 269d4fa1a1SMauro Carvalho Chehab struct atomisp_device; 279d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device; 289d4fa1a1SMauro Carvalho Chehab struct video_device; 299d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id; 309d4fa1a1SMauro Carvalho Chehab 319d4fa1a1SMauro Carvalho Chehab struct atomisp_metadata_buf { 329d4fa1a1SMauro Carvalho Chehab struct ia_css_metadata *metadata; 339d4fa1a1SMauro Carvalho Chehab void *md_vptr; 349d4fa1a1SMauro Carvalho Chehab struct list_head list; 359d4fa1a1SMauro Carvalho Chehab }; 369d4fa1a1SMauro Carvalho Chehab 371a16d545SMauro Carvalho Chehab void atomisp_css2_hw_store_32(hrt_address addr, uint32_t data); 389d4fa1a1SMauro Carvalho Chehab void atomisp_load_uint32(hrt_address addr, uint32_t *data); 399d4fa1a1SMauro Carvalho Chehab 409d4fa1a1SMauro Carvalho Chehab int atomisp_css_init(struct atomisp_device *isp); 419d4fa1a1SMauro Carvalho Chehab 429d4fa1a1SMauro Carvalho Chehab void atomisp_css_uninit(struct atomisp_device *isp); 439d4fa1a1SMauro Carvalho Chehab 449d4fa1a1SMauro Carvalho Chehab void atomisp_css_init_struct(struct atomisp_sub_device *asd); 459d4fa1a1SMauro Carvalho Chehab 469d4fa1a1SMauro Carvalho Chehab int atomisp_css_irq_translate(struct atomisp_device *isp, 479d4fa1a1SMauro Carvalho Chehab unsigned int *infos); 489d4fa1a1SMauro Carvalho Chehab 499d4fa1a1SMauro Carvalho Chehab void atomisp_css_rx_get_irq_info(enum mipi_port_id port, 509d4fa1a1SMauro Carvalho Chehab unsigned int *infos); 519d4fa1a1SMauro Carvalho Chehab 529d4fa1a1SMauro Carvalho Chehab void atomisp_css_rx_clear_irq_info(enum mipi_port_id port, 539d4fa1a1SMauro Carvalho Chehab unsigned int infos); 549d4fa1a1SMauro Carvalho Chehab 559d4fa1a1SMauro Carvalho Chehab int atomisp_css_irq_enable(struct atomisp_device *isp, 56c01d5546SMauro Carvalho Chehab enum ia_css_irq_info info, bool enable); 579d4fa1a1SMauro Carvalho Chehab 589d4fa1a1SMauro Carvalho Chehab int atomisp_q_video_buffer_to_css(struct atomisp_sub_device *asd, 59cb48ae89SHans de Goede struct ia_css_frame *frame, 609d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 61c01d5546SMauro Carvalho Chehab enum ia_css_buffer_type css_buf_type, 62c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id css_pipe_id); 639d4fa1a1SMauro Carvalho Chehab 649d4fa1a1SMauro Carvalho Chehab int atomisp_q_s3a_buffer_to_css(struct atomisp_sub_device *asd, 659d4fa1a1SMauro Carvalho Chehab struct atomisp_s3a_buf *s3a_buf, 669d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 67c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id css_pipe_id); 689d4fa1a1SMauro Carvalho Chehab 699d4fa1a1SMauro Carvalho Chehab int atomisp_q_metadata_buffer_to_css(struct atomisp_sub_device *asd, 709d4fa1a1SMauro Carvalho Chehab struct atomisp_metadata_buf *metadata_buf, 719d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 72c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id css_pipe_id); 739d4fa1a1SMauro Carvalho Chehab 749d4fa1a1SMauro Carvalho Chehab int atomisp_q_dis_buffer_to_css(struct atomisp_sub_device *asd, 759d4fa1a1SMauro Carvalho Chehab struct atomisp_dis_buf *dis_buf, 769d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 77c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id css_pipe_id); 789d4fa1a1SMauro Carvalho Chehab 791a16d545SMauro Carvalho Chehab void ia_css_mmu_invalidate_cache(void); 809d4fa1a1SMauro Carvalho Chehab 81*ae39964dSHans de Goede int atomisp_css_start(struct atomisp_sub_device *asd); 829d4fa1a1SMauro Carvalho Chehab 839d4fa1a1SMauro Carvalho Chehab void atomisp_css_update_isp_params(struct atomisp_sub_device *asd); 849d4fa1a1SMauro Carvalho Chehab void atomisp_css_update_isp_params_on_pipe(struct atomisp_sub_device *asd, 859d4fa1a1SMauro Carvalho Chehab struct ia_css_pipe *pipe); 869d4fa1a1SMauro Carvalho Chehab 879d4fa1a1SMauro Carvalho Chehab int atomisp_css_queue_buffer(struct atomisp_sub_device *asd, 889d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 89c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id pipe_id, 90c01d5546SMauro Carvalho Chehab enum ia_css_buffer_type buf_type, 919d4fa1a1SMauro Carvalho Chehab struct atomisp_css_buffer *isp_css_buffer); 929d4fa1a1SMauro Carvalho Chehab 939d4fa1a1SMauro Carvalho Chehab int atomisp_css_dequeue_buffer(struct atomisp_sub_device *asd, 949d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 95c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id pipe_id, 96c01d5546SMauro Carvalho Chehab enum ia_css_buffer_type buf_type, 979d4fa1a1SMauro Carvalho Chehab struct atomisp_css_buffer *isp_css_buffer); 989d4fa1a1SMauro Carvalho Chehab 999d4fa1a1SMauro Carvalho Chehab int atomisp_css_allocate_stat_buffers(struct atomisp_sub_device *asd, 1009d4fa1a1SMauro Carvalho Chehab u16 stream_id, 1019d4fa1a1SMauro Carvalho Chehab struct atomisp_s3a_buf *s3a_buf, 1029d4fa1a1SMauro Carvalho Chehab struct atomisp_dis_buf *dis_buf, 1039d4fa1a1SMauro Carvalho Chehab struct atomisp_metadata_buf *md_buf); 1049d4fa1a1SMauro Carvalho Chehab 1059d4fa1a1SMauro Carvalho Chehab void atomisp_css_free_stat_buffers(struct atomisp_sub_device *asd); 1069d4fa1a1SMauro Carvalho Chehab 1079d4fa1a1SMauro Carvalho Chehab void atomisp_css_free_3a_buffer(struct atomisp_s3a_buf *s3a_buf); 1089d4fa1a1SMauro Carvalho Chehab 1099d4fa1a1SMauro Carvalho Chehab void atomisp_css_free_dis_buffer(struct atomisp_dis_buf *dis_buf); 1109d4fa1a1SMauro Carvalho Chehab 1119d4fa1a1SMauro Carvalho Chehab void atomisp_css_free_metadata_buffer(struct atomisp_metadata_buf 1129d4fa1a1SMauro Carvalho Chehab *metadata_buf); 1139d4fa1a1SMauro Carvalho Chehab 1149d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_grid_info(struct atomisp_sub_device *asd, 115e4454e06SHans de Goede enum ia_css_pipe_id pipe_id); 1169d4fa1a1SMauro Carvalho Chehab 1179d4fa1a1SMauro Carvalho Chehab int atomisp_alloc_3a_output_buf(struct atomisp_sub_device *asd); 1189d4fa1a1SMauro Carvalho Chehab 1199d4fa1a1SMauro Carvalho Chehab int atomisp_alloc_dis_coef_buf(struct atomisp_sub_device *asd); 1209d4fa1a1SMauro Carvalho Chehab 1219d4fa1a1SMauro Carvalho Chehab int atomisp_alloc_metadata_output_buf(struct atomisp_sub_device *asd); 1229d4fa1a1SMauro Carvalho Chehab 1239d4fa1a1SMauro Carvalho Chehab void atomisp_free_metadata_output_buf(struct atomisp_sub_device *asd); 1249d4fa1a1SMauro Carvalho Chehab 1259d4fa1a1SMauro Carvalho Chehab void atomisp_css_temp_pipe_to_pipe_id(struct atomisp_sub_device *asd, 1269d4fa1a1SMauro Carvalho Chehab struct atomisp_css_event *current_event); 1279d4fa1a1SMauro Carvalho Chehab 1289d4fa1a1SMauro Carvalho Chehab int atomisp_css_isys_set_resolution(struct atomisp_sub_device *asd, 1299d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1309d4fa1a1SMauro Carvalho Chehab struct v4l2_mbus_framefmt *ffmt, 1319d4fa1a1SMauro Carvalho Chehab int isys_stream); 1329d4fa1a1SMauro Carvalho Chehab 1339d4fa1a1SMauro Carvalho Chehab void atomisp_css_isys_set_link(struct atomisp_sub_device *asd, 1349d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1359d4fa1a1SMauro Carvalho Chehab int link, 1369d4fa1a1SMauro Carvalho Chehab int isys_stream); 1379d4fa1a1SMauro Carvalho Chehab 1389d4fa1a1SMauro Carvalho Chehab void atomisp_css_isys_set_valid(struct atomisp_sub_device *asd, 1399d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1409d4fa1a1SMauro Carvalho Chehab bool valid, 1419d4fa1a1SMauro Carvalho Chehab int isys_stream); 1429d4fa1a1SMauro Carvalho Chehab 1439d4fa1a1SMauro Carvalho Chehab void atomisp_css_isys_set_format(struct atomisp_sub_device *asd, 1449d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1459d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format format, 1469d4fa1a1SMauro Carvalho Chehab int isys_stream); 1479d4fa1a1SMauro Carvalho Chehab 1489d4fa1a1SMauro Carvalho Chehab int atomisp_css_set_default_isys_config(struct atomisp_sub_device *asd, 1499d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1509d4fa1a1SMauro Carvalho Chehab struct v4l2_mbus_framefmt *ffmt); 1519d4fa1a1SMauro Carvalho Chehab 1529d4fa1a1SMauro Carvalho Chehab void atomisp_css_isys_two_stream_cfg_update_stream1( 1539d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 1549d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1559d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format input_format, 1569d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 1579d4fa1a1SMauro Carvalho Chehab 1589d4fa1a1SMauro Carvalho Chehab void atomisp_css_isys_two_stream_cfg_update_stream2( 1599d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 1609d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1619d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format input_format, 1629d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 1639d4fa1a1SMauro Carvalho Chehab 1649d4fa1a1SMauro Carvalho Chehab int atomisp_css_input_set_resolution(struct atomisp_sub_device *asd, 1659d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1669d4fa1a1SMauro Carvalho Chehab struct v4l2_mbus_framefmt *ffmt); 1679d4fa1a1SMauro Carvalho Chehab 1689d4fa1a1SMauro Carvalho Chehab void atomisp_css_input_set_binning_factor(struct atomisp_sub_device *asd, 1699d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1709d4fa1a1SMauro Carvalho Chehab unsigned int bin_factor); 1719d4fa1a1SMauro Carvalho Chehab 1729d4fa1a1SMauro Carvalho Chehab void atomisp_css_input_set_bayer_order(struct atomisp_sub_device *asd, 1739d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 174c01d5546SMauro Carvalho Chehab enum ia_css_bayer_order bayer_order); 1759d4fa1a1SMauro Carvalho Chehab 1769d4fa1a1SMauro Carvalho Chehab void atomisp_css_input_set_format(struct atomisp_sub_device *asd, 1779d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1789d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format format); 1799d4fa1a1SMauro Carvalho Chehab 1809d4fa1a1SMauro Carvalho Chehab int atomisp_css_input_set_effective_resolution( 1819d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 1829d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1839d4fa1a1SMauro Carvalho Chehab unsigned int width, 1849d4fa1a1SMauro Carvalho Chehab unsigned int height); 1859d4fa1a1SMauro Carvalho Chehab 1869d4fa1a1SMauro Carvalho Chehab void atomisp_css_video_set_dis_envelope(struct atomisp_sub_device *asd, 1879d4fa1a1SMauro Carvalho Chehab unsigned int dvs_w, unsigned int dvs_h); 1889d4fa1a1SMauro Carvalho Chehab 1899d4fa1a1SMauro Carvalho Chehab void atomisp_css_input_set_two_pixels_per_clock( 1909d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 1919d4fa1a1SMauro Carvalho Chehab bool two_ppc); 1929d4fa1a1SMauro Carvalho Chehab 1939d4fa1a1SMauro Carvalho Chehab void atomisp_css_enable_dz(struct atomisp_sub_device *asd, bool enable); 1949d4fa1a1SMauro Carvalho Chehab 1959d4fa1a1SMauro Carvalho Chehab void atomisp_css_capture_set_mode(struct atomisp_sub_device *asd, 196c01d5546SMauro Carvalho Chehab enum ia_css_capture_mode mode); 1979d4fa1a1SMauro Carvalho Chehab 1989d4fa1a1SMauro Carvalho Chehab void atomisp_css_input_set_mode(struct atomisp_sub_device *asd, 199c01d5546SMauro Carvalho Chehab enum ia_css_input_mode mode); 2009d4fa1a1SMauro Carvalho Chehab 2019d4fa1a1SMauro Carvalho Chehab void atomisp_css_capture_enable_online(struct atomisp_sub_device *asd, 2029d4fa1a1SMauro Carvalho Chehab unsigned short stream_index, bool enable); 2039d4fa1a1SMauro Carvalho Chehab 2049d4fa1a1SMauro Carvalho Chehab void atomisp_css_preview_enable_online(struct atomisp_sub_device *asd, 2059d4fa1a1SMauro Carvalho Chehab unsigned short stream_index, bool enable); 2069d4fa1a1SMauro Carvalho Chehab 2079d4fa1a1SMauro Carvalho Chehab int atomisp_css_input_configure_port(struct atomisp_sub_device *asd, 2089d4fa1a1SMauro Carvalho Chehab enum mipi_port_id port, 2099d4fa1a1SMauro Carvalho Chehab unsigned int num_lanes, 2109d4fa1a1SMauro Carvalho Chehab unsigned int timeout, 2119d4fa1a1SMauro Carvalho Chehab unsigned int mipi_freq, 2129d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format metadata_format, 2139d4fa1a1SMauro Carvalho Chehab unsigned int metadata_width, 2149d4fa1a1SMauro Carvalho Chehab unsigned int metadata_height); 2159d4fa1a1SMauro Carvalho Chehab 216798d2ad7SHans de Goede int atomisp_create_pipes_stream(struct atomisp_sub_device *asd); 2172cb61011SHans de Goede void atomisp_destroy_pipes_stream(struct atomisp_sub_device *asd); 2189d4fa1a1SMauro Carvalho Chehab 219e5fab487SHans de Goede void atomisp_css_stop(struct atomisp_sub_device *asd, bool in_reset); 2209d4fa1a1SMauro Carvalho Chehab 2215d986a0eSKaixu Xia void atomisp_css_continuous_set_num_raw_frames( 2229d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 2239d4fa1a1SMauro Carvalho Chehab int num_frames); 2249d4fa1a1SMauro Carvalho Chehab 2259d4fa1a1SMauro Carvalho Chehab int atomisp_css_copy_configure_output(struct atomisp_sub_device *asd, 2269d4fa1a1SMauro Carvalho Chehab unsigned int stream_index, 2279d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 2289d4fa1a1SMauro Carvalho Chehab unsigned int padded_width, 229c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 2309d4fa1a1SMauro Carvalho Chehab 2319d4fa1a1SMauro Carvalho Chehab int atomisp_css_preview_configure_output(struct atomisp_sub_device *asd, 2329d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 2339d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 234c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 2359d4fa1a1SMauro Carvalho Chehab 2369d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_configure_output(struct atomisp_sub_device *asd, 2379d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 2389d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 239c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 2409d4fa1a1SMauro Carvalho Chehab 2419d4fa1a1SMauro Carvalho Chehab int atomisp_css_video_configure_output(struct atomisp_sub_device *asd, 2429d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 2439d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 244c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 2459d4fa1a1SMauro Carvalho Chehab 2469d4fa1a1SMauro Carvalho Chehab int atomisp_get_css_frame_info(struct atomisp_sub_device *asd, 247c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *frame_info); 2489d4fa1a1SMauro Carvalho Chehab 2499d4fa1a1SMauro Carvalho Chehab int atomisp_css_video_configure_viewfinder(struct atomisp_sub_device *asd, 2509d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 2519d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 252c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 2539d4fa1a1SMauro Carvalho Chehab 2549d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_configure_viewfinder( 2559d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 2569d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 2579d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 258c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 2599d4fa1a1SMauro Carvalho Chehab 2609d4fa1a1SMauro Carvalho Chehab int atomisp_css_video_get_viewfinder_frame_info( 2619d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 262c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 2639d4fa1a1SMauro Carvalho Chehab 2649d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_get_viewfinder_frame_info( 2659d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 266c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 2679d4fa1a1SMauro Carvalho Chehab 2689d4fa1a1SMauro Carvalho Chehab int atomisp_css_copy_get_output_frame_info( 2699d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 2709d4fa1a1SMauro Carvalho Chehab unsigned int stream_index, 271c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 2729d4fa1a1SMauro Carvalho Chehab 2739d4fa1a1SMauro Carvalho Chehab int atomisp_css_preview_get_output_frame_info( 2749d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 275c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 2769d4fa1a1SMauro Carvalho Chehab 2779d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_get_output_frame_info( 2789d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 279c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 2809d4fa1a1SMauro Carvalho Chehab 2819d4fa1a1SMauro Carvalho Chehab int atomisp_css_video_get_output_frame_info( 2829d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 283c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 2849d4fa1a1SMauro Carvalho Chehab 2859d4fa1a1SMauro Carvalho Chehab int atomisp_css_preview_configure_pp_input( 2869d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 2879d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 2889d4fa1a1SMauro Carvalho Chehab 2899d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_configure_pp_input( 2909d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 2919d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 2929d4fa1a1SMauro Carvalho Chehab 2939d4fa1a1SMauro Carvalho Chehab int atomisp_css_video_configure_pp_input( 2949d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 2959d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 2969d4fa1a1SMauro Carvalho Chehab 2979d4fa1a1SMauro Carvalho Chehab int atomisp_css_offline_capture_configure(struct atomisp_sub_device *asd, 2989d4fa1a1SMauro Carvalho Chehab int num_captures, unsigned int skip, int offset); 2999d4fa1a1SMauro Carvalho Chehab int atomisp_css_exp_id_capture(struct atomisp_sub_device *asd, int exp_id); 3009d4fa1a1SMauro Carvalho Chehab int atomisp_css_exp_id_unlock(struct atomisp_sub_device *asd, int exp_id); 3019d4fa1a1SMauro Carvalho Chehab 3029d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_enable_xnr(struct atomisp_sub_device *asd, 3039d4fa1a1SMauro Carvalho Chehab bool enable); 3049d4fa1a1SMauro Carvalho Chehab 3059d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_ctc_table(struct atomisp_sub_device *asd, 306c01d5546SMauro Carvalho Chehab struct ia_css_ctc_table *ctc_table); 3079d4fa1a1SMauro Carvalho Chehab 3089d4fa1a1SMauro Carvalho Chehab void atomisp_css_video_set_dis_vector(struct atomisp_sub_device *asd, 3099d4fa1a1SMauro Carvalho Chehab struct atomisp_dis_vector *vector); 3109d4fa1a1SMauro Carvalho Chehab 3119d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_dvs2_coefs(struct atomisp_sub_device *asd, 3129d4fa1a1SMauro Carvalho Chehab struct ia_css_dvs2_coefficients *coefs); 3139d4fa1a1SMauro Carvalho Chehab 3149d4fa1a1SMauro Carvalho Chehab int atomisp_css_set_dis_coefs(struct atomisp_sub_device *asd, 3159d4fa1a1SMauro Carvalho Chehab struct atomisp_dis_coefficients *coefs); 3169d4fa1a1SMauro Carvalho Chehab 3179d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_zoom_factor(struct atomisp_sub_device *asd, 3189d4fa1a1SMauro Carvalho Chehab unsigned int zoom); 3199d4fa1a1SMauro Carvalho Chehab 3209d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_wb_config(struct atomisp_sub_device *asd, 3219d4fa1a1SMauro Carvalho Chehab struct atomisp_wb_config *config); 3229d4fa1a1SMauro Carvalho Chehab 3239d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_ob_config(struct atomisp_sub_device *asd, 3249d4fa1a1SMauro Carvalho Chehab struct atomisp_ob_config *config); 3259d4fa1a1SMauro Carvalho Chehab 3269d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_dp_config(struct atomisp_sub_device *asd, 3279d4fa1a1SMauro Carvalho Chehab struct atomisp_dp_config *config); 3289d4fa1a1SMauro Carvalho Chehab 3299d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_de_config(struct atomisp_sub_device *asd, 3309d4fa1a1SMauro Carvalho Chehab struct atomisp_de_config *config); 3319d4fa1a1SMauro Carvalho Chehab 3329d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_nr_config(struct atomisp_sub_device *asd, 3339d4fa1a1SMauro Carvalho Chehab struct atomisp_nr_config *config); 3349d4fa1a1SMauro Carvalho Chehab 3359d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_ee_config(struct atomisp_sub_device *asd, 3369d4fa1a1SMauro Carvalho Chehab struct atomisp_ee_config *config); 3379d4fa1a1SMauro Carvalho Chehab 3389d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_tnr_config(struct atomisp_sub_device *asd, 3399d4fa1a1SMauro Carvalho Chehab struct atomisp_tnr_config *config); 3409d4fa1a1SMauro Carvalho Chehab 3419d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_ctc_table(struct atomisp_sub_device *asd, 3429d4fa1a1SMauro Carvalho Chehab struct atomisp_ctc_table *config); 3439d4fa1a1SMauro Carvalho Chehab 3449d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_gamma_table(struct atomisp_sub_device *asd, 3459d4fa1a1SMauro Carvalho Chehab struct atomisp_gamma_table *config); 3469d4fa1a1SMauro Carvalho Chehab 3479d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_gc_config(struct atomisp_sub_device *asd, 3489d4fa1a1SMauro Carvalho Chehab struct atomisp_gc_config *config); 3499d4fa1a1SMauro Carvalho Chehab 3509d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_3a_config(struct atomisp_sub_device *asd, 3519d4fa1a1SMauro Carvalho Chehab struct atomisp_3a_config *config); 3529d4fa1a1SMauro Carvalho Chehab 3539d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_formats_config(struct atomisp_sub_device *asd, 3549d4fa1a1SMauro Carvalho Chehab struct atomisp_formats_config *formats_config); 3559d4fa1a1SMauro Carvalho Chehab 3569d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_formats_config(struct atomisp_sub_device *asd, 357c01d5546SMauro Carvalho Chehab struct ia_css_formats_config *formats_config); 3589d4fa1a1SMauro Carvalho Chehab 3599d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_zoom_factor(struct atomisp_sub_device *asd, 3609d4fa1a1SMauro Carvalho Chehab unsigned int *zoom); 3619d4fa1a1SMauro Carvalho Chehab 362c01d5546SMauro Carvalho Chehab struct ia_css_shading_table *atomisp_css_shading_table_alloc( 3639d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 3649d4fa1a1SMauro Carvalho Chehab 3659d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_shading_table(struct atomisp_sub_device *asd, 366c01d5546SMauro Carvalho Chehab struct ia_css_shading_table *table); 3679d4fa1a1SMauro Carvalho Chehab 368c01d5546SMauro Carvalho Chehab void atomisp_css_shading_table_free(struct ia_css_shading_table *table); 3699d4fa1a1SMauro Carvalho Chehab 370c01d5546SMauro Carvalho Chehab struct ia_css_morph_table *atomisp_css_morph_table_allocate( 3719d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 3729d4fa1a1SMauro Carvalho Chehab 3739d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_morph_table(struct atomisp_sub_device *asd, 374c01d5546SMauro Carvalho Chehab struct ia_css_morph_table *table); 3759d4fa1a1SMauro Carvalho Chehab 3769d4fa1a1SMauro Carvalho Chehab void atomisp_css_get_morph_table(struct atomisp_sub_device *asd, 377c01d5546SMauro Carvalho Chehab struct ia_css_morph_table *table); 3789d4fa1a1SMauro Carvalho Chehab 379c01d5546SMauro Carvalho Chehab void atomisp_css_morph_table_free(struct ia_css_morph_table *table); 3809d4fa1a1SMauro Carvalho Chehab 3819d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_dis_stat(struct atomisp_sub_device *asd, 3829d4fa1a1SMauro Carvalho Chehab struct atomisp_dis_statistics *stats); 3839d4fa1a1SMauro Carvalho Chehab 3849d4fa1a1SMauro Carvalho Chehab int atomisp_css_update_stream(struct atomisp_sub_device *asd); 3859d4fa1a1SMauro Carvalho Chehab 386401e0e41SHans de Goede int atomisp_css_isr_thread(struct atomisp_device *isp); 3879d4fa1a1SMauro Carvalho Chehab 3889d4fa1a1SMauro Carvalho Chehab bool atomisp_css_valid_sof(struct atomisp_device *isp); 3899d4fa1a1SMauro Carvalho Chehab 3909d4fa1a1SMauro Carvalho Chehab void atomisp_en_dz_capt_pipe(struct atomisp_sub_device *asd, bool enable); 3919d4fa1a1SMauro Carvalho Chehab 3929d4fa1a1SMauro Carvalho Chehab #endif 393