Instead of copying separately the GTT remapped and color plane view info from the FB to the plane state, do this by copying the whole intel_fb_view struct. For this we make sure the FB view state is fully inited (that is also including the view type) already during FB creation, so this init is not required during atomic check time. This also means the we don't need to reset the unused color plane info during atomic check, as these are already reset during FB creation. I noticed that initial FBs will only work atm if they are page aligned (which BIOS most probably always ensures), but add a comment to sanitize this part once. Also we won't disable the plane if get_initial_plane_config() failed for some reason (for instance due to unsupported rotation), add a TODO: comment for this too. Cc: Ville Syrjälä <ville.syrjala@linux.intel.com> Signed-off-by: Imre Deak <imre.deak@intel.com> Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20210325214808.2071517-19-imre.deak@intel.com
55 lines
1.9 KiB
C
55 lines
1.9 KiB
C
/* SPDX-License-Identifier: MIT */
|
|
/*
|
|
* Copyright © 2020-2021 Intel Corporation
|
|
*/
|
|
|
|
#ifndef __INTEL_FB_H__
|
|
#define __INTEL_FB_H__
|
|
|
|
#include <linux/types.h>
|
|
|
|
struct drm_framebuffer;
|
|
|
|
struct drm_i915_private;
|
|
|
|
struct intel_fb_view;
|
|
struct intel_framebuffer;
|
|
struct intel_plane_state;
|
|
|
|
bool is_ccs_plane(const struct drm_framebuffer *fb, int plane);
|
|
bool is_gen12_ccs_plane(const struct drm_framebuffer *fb, int plane);
|
|
bool is_gen12_ccs_cc_plane(const struct drm_framebuffer *fb, int plane);
|
|
bool is_aux_plane(const struct drm_framebuffer *fb, int plane);
|
|
bool is_semiplanar_uv_plane(const struct drm_framebuffer *fb, int color_plane);
|
|
|
|
bool is_surface_linear(const struct drm_framebuffer *fb, int color_plane);
|
|
|
|
int main_to_ccs_plane(const struct drm_framebuffer *fb, int main_plane);
|
|
int skl_ccs_to_main_plane(const struct drm_framebuffer *fb, int ccs_plane);
|
|
int skl_main_to_aux_plane(const struct drm_framebuffer *fb, int main_plane);
|
|
|
|
unsigned int intel_tile_size(const struct drm_i915_private *i915);
|
|
unsigned int intel_tile_height(const struct drm_framebuffer *fb, int color_plane);
|
|
unsigned int intel_tile_row_size(const struct drm_framebuffer *fb, int color_plane);
|
|
|
|
unsigned int intel_cursor_alignment(const struct drm_i915_private *i915);
|
|
|
|
void intel_fb_plane_get_subsampling(int *hsub, int *vsub,
|
|
const struct drm_framebuffer *fb,
|
|
int color_plane);
|
|
|
|
u32 intel_plane_adjust_aligned_offset(int *x, int *y,
|
|
const struct intel_plane_state *state,
|
|
int color_plane,
|
|
u32 old_offset, u32 new_offset);
|
|
u32 intel_plane_compute_aligned_offset(int *x, int *y,
|
|
const struct intel_plane_state *state,
|
|
int color_plane);
|
|
|
|
int intel_fill_fb_info(struct drm_i915_private *i915, struct drm_framebuffer *fb);
|
|
void intel_fb_fill_view(const struct intel_framebuffer *fb, unsigned int rotation,
|
|
struct intel_fb_view *view);
|
|
int intel_plane_compute_gtt(struct intel_plane_state *plane_state);
|
|
|
|
#endif /* __INTEL_FB_H__ */
|