1 /* SPDX-License-Identifier: GPL-2.0 */ 2 /* 3 * Support for Intel Camera Imaging ISP subsystem. 4 * Copyright (c) 2010 - 2015, Intel Corporation. 5 * 6 * This program is free software; you can redistribute it and/or modify it 7 * under the terms and conditions of the GNU General Public License, 8 * version 2, as published by the Free Software Foundation. 9 * 10 * This program is distributed in the hope it will be useful, but WITHOUT 11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 12 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 13 * more details. 14 */ 15 16 #ifndef __IA_CSS_FRAME_H__ 17 #define __IA_CSS_FRAME_H__ 18 19 /* ISP2401 */ 20 #include <ia_css_types.h> 21 22 #include <ia_css_frame_format.h> 23 #include <ia_css_frame_public.h> 24 #include "dma.h" 25 26 /********************************************************************* 27 **** Frame INFO APIs 28 **********************************************************************/ 29 /* @brief Sets the given width and alignment to the frame info 30 * 31 * @param 32 * @param[in] info The info to which parameters would set 33 * @param[in] width The width to be set to info 34 * @param[in] aligned The aligned to be set to info 35 * @return 36 */ 37 void ia_css_frame_info_set_width(struct ia_css_frame_info *info, 38 unsigned int width, 39 unsigned int min_padded_width); 40 41 /* @brief Sets the given format to the frame info 42 * 43 * @param 44 * @param[in] info The info to which parameters would set 45 * @param[in] format The format to be set to info 46 * @return 47 */ 48 void ia_css_frame_info_set_format(struct ia_css_frame_info *info, 49 enum ia_css_frame_format format); 50 51 /* @brief Sets the frame info with the given parameters 52 * 53 * @param 54 * @param[in] info The info to which parameters would set 55 * @param[in] width The width to be set to info 56 * @param[in] height The height to be set to info 57 * @param[in] format The format to be set to info 58 * @param[in] aligned The aligned to be set to info 59 * @return 60 */ 61 void ia_css_frame_info_init(struct ia_css_frame_info *info, 62 unsigned int width, 63 unsigned int height, 64 enum ia_css_frame_format format, 65 unsigned int aligned); 66 67 /* @brief Checks whether 2 frame infos has the same resolution 68 * 69 * @param 70 * @param[in] frame_a The first frame to be compared 71 * @param[in] frame_b The second frame to be compared 72 * @return Returns true if the frames are equal 73 */ 74 bool ia_css_frame_info_is_same_resolution( 75 const struct ia_css_frame_info *info_a, 76 const struct ia_css_frame_info *info_b); 77 78 /* @brief Check the frame info is valid 79 * 80 * @param 81 * @param[in] info The frame attributes to be initialized 82 * @return The error code. 83 */ 84 int ia_css_frame_check_info(const struct ia_css_frame_info *info); 85 86 /********************************************************************* 87 **** Frame APIs 88 **********************************************************************/ 89 90 /* @brief Initialize the plane depending on the frame type 91 * 92 * @param 93 * @param[in] frame The frame attributes to be initialized 94 * @return The error code. 95 */ 96 int ia_css_frame_init_planes(struct ia_css_frame *frame); 97 98 /* @brief Free an array of frames 99 * 100 * @param 101 * @param[in] num_frames The number of frames to be freed in the array 102 * @param[in] **frames_array The array of frames to be removed 103 * @return 104 */ 105 void ia_css_frame_free_multiple(unsigned int num_frames, 106 struct ia_css_frame **frames_array); 107 108 /* @brief Allocate a CSS frame structure of given size in bytes.. 109 * 110 * @param frame The allocated frame. 111 * @param[in] size_bytes The frame size in bytes. 112 * @param[in] contiguous Allocate memory physically contiguously or not. 113 * @return The error code. 114 * 115 * Allocate a frame using the given size in bytes. 116 * The frame structure is partially null initialized. 117 */ 118 int ia_css_frame_allocate_with_buffer_size( 119 struct ia_css_frame **frame, 120 const unsigned int size_bytes, 121 const bool contiguous); 122 123 /* @brief Check whether 2 frames are same type 124 * 125 * @param 126 * @param[in] frame_a The first frame to be compared 127 * @param[in] frame_b The second frame to be compared 128 * @return Returns true if the frames are equal 129 */ 130 bool ia_css_frame_is_same_type( 131 const struct ia_css_frame *frame_a, 132 const struct ia_css_frame *frame_b); 133 134 /* @brief Configure a dma port from frame info 135 * 136 * @param 137 * @param[in] config The DAM port configuration 138 * @param[in] info The frame info 139 * @return 140 */ 141 void ia_css_dma_configure_from_info( 142 struct dma_port_config *config, 143 const struct ia_css_frame_info *info); 144 145 /* ISP2401 */ 146 /* @brief Finds the cropping resolution 147 * This function finds the maximum cropping resolution in an input image keeping 148 * the aspect ratio for the given output resolution.Calculates the coordinates 149 * for cropping from the center and returns the starting pixel location of the 150 * region in the input image. Also returns the dimension of the cropping 151 * resolution. 152 * 153 * @param 154 * @param[in] in_res Resolution of input image 155 * @param[in] out_res Resolution of output image 156 * @param[out] crop_res Crop resolution of input image 157 * @return Returns 0 or -EINVAL on error 158 */ 159 int 160 ia_css_frame_find_crop_resolution(const struct ia_css_resolution *in_res, 161 const struct ia_css_resolution *out_res, 162 struct ia_css_resolution *crop_res); 163 164 #endif /* __IA_CSS_FRAME_H__ */ 165