1 /* Copyright 2022 Advanced Micro Devices, Inc. 2 * 3 * Permission is hereby granted, free of charge, to any person obtaining a 4 * copy of this software and associated documentation files (the "Software"), 5 * to deal in the Software without restriction, including without limitation 6 * the rights to use, copy, modify, merge, publish, distribute, sublicense, 7 * and/or sell copies of the Software, and to permit persons to whom the 8 * Software is furnished to do so, subject to the following conditions: 9 * 10 * The above copyright notice and this permission notice shall be included in 11 * all copies or substantial portions of the Software. 12 * 13 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 14 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 15 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 16 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR 17 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 18 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 19 * OTHER DEALINGS IN THE SOFTWARE. 20 * 21 * Authors: AMD 22 * 23 */ 24 #pragma once 25 26 #include "resource.h" 27 28 #ifdef __cplusplus 29 extern "C" { 30 #endif 31 32 enum vpe_status vpe10_construct_resource(struct vpe_priv *vpe_priv, struct resource *res); 33 34 void vpe10_destroy_resource(struct vpe_priv *vpe_priv, struct resource *res); 35 36 enum vpe_status vpe10_set_num_segments(struct vpe_priv *vpe_priv, struct stream_ctx *stream_ctx, 37 struct scaler_data *scl_data, struct vpe_rect *src_rect, struct vpe_rect *dst_rect, 38 uint32_t *max_seg_width); 39 40 bool vpe10_get_dcc_compression_output_cap(const struct vpe *vpe, const struct vpe_dcc_surface_param *params, struct vpe_surface_dcc_cap *cap); 41 42 bool vpe10_get_dcc_compression_input_cap(const struct vpe *vpe, const struct vpe_dcc_surface_param *params, struct vpe_surface_dcc_cap *cap); 43 44 bool vpe10_check_input_color_space(struct vpe_priv *vpe_priv, enum vpe_surface_pixel_format format, 45 const struct vpe_color_space *vcs); 46 47 bool vpe10_check_output_color_space(struct vpe_priv *vpe_priv, enum vpe_surface_pixel_format format, 48 const struct vpe_color_space *vcs); 49 50 bool vpe10_check_h_mirror_support(bool *input_mirror, bool *output_mirror); 51 52 enum vpe_status vpe10_check_bg_color_support(struct vpe_priv* vpe_priv, struct vpe_color* bg_color); 53 54 enum vpe_status vpe10_calculate_segments( 55 struct vpe_priv *vpe_priv, const struct vpe_build_param *params); 56 57 int32_t vpe10_program_frontend(struct vpe_priv *vpe_priv, uint32_t pipe_idx, uint32_t cmd_idx, 58 uint32_t cmd_input_idx, bool seg_only); 59 60 int32_t vpe10_program_backend( 61 struct vpe_priv *vpe_priv, uint32_t pipe_idx, uint32_t cmd_idx, bool seg_only); 62 63 enum vpe_status vpe10_populate_cmd_info(struct vpe_priv *vpe_priv); 64 65 void vpe10_calculate_dst_viewport_and_active( 66 struct segment_ctx *segment_ctx, uint32_t max_seg_width); 67 68 void vpe10_create_stream_ops_config(struct vpe_priv *vpe_priv, uint32_t pipe_idx, 69 struct stream_ctx *stream_ctx, struct vpe_cmd_input *cmd_input, enum vpe_cmd_ops ops); 70 71 void vpe10_get_bufs_req(struct vpe_priv *vpe_priv, struct vpe_bufs_req *req); 72 73 struct opp *vpe10_opp_create(struct vpe_priv *vpe_priv, int inst); 74 75 struct mpc *vpe10_mpc_create(struct vpe_priv *vpe_priv, int inst); 76 77 struct dpp *vpe10_dpp_create(struct vpe_priv *vpe_priv, int inst); 78 79 struct cdc *vpe10_cdc_create(struct vpe_priv *vpe_priv, int inst); 80 81 #ifdef __cplusplus 82 } 83 #endif 84