19d4fa1a1SMauro Carvalho Chehab /* 29d4fa1a1SMauro Carvalho Chehab * Support for Clovertrail PNW Camera Imaging ISP subsystem. 39d4fa1a1SMauro Carvalho Chehab * 49d4fa1a1SMauro Carvalho Chehab * Copyright (c) 2012 Intel Corporation. All Rights Reserved. 59d4fa1a1SMauro Carvalho Chehab * 69d4fa1a1SMauro Carvalho Chehab * This program is free software; you can redistribute it and/or 79d4fa1a1SMauro Carvalho Chehab * modify it under the terms of the GNU General Public License version 89d4fa1a1SMauro Carvalho Chehab * 2 as published by the Free Software Foundation. 99d4fa1a1SMauro Carvalho Chehab * 109d4fa1a1SMauro Carvalho Chehab * This program is distributed in the hope that it will be useful, 119d4fa1a1SMauro Carvalho Chehab * but WITHOUT ANY WARRANTY; without even the implied warranty of 129d4fa1a1SMauro Carvalho Chehab * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 139d4fa1a1SMauro Carvalho Chehab * GNU General Public License for more details. 149d4fa1a1SMauro Carvalho Chehab * 159d4fa1a1SMauro Carvalho Chehab * 169d4fa1a1SMauro Carvalho Chehab */ 179d4fa1a1SMauro Carvalho Chehab 189d4fa1a1SMauro Carvalho Chehab #ifndef __ATOMISP_COMPAT_H__ 199d4fa1a1SMauro Carvalho Chehab #define __ATOMISP_COMPAT_H__ 209d4fa1a1SMauro Carvalho Chehab 219d4fa1a1SMauro Carvalho Chehab #include "atomisp_compat_css20.h" 229d4fa1a1SMauro Carvalho Chehab 239d4fa1a1SMauro Carvalho Chehab #include "../../include/linux/atomisp.h" 249d4fa1a1SMauro Carvalho Chehab #include <media/videobuf-vmalloc.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 379d4fa1a1SMauro Carvalho Chehab void atomisp_css_debug_dump_sp_sw_debug_info(void); 389d4fa1a1SMauro Carvalho Chehab void atomisp_css_debug_dump_debug_info(const char *context); 399d4fa1a1SMauro Carvalho Chehab void atomisp_css_debug_set_dtrace_level(const unsigned int trace_level); 409d4fa1a1SMauro Carvalho Chehab 419d4fa1a1SMauro Carvalho Chehab void atomisp_store_uint32(hrt_address addr, uint32_t data); 429d4fa1a1SMauro Carvalho Chehab void atomisp_load_uint32(hrt_address addr, uint32_t *data); 439d4fa1a1SMauro Carvalho Chehab 449d4fa1a1SMauro Carvalho Chehab int atomisp_css_init(struct atomisp_device *isp); 459d4fa1a1SMauro Carvalho Chehab 469d4fa1a1SMauro Carvalho Chehab void atomisp_css_uninit(struct atomisp_device *isp); 479d4fa1a1SMauro Carvalho Chehab 489d4fa1a1SMauro Carvalho Chehab void atomisp_css_suspend(struct atomisp_device *isp); 499d4fa1a1SMauro Carvalho Chehab 509d4fa1a1SMauro Carvalho Chehab int atomisp_css_resume(struct atomisp_device *isp); 519d4fa1a1SMauro Carvalho Chehab 529d4fa1a1SMauro Carvalho Chehab void atomisp_css_init_struct(struct atomisp_sub_device *asd); 539d4fa1a1SMauro Carvalho Chehab 549d4fa1a1SMauro Carvalho Chehab int atomisp_css_irq_translate(struct atomisp_device *isp, 559d4fa1a1SMauro Carvalho Chehab unsigned int *infos); 569d4fa1a1SMauro Carvalho Chehab 579d4fa1a1SMauro Carvalho Chehab void atomisp_css_rx_get_irq_info(enum mipi_port_id port, 589d4fa1a1SMauro Carvalho Chehab unsigned int *infos); 599d4fa1a1SMauro Carvalho Chehab 609d4fa1a1SMauro Carvalho Chehab void atomisp_css_rx_clear_irq_info(enum mipi_port_id port, 619d4fa1a1SMauro Carvalho Chehab unsigned int infos); 629d4fa1a1SMauro Carvalho Chehab 639d4fa1a1SMauro Carvalho Chehab int atomisp_css_irq_enable(struct atomisp_device *isp, 64c01d5546SMauro Carvalho Chehab enum ia_css_irq_info info, bool enable); 659d4fa1a1SMauro Carvalho Chehab 669d4fa1a1SMauro Carvalho Chehab int atomisp_q_video_buffer_to_css(struct atomisp_sub_device *asd, 679d4fa1a1SMauro Carvalho Chehab struct videobuf_vmalloc_memory *vm_mem, 689d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 69c01d5546SMauro Carvalho Chehab enum ia_css_buffer_type css_buf_type, 70c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id css_pipe_id); 719d4fa1a1SMauro Carvalho Chehab 729d4fa1a1SMauro Carvalho Chehab int atomisp_q_s3a_buffer_to_css(struct atomisp_sub_device *asd, 739d4fa1a1SMauro Carvalho Chehab struct atomisp_s3a_buf *s3a_buf, 749d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 75c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id css_pipe_id); 769d4fa1a1SMauro Carvalho Chehab 779d4fa1a1SMauro Carvalho Chehab int atomisp_q_metadata_buffer_to_css(struct atomisp_sub_device *asd, 789d4fa1a1SMauro Carvalho Chehab struct atomisp_metadata_buf *metadata_buf, 799d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 80c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id css_pipe_id); 819d4fa1a1SMauro Carvalho Chehab 829d4fa1a1SMauro Carvalho Chehab int atomisp_q_dis_buffer_to_css(struct atomisp_sub_device *asd, 839d4fa1a1SMauro Carvalho Chehab struct atomisp_dis_buf *dis_buf, 849d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 85c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id css_pipe_id); 869d4fa1a1SMauro Carvalho Chehab 879d4fa1a1SMauro Carvalho Chehab void atomisp_css_mmu_invalidate_cache(void); 889d4fa1a1SMauro Carvalho Chehab 899d4fa1a1SMauro Carvalho Chehab void atomisp_css_mmu_invalidate_tlb(void); 909d4fa1a1SMauro Carvalho Chehab 919d4fa1a1SMauro Carvalho Chehab int atomisp_css_start(struct atomisp_sub_device *asd, 92c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id pipe_id, bool in_reset); 939d4fa1a1SMauro Carvalho Chehab 949d4fa1a1SMauro Carvalho Chehab void atomisp_css_update_isp_params(struct atomisp_sub_device *asd); 959d4fa1a1SMauro Carvalho Chehab void atomisp_css_update_isp_params_on_pipe(struct atomisp_sub_device *asd, 969d4fa1a1SMauro Carvalho Chehab struct ia_css_pipe *pipe); 979d4fa1a1SMauro Carvalho Chehab 989d4fa1a1SMauro Carvalho Chehab int atomisp_css_queue_buffer(struct atomisp_sub_device *asd, 999d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 100c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id pipe_id, 101c01d5546SMauro Carvalho Chehab enum ia_css_buffer_type buf_type, 1029d4fa1a1SMauro Carvalho Chehab struct atomisp_css_buffer *isp_css_buffer); 1039d4fa1a1SMauro Carvalho Chehab 1049d4fa1a1SMauro Carvalho Chehab int atomisp_css_dequeue_buffer(struct atomisp_sub_device *asd, 1059d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 106c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id pipe_id, 107c01d5546SMauro Carvalho Chehab enum ia_css_buffer_type buf_type, 1089d4fa1a1SMauro Carvalho Chehab struct atomisp_css_buffer *isp_css_buffer); 1099d4fa1a1SMauro Carvalho Chehab 1109d4fa1a1SMauro Carvalho Chehab int atomisp_css_allocate_stat_buffers(struct atomisp_sub_device *asd, 1119d4fa1a1SMauro Carvalho Chehab u16 stream_id, 1129d4fa1a1SMauro Carvalho Chehab struct atomisp_s3a_buf *s3a_buf, 1139d4fa1a1SMauro Carvalho Chehab struct atomisp_dis_buf *dis_buf, 1149d4fa1a1SMauro Carvalho Chehab struct atomisp_metadata_buf *md_buf); 1159d4fa1a1SMauro Carvalho Chehab 1169d4fa1a1SMauro Carvalho Chehab void atomisp_css_free_stat_buffers(struct atomisp_sub_device *asd); 1179d4fa1a1SMauro Carvalho Chehab 1189d4fa1a1SMauro Carvalho Chehab void atomisp_css_free_3a_buffer(struct atomisp_s3a_buf *s3a_buf); 1199d4fa1a1SMauro Carvalho Chehab 1209d4fa1a1SMauro Carvalho Chehab void atomisp_css_free_dis_buffer(struct atomisp_dis_buf *dis_buf); 1219d4fa1a1SMauro Carvalho Chehab 1229d4fa1a1SMauro Carvalho Chehab void atomisp_css_free_metadata_buffer(struct atomisp_metadata_buf 1239d4fa1a1SMauro Carvalho Chehab *metadata_buf); 1249d4fa1a1SMauro Carvalho Chehab 1259d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_grid_info(struct atomisp_sub_device *asd, 126c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id pipe_id, 1279d4fa1a1SMauro Carvalho Chehab int source_pad); 1289d4fa1a1SMauro Carvalho Chehab 1299d4fa1a1SMauro Carvalho Chehab int atomisp_alloc_3a_output_buf(struct atomisp_sub_device *asd); 1309d4fa1a1SMauro Carvalho Chehab 1319d4fa1a1SMauro Carvalho Chehab int atomisp_alloc_dis_coef_buf(struct atomisp_sub_device *asd); 1329d4fa1a1SMauro Carvalho Chehab 1339d4fa1a1SMauro Carvalho Chehab int atomisp_alloc_metadata_output_buf(struct atomisp_sub_device *asd); 1349d4fa1a1SMauro Carvalho Chehab 1359d4fa1a1SMauro Carvalho Chehab void atomisp_free_metadata_output_buf(struct atomisp_sub_device *asd); 1369d4fa1a1SMauro Carvalho Chehab 1379d4fa1a1SMauro Carvalho Chehab void atomisp_css_get_dis_statistics(struct atomisp_sub_device *asd, 1389d4fa1a1SMauro Carvalho Chehab struct atomisp_css_buffer *isp_css_buffer, 1399d4fa1a1SMauro Carvalho Chehab struct ia_css_isp_dvs_statistics_map *dvs_map); 1409d4fa1a1SMauro Carvalho Chehab 1419d4fa1a1SMauro Carvalho Chehab int atomisp_css_dequeue_event(struct atomisp_css_event *current_event); 1429d4fa1a1SMauro Carvalho Chehab 1439d4fa1a1SMauro Carvalho Chehab void atomisp_css_temp_pipe_to_pipe_id(struct atomisp_sub_device *asd, 1449d4fa1a1SMauro Carvalho Chehab struct atomisp_css_event *current_event); 1459d4fa1a1SMauro Carvalho Chehab 1469d4fa1a1SMauro Carvalho Chehab int atomisp_css_isys_set_resolution(struct atomisp_sub_device *asd, 1479d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1489d4fa1a1SMauro Carvalho Chehab struct v4l2_mbus_framefmt *ffmt, 1499d4fa1a1SMauro Carvalho Chehab int isys_stream); 1509d4fa1a1SMauro Carvalho Chehab 1519d4fa1a1SMauro Carvalho Chehab void atomisp_css_isys_set_link(struct atomisp_sub_device *asd, 1529d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1539d4fa1a1SMauro Carvalho Chehab int link, 1549d4fa1a1SMauro Carvalho Chehab int isys_stream); 1559d4fa1a1SMauro Carvalho Chehab 1569d4fa1a1SMauro Carvalho Chehab void atomisp_css_isys_set_valid(struct atomisp_sub_device *asd, 1579d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1589d4fa1a1SMauro Carvalho Chehab bool valid, 1599d4fa1a1SMauro Carvalho Chehab int isys_stream); 1609d4fa1a1SMauro Carvalho Chehab 1619d4fa1a1SMauro Carvalho Chehab void atomisp_css_isys_set_format(struct atomisp_sub_device *asd, 1629d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1639d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format format, 1649d4fa1a1SMauro Carvalho Chehab int isys_stream); 1659d4fa1a1SMauro Carvalho Chehab 1669d4fa1a1SMauro Carvalho Chehab int atomisp_css_set_default_isys_config(struct atomisp_sub_device *asd, 1679d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1689d4fa1a1SMauro Carvalho Chehab struct v4l2_mbus_framefmt *ffmt); 1699d4fa1a1SMauro Carvalho Chehab 1709d4fa1a1SMauro Carvalho Chehab int atomisp_css_isys_two_stream_cfg(struct atomisp_sub_device *asd, 1719d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1729d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format input_format); 1739d4fa1a1SMauro Carvalho Chehab 1749d4fa1a1SMauro Carvalho Chehab void atomisp_css_isys_two_stream_cfg_update_stream1( 1759d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 1769d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1779d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format input_format, 1789d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 1799d4fa1a1SMauro Carvalho Chehab 1809d4fa1a1SMauro Carvalho Chehab void atomisp_css_isys_two_stream_cfg_update_stream2( 1819d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 1829d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1839d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format input_format, 1849d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 1859d4fa1a1SMauro Carvalho Chehab 1869d4fa1a1SMauro Carvalho Chehab int atomisp_css_input_set_resolution(struct atomisp_sub_device *asd, 1879d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1889d4fa1a1SMauro Carvalho Chehab struct v4l2_mbus_framefmt *ffmt); 1899d4fa1a1SMauro Carvalho Chehab 1909d4fa1a1SMauro Carvalho Chehab void atomisp_css_input_set_binning_factor(struct atomisp_sub_device *asd, 1919d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 1929d4fa1a1SMauro Carvalho Chehab unsigned int bin_factor); 1939d4fa1a1SMauro Carvalho Chehab 1949d4fa1a1SMauro Carvalho Chehab void atomisp_css_input_set_bayer_order(struct atomisp_sub_device *asd, 1959d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 196c01d5546SMauro Carvalho Chehab enum ia_css_bayer_order bayer_order); 1979d4fa1a1SMauro Carvalho Chehab 1989d4fa1a1SMauro Carvalho Chehab void atomisp_css_input_set_format(struct atomisp_sub_device *asd, 1999d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 2009d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format format); 2019d4fa1a1SMauro Carvalho Chehab 2029d4fa1a1SMauro Carvalho Chehab int atomisp_css_input_set_effective_resolution( 2039d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 2049d4fa1a1SMauro Carvalho Chehab enum atomisp_input_stream_id stream_id, 2059d4fa1a1SMauro Carvalho Chehab unsigned int width, 2069d4fa1a1SMauro Carvalho Chehab unsigned int height); 2079d4fa1a1SMauro Carvalho Chehab 2089d4fa1a1SMauro Carvalho Chehab void atomisp_css_video_set_dis_envelope(struct atomisp_sub_device *asd, 2099d4fa1a1SMauro Carvalho Chehab unsigned int dvs_w, unsigned int dvs_h); 2109d4fa1a1SMauro Carvalho Chehab 2119d4fa1a1SMauro Carvalho Chehab void atomisp_css_input_set_two_pixels_per_clock( 2129d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 2139d4fa1a1SMauro Carvalho Chehab bool two_ppc); 2149d4fa1a1SMauro Carvalho Chehab 2159d4fa1a1SMauro Carvalho Chehab void atomisp_css_enable_raw_binning(struct atomisp_sub_device *asd, 2169d4fa1a1SMauro Carvalho Chehab bool enable); 2179d4fa1a1SMauro Carvalho Chehab 2189d4fa1a1SMauro Carvalho Chehab void atomisp_css_enable_dz(struct atomisp_sub_device *asd, bool enable); 2199d4fa1a1SMauro Carvalho Chehab 2209d4fa1a1SMauro Carvalho Chehab void atomisp_css_capture_set_mode(struct atomisp_sub_device *asd, 221c01d5546SMauro Carvalho Chehab enum ia_css_capture_mode mode); 2229d4fa1a1SMauro Carvalho Chehab 2239d4fa1a1SMauro Carvalho Chehab void atomisp_css_input_set_mode(struct atomisp_sub_device *asd, 224c01d5546SMauro Carvalho Chehab enum ia_css_input_mode mode); 2259d4fa1a1SMauro Carvalho Chehab 2269d4fa1a1SMauro Carvalho Chehab void atomisp_css_capture_enable_online(struct atomisp_sub_device *asd, 2279d4fa1a1SMauro Carvalho Chehab unsigned short stream_index, bool enable); 2289d4fa1a1SMauro Carvalho Chehab 2299d4fa1a1SMauro Carvalho Chehab void atomisp_css_preview_enable_online(struct atomisp_sub_device *asd, 2309d4fa1a1SMauro Carvalho Chehab unsigned short stream_index, bool enable); 2319d4fa1a1SMauro Carvalho Chehab 2329d4fa1a1SMauro Carvalho Chehab void atomisp_css_video_enable_online(struct atomisp_sub_device *asd, 2339d4fa1a1SMauro Carvalho Chehab bool enable); 2349d4fa1a1SMauro Carvalho Chehab 2359d4fa1a1SMauro Carvalho Chehab void atomisp_css_enable_continuous(struct atomisp_sub_device *asd, 2369d4fa1a1SMauro Carvalho Chehab bool enable); 2379d4fa1a1SMauro Carvalho Chehab 2389d4fa1a1SMauro Carvalho Chehab void atomisp_css_enable_cvf(struct atomisp_sub_device *asd, 2399d4fa1a1SMauro Carvalho Chehab bool enable); 2409d4fa1a1SMauro Carvalho Chehab 2419d4fa1a1SMauro Carvalho Chehab int atomisp_css_input_configure_port(struct atomisp_sub_device *asd, 2429d4fa1a1SMauro Carvalho Chehab enum mipi_port_id port, 2439d4fa1a1SMauro Carvalho Chehab unsigned int num_lanes, 2449d4fa1a1SMauro Carvalho Chehab unsigned int timeout, 2459d4fa1a1SMauro Carvalho Chehab unsigned int mipi_freq, 2469d4fa1a1SMauro Carvalho Chehab enum atomisp_input_format metadata_format, 2479d4fa1a1SMauro Carvalho Chehab unsigned int metadata_width, 2489d4fa1a1SMauro Carvalho Chehab unsigned int metadata_height); 2499d4fa1a1SMauro Carvalho Chehab 250c01d5546SMauro Carvalho Chehab int atomisp_css_frame_allocate(struct ia_css_frame **frame, 2519d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 252c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format, 2539d4fa1a1SMauro Carvalho Chehab unsigned int padded_width, 2549d4fa1a1SMauro Carvalho Chehab unsigned int raw_bit_depth); 2559d4fa1a1SMauro Carvalho Chehab 256c01d5546SMauro Carvalho Chehab int atomisp_css_frame_allocate_from_info(struct ia_css_frame **frame, 257c01d5546SMauro Carvalho Chehab const struct ia_css_frame_info *info); 2589d4fa1a1SMauro Carvalho Chehab 259c01d5546SMauro Carvalho Chehab void atomisp_css_frame_free(struct ia_css_frame *frame); 2609d4fa1a1SMauro Carvalho Chehab 261c01d5546SMauro Carvalho Chehab int atomisp_css_frame_map(struct ia_css_frame **frame, 262c01d5546SMauro Carvalho Chehab const struct ia_css_frame_info *info, 2639d4fa1a1SMauro Carvalho Chehab const void __user *data, uint16_t attribute, 2649d4fa1a1SMauro Carvalho Chehab void *context); 2659d4fa1a1SMauro Carvalho Chehab 2669d4fa1a1SMauro Carvalho Chehab int atomisp_css_set_black_frame(struct atomisp_sub_device *asd, 267c01d5546SMauro Carvalho Chehab const struct ia_css_frame *raw_black_frame); 2689d4fa1a1SMauro Carvalho Chehab 2699d4fa1a1SMauro Carvalho Chehab int atomisp_css_allocate_continuous_frames(bool init_time, 2709d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd); 2719d4fa1a1SMauro Carvalho Chehab 2729d4fa1a1SMauro Carvalho Chehab void atomisp_css_update_continuous_frames(struct atomisp_sub_device *asd); 2739d4fa1a1SMauro Carvalho Chehab 2749d4fa1a1SMauro Carvalho Chehab void atomisp_create_pipes_stream(struct atomisp_sub_device *asd); 2759d4fa1a1SMauro Carvalho Chehab void atomisp_destroy_pipes_stream_force(struct atomisp_sub_device *asd); 2769d4fa1a1SMauro Carvalho Chehab 2779d4fa1a1SMauro Carvalho Chehab int atomisp_css_stop(struct atomisp_sub_device *asd, 278c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id pipe_id, bool in_reset); 2799d4fa1a1SMauro Carvalho Chehab 2809d4fa1a1SMauro Carvalho Chehab int atomisp_css_continuous_set_num_raw_frames( 2819d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 2829d4fa1a1SMauro Carvalho Chehab int num_frames); 2839d4fa1a1SMauro Carvalho Chehab 2849d4fa1a1SMauro Carvalho Chehab void atomisp_css_disable_vf_pp(struct atomisp_sub_device *asd, 2859d4fa1a1SMauro Carvalho Chehab bool disable); 2869d4fa1a1SMauro Carvalho Chehab 2879d4fa1a1SMauro Carvalho Chehab int atomisp_css_copy_configure_output(struct atomisp_sub_device *asd, 2889d4fa1a1SMauro Carvalho Chehab unsigned int stream_index, 2899d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 2909d4fa1a1SMauro Carvalho Chehab unsigned int padded_width, 291c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 2929d4fa1a1SMauro Carvalho Chehab 2939d4fa1a1SMauro Carvalho Chehab int atomisp_css_yuvpp_configure_output(struct atomisp_sub_device *asd, 2949d4fa1a1SMauro Carvalho Chehab unsigned int stream_index, 2959d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 2969d4fa1a1SMauro Carvalho Chehab unsigned int padded_width, 297c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 2989d4fa1a1SMauro Carvalho Chehab 2999d4fa1a1SMauro Carvalho Chehab int atomisp_css_yuvpp_configure_viewfinder( 3009d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 3019d4fa1a1SMauro Carvalho Chehab unsigned int stream_index, 3029d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 3039d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 304c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 3059d4fa1a1SMauro Carvalho Chehab 3069d4fa1a1SMauro Carvalho Chehab int atomisp_css_yuvpp_get_output_frame_info( 3079d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 3089d4fa1a1SMauro Carvalho Chehab unsigned int stream_index, 309c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 3109d4fa1a1SMauro Carvalho Chehab 3119d4fa1a1SMauro Carvalho Chehab int atomisp_css_yuvpp_get_viewfinder_frame_info( 3129d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 3139d4fa1a1SMauro Carvalho Chehab unsigned int stream_index, 314c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 3159d4fa1a1SMauro Carvalho Chehab 3169d4fa1a1SMauro Carvalho Chehab int atomisp_css_preview_configure_output(struct atomisp_sub_device *asd, 3179d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 3189d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 319c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 3209d4fa1a1SMauro Carvalho Chehab 3219d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_configure_output(struct atomisp_sub_device *asd, 3229d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 3239d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 324c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 3259d4fa1a1SMauro Carvalho Chehab 3269d4fa1a1SMauro Carvalho Chehab int atomisp_css_video_configure_output(struct atomisp_sub_device *asd, 3279d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 3289d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 329c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 3309d4fa1a1SMauro Carvalho Chehab 3319d4fa1a1SMauro Carvalho Chehab int atomisp_get_css_frame_info(struct atomisp_sub_device *asd, 3329d4fa1a1SMauro Carvalho Chehab u16 source_pad, 333c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *frame_info); 3349d4fa1a1SMauro Carvalho Chehab 3359d4fa1a1SMauro Carvalho Chehab int atomisp_css_video_configure_viewfinder(struct atomisp_sub_device *asd, 3369d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 3379d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 338c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 3399d4fa1a1SMauro Carvalho Chehab 3409d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_configure_viewfinder( 3419d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 3429d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height, 3439d4fa1a1SMauro Carvalho Chehab unsigned int min_width, 344c01d5546SMauro Carvalho Chehab enum ia_css_frame_format format); 3459d4fa1a1SMauro Carvalho Chehab 3469d4fa1a1SMauro Carvalho Chehab int atomisp_css_video_get_viewfinder_frame_info( 3479d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 348c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 3499d4fa1a1SMauro Carvalho Chehab 3509d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_get_viewfinder_frame_info( 3519d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 352c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 3539d4fa1a1SMauro Carvalho Chehab 3549d4fa1a1SMauro Carvalho Chehab int atomisp_css_copy_get_output_frame_info( 3559d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 3569d4fa1a1SMauro Carvalho Chehab unsigned int stream_index, 357c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 3589d4fa1a1SMauro Carvalho Chehab 3599d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_get_output_raw_frame_info( 3609d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 361c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 3629d4fa1a1SMauro Carvalho Chehab 3639d4fa1a1SMauro Carvalho Chehab int atomisp_css_preview_get_output_frame_info( 3649d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 365c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 3669d4fa1a1SMauro Carvalho Chehab 3679d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_get_output_frame_info( 3689d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 369c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 3709d4fa1a1SMauro Carvalho Chehab 3719d4fa1a1SMauro Carvalho Chehab int atomisp_css_video_get_output_frame_info( 3729d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 373c01d5546SMauro Carvalho Chehab struct ia_css_frame_info *info); 3749d4fa1a1SMauro Carvalho Chehab 3759d4fa1a1SMauro Carvalho Chehab int atomisp_css_preview_configure_pp_input( 3769d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 3779d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 3789d4fa1a1SMauro Carvalho Chehab 3799d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_configure_pp_input( 3809d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 3819d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 3829d4fa1a1SMauro Carvalho Chehab 3839d4fa1a1SMauro Carvalho Chehab int atomisp_css_video_configure_pp_input( 3849d4fa1a1SMauro Carvalho Chehab struct atomisp_sub_device *asd, 3859d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 3869d4fa1a1SMauro Carvalho Chehab 3879d4fa1a1SMauro Carvalho Chehab int atomisp_css_offline_capture_configure(struct atomisp_sub_device *asd, 3889d4fa1a1SMauro Carvalho Chehab int num_captures, unsigned int skip, int offset); 3899d4fa1a1SMauro Carvalho Chehab int atomisp_css_exp_id_capture(struct atomisp_sub_device *asd, int exp_id); 3909d4fa1a1SMauro Carvalho Chehab int atomisp_css_exp_id_unlock(struct atomisp_sub_device *asd, int exp_id); 3919d4fa1a1SMauro Carvalho Chehab 3929d4fa1a1SMauro Carvalho Chehab int atomisp_css_capture_enable_xnr(struct atomisp_sub_device *asd, 3939d4fa1a1SMauro Carvalho Chehab bool enable); 3949d4fa1a1SMauro Carvalho Chehab 3959d4fa1a1SMauro Carvalho Chehab void atomisp_css_send_input_frame(struct atomisp_sub_device *asd, 3969d4fa1a1SMauro Carvalho Chehab unsigned short *data, unsigned int width, 3979d4fa1a1SMauro Carvalho Chehab unsigned int height); 3989d4fa1a1SMauro Carvalho Chehab 3999d4fa1a1SMauro Carvalho Chehab bool atomisp_css_isp_has_started(void); 4009d4fa1a1SMauro Carvalho Chehab 4019d4fa1a1SMauro Carvalho Chehab void atomisp_css_request_flash(struct atomisp_sub_device *asd); 4029d4fa1a1SMauro Carvalho Chehab 4039d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_wb_config(struct atomisp_sub_device *asd, 404c01d5546SMauro Carvalho Chehab struct ia_css_wb_config *wb_config); 4059d4fa1a1SMauro Carvalho Chehab 4069d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_ob_config(struct atomisp_sub_device *asd, 407c01d5546SMauro Carvalho Chehab struct ia_css_ob_config *ob_config); 4089d4fa1a1SMauro Carvalho Chehab 4099d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_dp_config(struct atomisp_sub_device *asd, 410c01d5546SMauro Carvalho Chehab struct ia_css_dp_config *dp_config); 4119d4fa1a1SMauro Carvalho Chehab 4129d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_de_config(struct atomisp_sub_device *asd, 413c01d5546SMauro Carvalho Chehab struct ia_css_de_config *de_config); 4149d4fa1a1SMauro Carvalho Chehab 4159d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_dz_config(struct atomisp_sub_device *asd, 416c01d5546SMauro Carvalho Chehab struct ia_css_dz_config *dz_config); 4179d4fa1a1SMauro Carvalho Chehab 4189d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_default_de_config(struct atomisp_sub_device *asd); 4199d4fa1a1SMauro Carvalho Chehab 4209d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_ce_config(struct atomisp_sub_device *asd, 421c01d5546SMauro Carvalho Chehab struct ia_css_ce_config *ce_config); 4229d4fa1a1SMauro Carvalho Chehab 4239d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_nr_config(struct atomisp_sub_device *asd, 424c01d5546SMauro Carvalho Chehab struct ia_css_nr_config *nr_config); 4259d4fa1a1SMauro Carvalho Chehab 4269d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_ee_config(struct atomisp_sub_device *asd, 427c01d5546SMauro Carvalho Chehab struct ia_css_ee_config *ee_config); 4289d4fa1a1SMauro Carvalho Chehab 4299d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_tnr_config(struct atomisp_sub_device *asd, 430c01d5546SMauro Carvalho Chehab struct ia_css_tnr_config *tnr_config); 4319d4fa1a1SMauro Carvalho Chehab 4329d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_cc_config(struct atomisp_sub_device *asd, 433c01d5546SMauro Carvalho Chehab struct ia_css_cc_config *cc_config); 4349d4fa1a1SMauro Carvalho Chehab 4359d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_macc_table(struct atomisp_sub_device *asd, 436c01d5546SMauro Carvalho Chehab struct ia_css_macc_table *macc_table); 4379d4fa1a1SMauro Carvalho Chehab 4389d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_gamma_table(struct atomisp_sub_device *asd, 439c01d5546SMauro Carvalho Chehab struct ia_css_gamma_table *gamma_table); 4409d4fa1a1SMauro Carvalho Chehab 4419d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_ctc_table(struct atomisp_sub_device *asd, 442c01d5546SMauro Carvalho Chehab struct ia_css_ctc_table *ctc_table); 4439d4fa1a1SMauro Carvalho Chehab 4449d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_gc_config(struct atomisp_sub_device *asd, 445c01d5546SMauro Carvalho Chehab struct ia_css_gc_config *gc_config); 4469d4fa1a1SMauro Carvalho Chehab 4479d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_3a_config(struct atomisp_sub_device *asd, 448c01d5546SMauro Carvalho Chehab struct ia_css_3a_config *s3a_config); 4499d4fa1a1SMauro Carvalho Chehab 4509d4fa1a1SMauro Carvalho Chehab void atomisp_css_video_set_dis_vector(struct atomisp_sub_device *asd, 4519d4fa1a1SMauro Carvalho Chehab struct atomisp_dis_vector *vector); 4529d4fa1a1SMauro Carvalho Chehab 4539d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_dvs2_coefs(struct atomisp_sub_device *asd, 4549d4fa1a1SMauro Carvalho Chehab struct ia_css_dvs2_coefficients *coefs); 4559d4fa1a1SMauro Carvalho Chehab 4569d4fa1a1SMauro Carvalho Chehab int atomisp_css_set_dis_coefs(struct atomisp_sub_device *asd, 4579d4fa1a1SMauro Carvalho Chehab struct atomisp_dis_coefficients *coefs); 4589d4fa1a1SMauro Carvalho Chehab 4599d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_zoom_factor(struct atomisp_sub_device *asd, 4609d4fa1a1SMauro Carvalho Chehab unsigned int zoom); 4619d4fa1a1SMauro Carvalho Chehab 4629d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_wb_config(struct atomisp_sub_device *asd, 4639d4fa1a1SMauro Carvalho Chehab struct atomisp_wb_config *config); 4649d4fa1a1SMauro Carvalho Chehab 4659d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_ob_config(struct atomisp_sub_device *asd, 4669d4fa1a1SMauro Carvalho Chehab struct atomisp_ob_config *config); 4679d4fa1a1SMauro Carvalho Chehab 4689d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_dp_config(struct atomisp_sub_device *asd, 4699d4fa1a1SMauro Carvalho Chehab struct atomisp_dp_config *config); 4709d4fa1a1SMauro Carvalho Chehab 4719d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_de_config(struct atomisp_sub_device *asd, 4729d4fa1a1SMauro Carvalho Chehab struct atomisp_de_config *config); 4739d4fa1a1SMauro Carvalho Chehab 4749d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_nr_config(struct atomisp_sub_device *asd, 4759d4fa1a1SMauro Carvalho Chehab struct atomisp_nr_config *config); 4769d4fa1a1SMauro Carvalho Chehab 4779d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_ee_config(struct atomisp_sub_device *asd, 4789d4fa1a1SMauro Carvalho Chehab struct atomisp_ee_config *config); 4799d4fa1a1SMauro Carvalho Chehab 4809d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_tnr_config(struct atomisp_sub_device *asd, 4819d4fa1a1SMauro Carvalho Chehab struct atomisp_tnr_config *config); 4829d4fa1a1SMauro Carvalho Chehab 4839d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_ctc_table(struct atomisp_sub_device *asd, 4849d4fa1a1SMauro Carvalho Chehab struct atomisp_ctc_table *config); 4859d4fa1a1SMauro Carvalho Chehab 4869d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_gamma_table(struct atomisp_sub_device *asd, 4879d4fa1a1SMauro Carvalho Chehab struct atomisp_gamma_table *config); 4889d4fa1a1SMauro Carvalho Chehab 4899d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_gc_config(struct atomisp_sub_device *asd, 4909d4fa1a1SMauro Carvalho Chehab struct atomisp_gc_config *config); 4919d4fa1a1SMauro Carvalho Chehab 4929d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_3a_config(struct atomisp_sub_device *asd, 4939d4fa1a1SMauro Carvalho Chehab struct atomisp_3a_config *config); 4949d4fa1a1SMauro Carvalho Chehab 4959d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_formats_config(struct atomisp_sub_device *asd, 4969d4fa1a1SMauro Carvalho Chehab struct atomisp_formats_config *formats_config); 4979d4fa1a1SMauro Carvalho Chehab 4989d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_formats_config(struct atomisp_sub_device *asd, 499c01d5546SMauro Carvalho Chehab struct ia_css_formats_config *formats_config); 5009d4fa1a1SMauro Carvalho Chehab 5019d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_zoom_factor(struct atomisp_sub_device *asd, 5029d4fa1a1SMauro Carvalho Chehab unsigned int *zoom); 5039d4fa1a1SMauro Carvalho Chehab 504c01d5546SMauro Carvalho Chehab struct ia_css_shading_table *atomisp_css_shading_table_alloc( 5059d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 5069d4fa1a1SMauro Carvalho Chehab 5079d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_shading_table(struct atomisp_sub_device *asd, 508c01d5546SMauro Carvalho Chehab struct ia_css_shading_table *table); 5099d4fa1a1SMauro Carvalho Chehab 510c01d5546SMauro Carvalho Chehab void atomisp_css_shading_table_free(struct ia_css_shading_table *table); 5119d4fa1a1SMauro Carvalho Chehab 512c01d5546SMauro Carvalho Chehab struct ia_css_morph_table *atomisp_css_morph_table_allocate( 5139d4fa1a1SMauro Carvalho Chehab unsigned int width, unsigned int height); 5149d4fa1a1SMauro Carvalho Chehab 5159d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_morph_table(struct atomisp_sub_device *asd, 516c01d5546SMauro Carvalho Chehab struct ia_css_morph_table *table); 5179d4fa1a1SMauro Carvalho Chehab 5189d4fa1a1SMauro Carvalho Chehab void atomisp_css_get_morph_table(struct atomisp_sub_device *asd, 519c01d5546SMauro Carvalho Chehab struct ia_css_morph_table *table); 5209d4fa1a1SMauro Carvalho Chehab 521c01d5546SMauro Carvalho Chehab void atomisp_css_morph_table_free(struct ia_css_morph_table *table); 5229d4fa1a1SMauro Carvalho Chehab 5239d4fa1a1SMauro Carvalho Chehab void atomisp_css_set_cont_prev_start_time(struct atomisp_device *isp, 5249d4fa1a1SMauro Carvalho Chehab unsigned int overlap); 5259d4fa1a1SMauro Carvalho Chehab 5269d4fa1a1SMauro Carvalho Chehab int atomisp_css_get_dis_stat(struct atomisp_sub_device *asd, 5279d4fa1a1SMauro Carvalho Chehab struct atomisp_dis_statistics *stats); 5289d4fa1a1SMauro Carvalho Chehab 5299d4fa1a1SMauro Carvalho Chehab int atomisp_css_update_stream(struct atomisp_sub_device *asd); 5309d4fa1a1SMauro Carvalho Chehab 5319d4fa1a1SMauro Carvalho Chehab int atomisp_css_create_acc_pipe(struct atomisp_sub_device *asd); 5329d4fa1a1SMauro Carvalho Chehab 5339d4fa1a1SMauro Carvalho Chehab int atomisp_css_start_acc_pipe(struct atomisp_sub_device *asd); 5349d4fa1a1SMauro Carvalho Chehab 5359d4fa1a1SMauro Carvalho Chehab int atomisp_css_stop_acc_pipe(struct atomisp_sub_device *asd); 5369d4fa1a1SMauro Carvalho Chehab 5379d4fa1a1SMauro Carvalho Chehab void atomisp_css_destroy_acc_pipe(struct atomisp_sub_device *asd); 5389d4fa1a1SMauro Carvalho Chehab 5399d4fa1a1SMauro Carvalho Chehab int atomisp_css_load_acc_extension(struct atomisp_sub_device *asd, 540c01d5546SMauro Carvalho Chehab struct ia_css_fw_info *fw, 541c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id pipe_id, 5429d4fa1a1SMauro Carvalho Chehab unsigned int type); 5439d4fa1a1SMauro Carvalho Chehab 5449d4fa1a1SMauro Carvalho Chehab void atomisp_css_unload_acc_extension(struct atomisp_sub_device *asd, 545c01d5546SMauro Carvalho Chehab struct ia_css_fw_info *fw, 546c01d5546SMauro Carvalho Chehab enum ia_css_pipe_id pipe_id); 5479d4fa1a1SMauro Carvalho Chehab 5489d4fa1a1SMauro Carvalho Chehab int atomisp_css_wait_acc_finish(struct atomisp_sub_device *asd); 5499d4fa1a1SMauro Carvalho Chehab 5509d4fa1a1SMauro Carvalho Chehab void atomisp_css_acc_done(struct atomisp_sub_device *asd); 5519d4fa1a1SMauro Carvalho Chehab 5529d4fa1a1SMauro Carvalho Chehab int atomisp_css_load_acc_binary(struct atomisp_sub_device *asd, 553c01d5546SMauro Carvalho Chehab struct ia_css_fw_info *fw, 5549d4fa1a1SMauro Carvalho Chehab unsigned int index); 5559d4fa1a1SMauro Carvalho Chehab 5569d4fa1a1SMauro Carvalho Chehab void atomisp_css_unload_acc_binary(struct atomisp_sub_device *asd); 5579d4fa1a1SMauro Carvalho Chehab 5589d4fa1a1SMauro Carvalho Chehab struct atomisp_acc_fw; 5599d4fa1a1SMauro Carvalho Chehab int atomisp_css_set_acc_parameters(struct atomisp_acc_fw *acc_fw); 5609d4fa1a1SMauro Carvalho Chehab 5619d4fa1a1SMauro Carvalho Chehab int atomisp_css_isr_thread(struct atomisp_device *isp, 5629d4fa1a1SMauro Carvalho Chehab bool *frame_done_found, 5639d4fa1a1SMauro Carvalho Chehab bool *css_pipe_done); 5649d4fa1a1SMauro Carvalho Chehab 5659d4fa1a1SMauro Carvalho Chehab bool atomisp_css_valid_sof(struct atomisp_device *isp); 5669d4fa1a1SMauro Carvalho Chehab 5679d4fa1a1SMauro Carvalho Chehab void atomisp_en_dz_capt_pipe(struct atomisp_sub_device *asd, bool enable); 5689d4fa1a1SMauro Carvalho Chehab 5699d4fa1a1SMauro Carvalho Chehab #endif 570