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