| /Linux-v6.1/drivers/gpu/drm/ |
| D | drm_plane.c | 41 * A plane represents an image source that can be blended with or overlaid on 43 * &drm_framebuffer object. The plane itself specifies the cropping and scaling 45 * pipeline, represented by &drm_crtc. A plane can also have additional 49 * To create a plane, a KMS drivers allocates and zeroes an instances of 53 * Each plane has a type, see enum drm_plane_type. A plane can be compatible 56 * Each CRTC must have a unique primary plane userspace can attach to enable 58 * primary plane to each CRTC at the same time. Primary planes can still be 63 * relies on the driver to set the primary and optionally the cursor plane used 65 * drivers must provide one primary plane per CRTC to avoid surprising legacy 70 * DOC: standard plane properties [all …]
|
| D | drm_gem_atomic_helper.c | 21 * synchronization helpers, and plane state and framebuffer BO mappings 24 * Before scanout, a plane's framebuffer needs to be synchronized with 27 * struct &drm_plane_helper.prepare_fb . It sets the plane's fence from 56 * and provide struct drm_shadow_plane_state, which stores the plane's mapping 61 * These macros set up the plane and plane-helper callbacks to point to the 79 * from the plane state. Use to_drm_shadow_plane_state() to upcast from 84 * void driver_plane_atomic_update(struct drm_plane *plane, 87 * struct drm_plane_state *plane_state = plane->state; 122 * Plane Helpers 127 * @plane: Plane [all …]
|
| D | drm_blend.c | 6 * DRM core plane blending related functions 41 * The basic plane composition model supported by standard plane properties only 49 * For the atomic ioctl the following standard (atomic) properties on the plane object 50 * encode the basic plane composition model: 77 * Mode object ID of the &drm_framebuffer this plane should scan out. 79 * Mode object ID of the &drm_crtc this plane should be connected to. 96 * plane-wide opacity, from transparent (0) to opaque (0xffff). It can be 99 * pre-multiplied by the global alpha associated to the plane. 110 * Signals that a drm plane is rotated <degrees> degrees in counter 114 * Signals that the contents of a drm plane is reflected along the [all …]
|
| D | drm_plane_helper.c | 4 * DRM universal plane helper functions 45 * primary plane support on top of the normal CRTC configuration interface. 47 * plane together with the CRTC state this does not allow userspace to disable 48 * the primary plane itself. The default primary plane only expose XRBG8888 and 56 * gradually switch to the atomic helper infrastructure for plane updates. Once 58 * the proper legacy implementations for update and disable plane hooks provided 63 * The plane helpers share the function table structures with other helpers, 83 * Note: Once we change the plane hooks to more fine-grained locking we in get_connectors_for_crtc() 103 static int drm_plane_helper_check_update(struct drm_plane *plane, in drm_plane_helper_check_update() argument 116 .plane = plane, in drm_plane_helper_check_update() [all …]
|
| D | drm_atomic_state_helper.c | 238 * __drm_atomic_helper_plane_state_reset - resets plane state to default values 239 * @plane_state: atomic plane state, must not be NULL 240 * @plane: plane object, must not be NULL 246 struct drm_plane *plane) in __drm_atomic_helper_plane_state_reset() argument 250 plane_state->plane = plane; in __drm_atomic_helper_plane_state_reset() 256 if (plane->color_encoding_property) { in __drm_atomic_helper_plane_state_reset() 257 if (!drm_object_property_get_default_value(&plane->base, in __drm_atomic_helper_plane_state_reset() 258 plane->color_encoding_property, in __drm_atomic_helper_plane_state_reset() 263 if (plane->color_range_property) { in __drm_atomic_helper_plane_state_reset() 264 if (!drm_object_property_get_default_value(&plane->base, in __drm_atomic_helper_plane_state_reset() [all …]
|
| /Linux-v6.1/drivers/gpu/drm/i915/display/ |
| D | intel_atomic_plane.c | 25 * DOC: atomic plane helpers 27 * The functions here are used by the atomic plane helper functions to 28 * implement legacy plane updates (i.e., drm_plane->update_plane() and 29 * drm_plane->disable_plane()). This allows plane updates to use the 30 * atomic state infrastructure and perform plane updates as separate 50 struct intel_plane *plane) in intel_plane_state_reset() argument 54 __drm_atomic_helper_plane_state_reset(&plane_state->uapi, &plane->base); in intel_plane_state_reset() 62 struct intel_plane *plane; in intel_plane_alloc() local 64 plane = kzalloc(sizeof(*plane), GFP_KERNEL); in intel_plane_alloc() 65 if (!plane) in intel_plane_alloc() [all …]
|
| D | i9xx_plane.c | 20 /* Primary plane formats for gen <= 3 */ 28 /* Primary plane formats for ivb (no fp16 due to hw issue) */ 38 /* Primary plane formats for gen >= 4, except ivb */ 49 /* Primary plane formats for vlv/chv */ 133 static bool i9xx_plane_has_windowing(struct intel_plane *plane) in i9xx_plane_has_windowing() argument 135 struct drm_i915_private *dev_priv = to_i915(plane->base.dev); in i9xx_plane_has_windowing() 136 enum i9xx_plane_id i9xx_plane = plane->i9xx_plane; in i9xx_plane_has_windowing() 153 to_i915(plane_state->uapi.plane->dev); in i9xx_plane_ctl() 225 to_i915(plane_state->uapi.plane->dev); in i9xx_check_plane_surface() 255 * When using an X-tiled surface the plane starts to in i9xx_check_plane_surface() [all …]
|
| D | intel_sprite.c | 26 * New plane/sprite handling. 28 * The older chips had a separate interface for programming plane related 29 * registers; newer ones are much simpler and we can use the new DRM plane 58 struct drm_i915_private *i915 = to_i915(plane_state->uapi.plane->dev); in intel_plane_check_src_coordinates() 127 struct intel_plane *plane = to_intel_plane(plane_state->uapi.plane); in chv_sprite_update_csc() local 128 struct drm_i915_private *dev_priv = to_i915(plane->base.dev); in chv_sprite_update_csc() 130 enum plane_id plane_id = plane->id; in chv_sprite_update_csc() 199 struct intel_plane *plane = to_intel_plane(plane_state->uapi.plane); in vlv_sprite_update_clrc() local 200 struct drm_i915_private *dev_priv = to_i915(plane->base.dev); in vlv_sprite_update_clrc() 202 enum pipe pipe = plane->pipe; in vlv_sprite_update_clrc() [all …]
|
| /Linux-v6.1/drivers/gpu/drm/nouveau/dispnv04/ |
| D | overlay.c | 113 nv10_update_plane(struct drm_plane *plane, struct drm_crtc *crtc, in nv10_update_plane() argument 120 struct nouveau_drm *drm = nouveau_drm(plane->dev); in nv10_update_plane() 123 container_of(plane, struct nouveau_plane, base); in nv10_update_plane() 192 nv10_disable_plane(struct drm_plane *plane, in nv10_disable_plane() argument 195 struct nvif_object *dev = &nouveau_drm(plane->dev)->client.device.object; in nv10_disable_plane() 197 container_of(plane, struct nouveau_plane, base); in nv10_disable_plane() 209 nv_destroy_plane(struct drm_plane *plane) in nv_destroy_plane() argument 211 drm_plane_force_disable(plane); in nv_destroy_plane() 212 drm_plane_cleanup(plane); in nv_destroy_plane() 213 kfree(plane); in nv_destroy_plane() [all …]
|
| /Linux-v6.1/drivers/gpu/drm/virtio/ |
| D | virtgpu_plane.c | 77 static int virtio_gpu_plane_atomic_check(struct drm_plane *plane, in virtio_gpu_plane_atomic_check() argument 81 plane); in virtio_gpu_plane_atomic_check() 82 bool is_cursor = plane->type == DRM_PLANE_TYPE_CURSOR; in virtio_gpu_plane_atomic_check() 124 static void virtio_gpu_resource_flush(struct drm_plane *plane, in virtio_gpu_resource_flush() argument 128 struct drm_device *dev = plane->dev; in virtio_gpu_resource_flush() 133 vgfb = to_virtio_gpu_framebuffer(plane->state->fb); in virtio_gpu_resource_flush() 158 static void virtio_gpu_primary_plane_update(struct drm_plane *plane, in virtio_gpu_primary_plane_update() argument 162 plane); in virtio_gpu_primary_plane_update() 163 struct drm_device *dev = plane->dev; in virtio_gpu_primary_plane_update() 169 if (plane->state->crtc) in virtio_gpu_primary_plane_update() [all …]
|
| /Linux-v6.1/include/drm/ |
| D | drm_plane.h | 44 * struct drm_plane_state - mutable plane state 53 /** @plane: backpointer to the plane */ 54 struct drm_plane *plane; member 88 * Left position of visible portion of plane on crtc, signed dest 96 * Upper position of visible portion of plane on crtc, signed dest 101 /** @crtc_w: width of visible portion of plane on crtc */ 102 /** @crtc_h: height of visible portion of plane on crtc */ 106 * @src_x: left position of visible portion of plane within plane (in 111 * @src_y: upper position of visible portion of plane within plane (in 115 /** @src_w: width of visible portion of plane (in 16.16) */ [all …]
|
| /Linux-v6.1/drivers/gpu/drm/mediatek/ |
| D | mtk_drm_plane.c | 35 static void mtk_plane_reset(struct drm_plane *plane) in mtk_plane_reset() argument 39 if (plane->state) { in mtk_plane_reset() 40 __drm_atomic_helper_plane_destroy_state(plane->state); in mtk_plane_reset() 42 state = to_mtk_plane_state(plane->state); in mtk_plane_reset() 50 __drm_atomic_helper_plane_reset(plane, &state->base); in mtk_plane_reset() 52 state->base.plane = plane; in mtk_plane_reset() 56 static struct drm_plane_state *mtk_plane_duplicate_state(struct drm_plane *plane) in mtk_plane_duplicate_state() argument 58 struct mtk_plane_state *old_state = to_mtk_plane_state(plane->state); in mtk_plane_duplicate_state() 65 __drm_atomic_helper_plane_duplicate_state(plane, &state->base); in mtk_plane_duplicate_state() 67 WARN_ON(state->base.plane != plane); in mtk_plane_duplicate_state() [all …]
|
| /Linux-v6.1/drivers/gpu/drm/i915/gvt/ |
| D | fb_decoder.c | 195 * intel_vgpu_decode_primary_plane - Decode primary plane 197 * @plane: primary plane to save decoded info 198 * This function is called for decoding plane 204 struct intel_vgpu_primary_plane_format *plane) in intel_vgpu_decode_primary_plane() argument 215 plane->enabled = !!(val & DISP_ENABLE); in intel_vgpu_decode_primary_plane() 216 if (!plane->enabled) in intel_vgpu_decode_primary_plane() 220 plane->tiled = val & PLANE_CTL_TILED_MASK; in intel_vgpu_decode_primary_plane() 232 plane->bpp = skl_pixel_formats[fmt].bpp; in intel_vgpu_decode_primary_plane() 233 plane->drm_format = skl_pixel_formats[fmt].drm_format; in intel_vgpu_decode_primary_plane() 235 plane->tiled = val & DISP_TILED; in intel_vgpu_decode_primary_plane() [all …]
|
| /Linux-v6.1/drivers/gpu/drm/omapdrm/ |
| D | omap_plane.c | 18 * plane funcs 45 static int omap_plane_prepare_fb(struct drm_plane *plane, in omap_plane_prepare_fb() argument 51 drm_gem_plane_helper_prepare_fb(plane, new_state); in omap_plane_prepare_fb() 56 static void omap_plane_cleanup_fb(struct drm_plane *plane, in omap_plane_cleanup_fb() argument 63 static void omap_plane_atomic_update(struct drm_plane *plane, in omap_plane_atomic_update() argument 66 struct omap_drm_private *priv = plane->dev->dev_private; in omap_plane_atomic_update() 68 plane); in omap_plane_atomic_update() 70 plane); in omap_plane_atomic_update() 90 DBG("[PLANE:%d:%s] no overlay attached", plane->base.id, plane->name); in omap_plane_atomic_update() 95 DBG("%s, crtc=%p fb=%p", plane->name, new_state->crtc, in omap_plane_atomic_update() [all …]
|
| /Linux-v6.1/drivers/gpu/drm/msm/disp/dpu1/ |
| D | dpu_plane.h | 18 * struct dpu_plane_state: Define dpu extension of drm plane state object 19 * @base: base drm plane state object 26 * @plane_fetch_bw: calculated BW per plane 27 * @plane_clk: calculated clk per plane 48 * struct dpu_multirect_plane_states: Defines multirect pair of drm plane states 49 * @r0: drm plane configured on rect 0 50 * @r1: drm plane configured on rect 1 61 * dpu_plane_pipe - return sspp identifier for the given plane 62 * @plane: Pointer to DRM plane object 63 * Returns: sspp identifier of the given plane [all …]
|
| D | dpu_plane.c | 29 #define DPU_DEBUG_PLANE(pl, fmt, ...) DRM_DEBUG_ATOMIC("plane%d " fmt,\ 32 #define DPU_ERROR_PLANE(pl, fmt, ...) DPU_ERROR("plane%d " fmt,\ 92 * struct dpu_plane - local dpu plane structure 96 * @revalidate: force revalidation of all the plane properties 120 static struct dpu_kms *_dpu_plane_get_kms(struct drm_plane *plane) in _dpu_plane_get_kms() argument 122 struct msm_drm_private *priv = plane->dev->dev_private; in _dpu_plane_get_kms() 128 * _dpu_plane_calc_bw - calculate bandwidth required for a plane 129 * @plane: Pointer to drm plane. 130 * @fb: Pointer to framebuffer associated with the given plane 132 * Result: Updates calculated bandwidth in the plane state. [all …]
|
| /Linux-v6.1/drivers/gpu/drm/rcar-du/ |
| D | rcar_du_plane.c | 27 * Atomic hardware plane allocator 29 * The hardware plane allocator is solely based on the atomic plane states 35 * the allocated hardware plane(s) for each KMS plane. The allocator then loops 36 * over all plane states to compute the free planes bitmask, allocates hardware 37 * planes based on that bitmask, and stores the result back in the plane states. 56 * as the extra hardware plane will be freed when committing, but doing in rcar_du_plane_needs_realloc() 86 * VSPD1. VSPD0 feeds DU0/1 plane 0, and VSPD1 feeds either DU2 plane 0 or 87 * DU0/1 plane 1. 89 * Allocate the correct fixed plane when sourcing frames from VSPD0 or VSPD1, 96 static int rcar_du_plane_hwalloc(struct rcar_du_plane *plane, in rcar_du_plane_hwalloc() argument [all …]
|
| /Linux-v6.1/drivers/gpu/drm/arm/display/komeda/ |
| D | komeda_plane.c | 20 struct komeda_plane *kplane = to_kplane(st->plane); in komeda_plane_init_data_flow() 32 st->plane->name, st->normalized_zpos, in komeda_plane_init_data_flow() 64 * @plane: DRM plane 65 * @state: the plane state object 71 komeda_plane_atomic_check(struct drm_plane *plane, in komeda_plane_atomic_check() argument 75 plane); in komeda_plane_atomic_check() 76 struct komeda_plane *kplane = to_kplane(plane); in komeda_plane_atomic_check() 90 DRM_DEBUG_ATOMIC("Cannot update plane on a disabled CRTC.\n"); in komeda_plane_atomic_check() 114 /* plane doesn't represent a real HW, so there is no HW update for plane. 118 komeda_plane_atomic_update(struct drm_plane *plane, in komeda_plane_atomic_update() argument [all …]
|
| /Linux-v6.1/drivers/video/fbdev/omap2/omapfb/dss/ |
| D | dispc.h | 339 static inline u16 DISPC_OVL_BASE(enum omap_plane plane) in DISPC_OVL_BASE() argument 341 switch (plane) { in DISPC_OVL_BASE() 359 static inline u16 DISPC_BA0_OFFSET(enum omap_plane plane) in DISPC_BA0_OFFSET() argument 361 switch (plane) { in DISPC_BA0_OFFSET() 375 static inline u16 DISPC_BA1_OFFSET(enum omap_plane plane) in DISPC_BA1_OFFSET() argument 377 switch (plane) { in DISPC_BA1_OFFSET() 391 static inline u16 DISPC_BA0_UV_OFFSET(enum omap_plane plane) in DISPC_BA0_UV_OFFSET() argument 393 switch (plane) { in DISPC_BA0_UV_OFFSET() 411 static inline u16 DISPC_BA1_UV_OFFSET(enum omap_plane plane) in DISPC_BA1_UV_OFFSET() argument 413 switch (plane) { in DISPC_BA1_UV_OFFSET() [all …]
|
| /Linux-v6.1/drivers/gpu/drm/omapdrm/dss/ |
| D | dispc.h | 342 static inline u16 DISPC_OVL_BASE(enum omap_plane_id plane) in DISPC_OVL_BASE() argument 344 switch (plane) { in DISPC_OVL_BASE() 362 static inline u16 DISPC_BA0_OFFSET(enum omap_plane_id plane) in DISPC_BA0_OFFSET() argument 364 switch (plane) { in DISPC_BA0_OFFSET() 378 static inline u16 DISPC_BA1_OFFSET(enum omap_plane_id plane) in DISPC_BA1_OFFSET() argument 380 switch (plane) { in DISPC_BA1_OFFSET() 394 static inline u16 DISPC_BA0_UV_OFFSET(enum omap_plane_id plane) in DISPC_BA0_UV_OFFSET() argument 396 switch (plane) { in DISPC_BA0_UV_OFFSET() 414 static inline u16 DISPC_BA1_UV_OFFSET(enum omap_plane_id plane) in DISPC_BA1_UV_OFFSET() argument 416 switch (plane) { in DISPC_BA1_UV_OFFSET() [all …]
|
| /Linux-v6.1/drivers/gpu/drm/sun4i/ |
| D | sun4i_layer.c | 19 static void sun4i_backend_layer_reset(struct drm_plane *plane) in sun4i_backend_layer_reset() argument 23 if (plane->state) { in sun4i_backend_layer_reset() 24 state = state_to_sun4i_layer_state(plane->state); in sun4i_backend_layer_reset() 29 plane->state = NULL; in sun4i_backend_layer_reset() 34 __drm_atomic_helper_plane_reset(plane, &state->state); in sun4i_backend_layer_reset() 38 sun4i_backend_layer_duplicate_state(struct drm_plane *plane) in sun4i_backend_layer_duplicate_state() argument 40 struct sun4i_layer_state *orig = state_to_sun4i_layer_state(plane->state); in sun4i_backend_layer_duplicate_state() 47 __drm_atomic_helper_plane_duplicate_state(plane, ©->state); in sun4i_backend_layer_duplicate_state() 53 static void sun4i_backend_layer_destroy_state(struct drm_plane *plane, in sun4i_backend_layer_destroy_state() argument 63 static void sun4i_backend_layer_atomic_disable(struct drm_plane *plane, in sun4i_backend_layer_atomic_disable() argument [all …]
|
| /Linux-v6.1/drivers/gpu/drm/tegra/ |
| D | plane.c | 17 #include "plane.h" 19 static void tegra_plane_destroy(struct drm_plane *plane) in tegra_plane_destroy() argument 21 struct tegra_plane *p = to_tegra_plane(plane); in tegra_plane_destroy() 23 drm_plane_cleanup(plane); in tegra_plane_destroy() 27 static void tegra_plane_reset(struct drm_plane *plane) in tegra_plane_reset() argument 29 struct tegra_plane *p = to_tegra_plane(plane); in tegra_plane_reset() 33 if (plane->state) in tegra_plane_reset() 34 __drm_atomic_helper_plane_destroy_state(plane->state); in tegra_plane_reset() 36 kfree(plane->state); in tegra_plane_reset() 37 plane->state = NULL; in tegra_plane_reset() [all …]
|
| /Linux-v6.1/drivers/gpu/drm/msm/disp/mdp5/ |
| D | mdp5_plane.c | 26 static int mdp5_plane_mode_set(struct drm_plane *plane, 30 static struct mdp5_kms *get_kms(struct drm_plane *plane) in get_kms() argument 32 struct msm_drm_private *priv = plane->dev->dev_private; in get_kms() 41 static void mdp5_plane_destroy(struct drm_plane *plane) in mdp5_plane_destroy() argument 43 struct mdp5_plane *mdp5_plane = to_mdp5_plane(plane); in mdp5_plane_destroy() 45 drm_plane_cleanup(plane); in mdp5_plane_destroy() 51 static void mdp5_plane_install_properties(struct drm_plane *plane, in mdp5_plane_install_properties() argument 56 drm_plane_create_rotation_property(plane, in mdp5_plane_install_properties() 62 drm_plane_create_alpha_property(plane); in mdp5_plane_install_properties() 63 drm_plane_create_blend_mode_property(plane, in mdp5_plane_install_properties() [all …]
|
| /Linux-v6.1/drivers/gpu/drm/atmel-hlcdc/ |
| D | atmel_hlcdc_plane.c | 23 * struct atmel_hlcdc_plane_state - Atmel HLCDC Plane state structure. 25 * @base: DRM plane state 26 * @crtc_x: x position of the plane relative to the CRTC 27 * @crtc_y: y position of the plane relative to the CRTC 28 * @crtc_w: visible width of the plane 29 * @crtc_h: visible height of the plane 274 atmel_hlcdc_plane_scaler_set_phicoeff(struct atmel_hlcdc_plane *plane, in atmel_hlcdc_plane_scaler_set_phicoeff() argument 281 atmel_hlcdc_layer_write_cfg(&plane->layer, cfg_offs + i, in atmel_hlcdc_plane_scaler_set_phicoeff() 285 static void atmel_hlcdc_plane_setup_scaler(struct atmel_hlcdc_plane *plane, in atmel_hlcdc_plane_setup_scaler() argument 288 const struct atmel_hlcdc_layer_desc *desc = plane->layer.desc; in atmel_hlcdc_plane_setup_scaler() [all …]
|
| /Linux-v6.1/Documentation/gpu/ |
| D | afbc.rst | 87 Within each plane, the component ordering also follows the fourcc 94 * Plane 0: 102 * Plane 0: 106 * Plane 1: 127 - Plane 0: 4 components 135 - Plane 0: 4 components 143 - Plane 0: 3 components 150 - Plane 0: 3 components 157 - Plane 0: 4 components 164 - 8-bit per component YCbCr 444, single plane [all …]
|