/* * Support for Intel Camera Imaging ISP subsystem. * Copyright (c) 2015, Intel Corporation. * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU General Public License, * version 2, as published by the Free Software Foundation. * * This program is distributed in the hope it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. */ #ifndef __IA_CSS_BUFFER_H #define __IA_CSS_BUFFER_H /** @file * This file contains datastructures and types for buffers used in CSS */ #include #include "ia_css_types.h" #include "ia_css_timer.h" /** Enumeration of buffer types. Buffers can be queued and de-queued * to hand them over between IA and ISP. */ enum ia_css_buffer_type { IA_CSS_BUFFER_TYPE_INVALID = -1, IA_CSS_BUFFER_TYPE_3A_STATISTICS = 0, IA_CSS_BUFFER_TYPE_DIS_STATISTICS, IA_CSS_BUFFER_TYPE_LACE_STATISTICS, IA_CSS_BUFFER_TYPE_INPUT_FRAME, IA_CSS_BUFFER_TYPE_OUTPUT_FRAME, IA_CSS_BUFFER_TYPE_SEC_OUTPUT_FRAME, IA_CSS_BUFFER_TYPE_VF_OUTPUT_FRAME, IA_CSS_BUFFER_TYPE_SEC_VF_OUTPUT_FRAME, IA_CSS_BUFFER_TYPE_RAW_OUTPUT_FRAME, IA_CSS_BUFFER_TYPE_CUSTOM_INPUT, IA_CSS_BUFFER_TYPE_CUSTOM_OUTPUT, IA_CSS_BUFFER_TYPE_METADATA, IA_CSS_BUFFER_TYPE_PARAMETER_SET, IA_CSS_BUFFER_TYPE_PER_FRAME_PARAMETER_SET, IA_CSS_NUM_DYNAMIC_BUFFER_TYPE, IA_CSS_NUM_BUFFER_TYPE }; /* Driver API is not SP/ISP visible, 64 bit types not supported on hivecc */ #if !defined(__ISP) /** Buffer structure. This is a container structure that enables content * independent buffer queues and access functions. */ struct ia_css_buffer { enum ia_css_buffer_type type; /**< Buffer type. */ unsigned int exp_id; /**< exposure id for this buffer; 0 = not available see ia_css_event_public.h for more detail. */ union { struct ia_css_isp_3a_statistics *stats_3a; /**< 3A statistics & optionally RGBY statistics. */ struct ia_css_isp_dvs_statistics *stats_dvs; /**< DVS statistics. */ struct ia_css_isp_skc_dvs_statistics *stats_skc_dvs; /**< SKC DVS statistics. */ struct ia_css_frame *frame; /**< Frame buffer. */ struct ia_css_acc_param *custom_data; /**< Custom buffer. */ struct ia_css_metadata *metadata; /**< Sensor metadata. */ } data; /**< Buffer data pointer. */ uint64_t driver_cookie; /**< cookie for the driver */ struct ia_css_time_meas timing_data; /**< timing data (readings from the timer) */ struct ia_css_clock_tick isys_eof_clock_tick; /**< ISYS's end of frame timer tick*/ }; /** @brief Dequeue param buffers from sp2host_queue * * @return None * * This function must be called at every driver interrupt handler to prevent * overflow of sp2host_queue. */ void ia_css_dequeue_param_buffers(void); #endif /* !__ISP */ #endif /* __IA_CSS_BUFFER_H */