Commit 485d98d4 authored by Martin Krastev's avatar Martin Krastev Committed by Zack Rusin

drm/vmwgfx: Add support for CursorMob and CursorBypass 4

* Add support for CursorMob
* Add support for CursorBypass 4
* Refactor vmw_du_cursor_plane_atomic_update to be kms-helper-atomic
  -- move BO mappings to vmw_du_cursor_plane_prepare_fb
  -- move BO unmappings to vmw_du_cursor_plane_cleanup_fb

Cursor mobs are a new svga feature which enables support for large
cursors, e.g. large accessibility cursor on platforms with vmwgfx. It
also cleans up the cursor code and makes it more uniform with the rest
of modern guest backed objects support.
Signed-off-by: default avatarMartin Krastev <krastevm@vmware.com>
Reviewed-by: default avatarZack Rusin <zackr@vmware.com>
Reviewed-by: default avatarMaaz Mombasawala <mombasawalam@vmware.com>
Signed-off-by: default avatarZack Rusin <zackr@vmware.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220302152426.885214-2-zack@kde.org
parent f28dd507
// SPDX-License-Identifier: GPL-2.0 OR MIT // SPDX-License-Identifier: GPL-2.0 OR MIT
/************************************************************************** /**************************************************************************
* *
* Copyright 2009-2016 VMware, Inc., Palo Alto, CA., USA * Copyright 2009-2022 VMware, Inc., Palo Alto, CA., USA
* *
* Permission is hereby granted, free of charge, to any person obtaining a * Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the * copy of this software and associated documentation files (the
......
/* SPDX-License-Identifier: GPL-2.0 OR MIT */ /* SPDX-License-Identifier: GPL-2.0 OR MIT */
/************************************************************************** /**************************************************************************
* *
* Copyright 2009-2021 VMware, Inc., Palo Alto, CA., USA * Copyright 2009-2022 VMware, Inc., Palo Alto, CA., USA
* *
* Permission is hereby granted, free of charge, to any person obtaining a * Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the * copy of this software and associated documentation files (the
...@@ -101,6 +101,7 @@ struct vmw_fpriv { ...@@ -101,6 +101,7 @@ struct vmw_fpriv {
* struct vmw_buffer_object - TTM buffer object with vmwgfx additions * struct vmw_buffer_object - TTM buffer object with vmwgfx additions
* @base: The TTM buffer object * @base: The TTM buffer object
* @res_tree: RB tree of resources using this buffer object as a backing MOB * @res_tree: RB tree of resources using this buffer object as a backing MOB
* @base_mapped_count: ttm BO mapping count; used by KMS atomic helpers.
* @cpu_writers: Number of synccpu write grabs. Protected by reservation when * @cpu_writers: Number of synccpu write grabs. Protected by reservation when
* increased. May be decreased without reservation. * increased. May be decreased without reservation.
* @dx_query_ctx: DX context if this buffer object is used as a DX query MOB * @dx_query_ctx: DX context if this buffer object is used as a DX query MOB
...@@ -111,6 +112,9 @@ struct vmw_fpriv { ...@@ -111,6 +112,9 @@ struct vmw_fpriv {
struct vmw_buffer_object { struct vmw_buffer_object {
struct ttm_buffer_object base; struct ttm_buffer_object base;
struct rb_root res_tree; struct rb_root res_tree;
/* For KMS atomic helpers: ttm bo mapping count */
atomic_t base_mapped_count;
atomic_t cpu_writers; atomic_t cpu_writers;
/* Not ref-counted. Protected by binding_mutex */ /* Not ref-counted. Protected by binding_mutex */
struct vmw_resource *dx_query_ctx; struct vmw_resource *dx_query_ctx;
......
This diff is collapsed.
/* SPDX-License-Identifier: GPL-2.0 OR MIT */ /* SPDX-License-Identifier: GPL-2.0 OR MIT */
/************************************************************************** /**************************************************************************
* *
* Copyright 2009-2015 VMware, Inc., Palo Alto, CA., USA * Copyright 2009-2022 VMware, Inc., Palo Alto, CA., USA
* *
* Permission is hereby granted, free of charge, to any person obtaining a * Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the * copy of this software and associated documentation files (the
...@@ -261,6 +261,7 @@ static const uint32_t __maybe_unused vmw_cursor_plane_formats[] = { ...@@ -261,6 +261,7 @@ static const uint32_t __maybe_unused vmw_cursor_plane_formats[] = {
#define vmw_plane_state_to_vps(x) container_of(x, struct vmw_plane_state, base) #define vmw_plane_state_to_vps(x) container_of(x, struct vmw_plane_state, base)
#define vmw_connector_state_to_vcs(x) \ #define vmw_connector_state_to_vcs(x) \
container_of(x, struct vmw_connector_state, base) container_of(x, struct vmw_connector_state, base)
#define vmw_plane_to_vcp(x) container_of(x, struct vmw_cursor_plane, base)
/** /**
* Derived class for crtc state object * Derived class for crtc state object
...@@ -293,6 +294,14 @@ struct vmw_plane_state { ...@@ -293,6 +294,14 @@ struct vmw_plane_state {
/* For CPU Blit */ /* For CPU Blit */
unsigned int cpp; unsigned int cpp;
/* CursorMob flipping index; -1 if cursor mobs not used */
unsigned int cursor_mob_idx;
/* Currently-active CursorMob */
struct ttm_buffer_object *cm_bo;
/* CursorMob kmap_obj; expected valid at cursor_plane_atomic_update
IFF currently-active CursorMob above is valid */
struct ttm_bo_kmap_obj cm_map;
}; };
...@@ -325,6 +334,17 @@ struct vmw_connector_state { ...@@ -325,6 +334,17 @@ struct vmw_connector_state {
int gui_y; int gui_y;
}; };
/**
* Derived class for cursor plane object
*
* @base DRM plane object
* @cursor_mob array of two MOBs for CursorMob flipping
*/
struct vmw_cursor_plane {
struct drm_plane base;
struct ttm_buffer_object *cursor_mob[2];
};
/** /**
* Base class display unit. * Base class display unit.
* *
...@@ -337,7 +357,7 @@ struct vmw_display_unit { ...@@ -337,7 +357,7 @@ struct vmw_display_unit {
struct drm_encoder encoder; struct drm_encoder encoder;
struct drm_connector connector; struct drm_connector connector;
struct drm_plane primary; struct drm_plane primary;
struct drm_plane cursor; struct vmw_cursor_plane cursor;
struct vmw_surface *cursor_surface; struct vmw_surface *cursor_surface;
struct vmw_buffer_object *cursor_bo; struct vmw_buffer_object *cursor_bo;
...@@ -452,6 +472,8 @@ void vmw_kms_create_implicit_placement_property(struct vmw_private *dev_priv); ...@@ -452,6 +472,8 @@ void vmw_kms_create_implicit_placement_property(struct vmw_private *dev_priv);
/* Universal Plane Helpers */ /* Universal Plane Helpers */
void vmw_du_primary_plane_destroy(struct drm_plane *plane); void vmw_du_primary_plane_destroy(struct drm_plane *plane);
void vmw_du_cursor_plane_destroy(struct drm_plane *plane); void vmw_du_cursor_plane_destroy(struct drm_plane *plane);
int vmw_du_create_cursor_mob_array(struct vmw_cursor_plane *vcp);
void vmw_du_destroy_cursor_mob_array(struct vmw_cursor_plane *vcp);
/* Atomic Helpers */ /* Atomic Helpers */
int vmw_du_primary_plane_atomic_check(struct drm_plane *plane, int vmw_du_primary_plane_atomic_check(struct drm_plane *plane,
...@@ -462,6 +484,8 @@ void vmw_du_cursor_plane_atomic_update(struct drm_plane *plane, ...@@ -462,6 +484,8 @@ void vmw_du_cursor_plane_atomic_update(struct drm_plane *plane,
struct drm_atomic_state *state); struct drm_atomic_state *state);
int vmw_du_cursor_plane_prepare_fb(struct drm_plane *plane, int vmw_du_cursor_plane_prepare_fb(struct drm_plane *plane,
struct drm_plane_state *new_state); struct drm_plane_state *new_state);
void vmw_du_cursor_plane_cleanup_fb(struct drm_plane *plane,
struct drm_plane_state *old_state);
void vmw_du_plane_cleanup_fb(struct drm_plane *plane, void vmw_du_plane_cleanup_fb(struct drm_plane *plane,
struct drm_plane_state *old_state); struct drm_plane_state *old_state);
void vmw_du_plane_reset(struct drm_plane *plane); void vmw_du_plane_reset(struct drm_plane *plane);
......
// SPDX-License-Identifier: GPL-2.0 OR MIT // SPDX-License-Identifier: GPL-2.0 OR MIT
/************************************************************************** /**************************************************************************
* *
* Copyright 2009-2015 VMware, Inc., Palo Alto, CA., USA * Copyright 2009-2022 VMware, Inc., Palo Alto, CA., USA
* *
* Permission is hereby granted, free of charge, to any person obtaining a * Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the * copy of this software and associated documentation files (the
...@@ -338,7 +338,7 @@ drm_plane_helper_funcs vmw_ldu_cursor_plane_helper_funcs = { ...@@ -338,7 +338,7 @@ drm_plane_helper_funcs vmw_ldu_cursor_plane_helper_funcs = {
.atomic_check = vmw_du_cursor_plane_atomic_check, .atomic_check = vmw_du_cursor_plane_atomic_check,
.atomic_update = vmw_du_cursor_plane_atomic_update, .atomic_update = vmw_du_cursor_plane_atomic_update,
.prepare_fb = vmw_du_cursor_plane_prepare_fb, .prepare_fb = vmw_du_cursor_plane_prepare_fb,
.cleanup_fb = vmw_du_plane_cleanup_fb, .cleanup_fb = vmw_du_cursor_plane_cleanup_fb,
}; };
static const struct static const struct
...@@ -363,7 +363,8 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -363,7 +363,8 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit)
struct drm_device *dev = &dev_priv->drm; struct drm_device *dev = &dev_priv->drm;
struct drm_connector *connector; struct drm_connector *connector;
struct drm_encoder *encoder; struct drm_encoder *encoder;
struct drm_plane *primary, *cursor; struct drm_plane *primary;
struct vmw_cursor_plane *cursor;
struct drm_crtc *crtc; struct drm_crtc *crtc;
int ret; int ret;
...@@ -392,7 +393,7 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -392,7 +393,7 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit)
ldu->base.is_implicit = true; ldu->base.is_implicit = true;
/* Initialize primary plane */ /* Initialize primary plane */
ret = drm_universal_plane_init(dev, &ldu->base.primary, ret = drm_universal_plane_init(dev, primary,
0, &vmw_ldu_plane_funcs, 0, &vmw_ldu_plane_funcs,
vmw_primary_plane_formats, vmw_primary_plane_formats,
ARRAY_SIZE(vmw_primary_plane_formats), ARRAY_SIZE(vmw_primary_plane_formats),
...@@ -409,7 +410,7 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -409,7 +410,7 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit)
*/ */
if (vmw_cmd_supported(dev_priv)) { if (vmw_cmd_supported(dev_priv)) {
/* Initialize cursor plane */ /* Initialize cursor plane */
ret = drm_universal_plane_init(dev, &ldu->base.cursor, ret = drm_universal_plane_init(dev, &cursor->base,
0, &vmw_ldu_cursor_funcs, 0, &vmw_ldu_cursor_funcs,
vmw_cursor_plane_formats, vmw_cursor_plane_formats,
ARRAY_SIZE(vmw_cursor_plane_formats), ARRAY_SIZE(vmw_cursor_plane_formats),
...@@ -420,7 +421,7 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -420,7 +421,7 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit)
goto err_free; goto err_free;
} }
drm_plane_helper_add(cursor, &vmw_ldu_cursor_plane_helper_funcs); drm_plane_helper_add(&cursor->base, &vmw_ldu_cursor_plane_helper_funcs);
} }
ret = drm_connector_init(dev, connector, &vmw_legacy_connector_funcs, ret = drm_connector_init(dev, connector, &vmw_legacy_connector_funcs,
...@@ -450,9 +451,8 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -450,9 +451,8 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit)
goto err_free_encoder; goto err_free_encoder;
} }
ret = drm_crtc_init_with_planes( ret = drm_crtc_init_with_planes(dev, crtc, primary,
dev, crtc, &ldu->base.primary, vmw_cmd_supported(dev_priv) ? &cursor->base : NULL,
vmw_cmd_supported(dev_priv) ? &ldu->base.cursor : NULL,
&vmw_legacy_crtc_funcs, NULL); &vmw_legacy_crtc_funcs, NULL);
if (ret) { if (ret) {
DRM_ERROR("Failed to initialize CRTC\n"); DRM_ERROR("Failed to initialize CRTC\n");
......
// SPDX-License-Identifier: GPL-2.0 OR MIT // SPDX-License-Identifier: GPL-2.0 OR MIT
/************************************************************************** /**************************************************************************
* *
* Copyright 2011-2015 VMware, Inc., Palo Alto, CA., USA * Copyright 2011-2022 VMware, Inc., Palo Alto, CA., USA
* *
* Permission is hereby granted, free of charge, to any person obtaining a * Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the * copy of this software and associated documentation files (the
...@@ -804,7 +804,7 @@ drm_plane_helper_funcs vmw_sou_cursor_plane_helper_funcs = { ...@@ -804,7 +804,7 @@ drm_plane_helper_funcs vmw_sou_cursor_plane_helper_funcs = {
.atomic_check = vmw_du_cursor_plane_atomic_check, .atomic_check = vmw_du_cursor_plane_atomic_check,
.atomic_update = vmw_du_cursor_plane_atomic_update, .atomic_update = vmw_du_cursor_plane_atomic_update,
.prepare_fb = vmw_du_cursor_plane_prepare_fb, .prepare_fb = vmw_du_cursor_plane_prepare_fb,
.cleanup_fb = vmw_du_plane_cleanup_fb, .cleanup_fb = vmw_du_cursor_plane_cleanup_fb,
}; };
static const struct static const struct
...@@ -832,7 +832,8 @@ static int vmw_sou_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -832,7 +832,8 @@ static int vmw_sou_init(struct vmw_private *dev_priv, unsigned unit)
struct drm_device *dev = &dev_priv->drm; struct drm_device *dev = &dev_priv->drm;
struct drm_connector *connector; struct drm_connector *connector;
struct drm_encoder *encoder; struct drm_encoder *encoder;
struct drm_plane *primary, *cursor; struct drm_plane *primary;
struct vmw_cursor_plane *cursor;
struct drm_crtc *crtc; struct drm_crtc *crtc;
int ret; int ret;
...@@ -859,7 +860,7 @@ static int vmw_sou_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -859,7 +860,7 @@ static int vmw_sou_init(struct vmw_private *dev_priv, unsigned unit)
sou->base.is_implicit = false; sou->base.is_implicit = false;
/* Initialize primary plane */ /* Initialize primary plane */
ret = drm_universal_plane_init(dev, &sou->base.primary, ret = drm_universal_plane_init(dev, primary,
0, &vmw_sou_plane_funcs, 0, &vmw_sou_plane_funcs,
vmw_primary_plane_formats, vmw_primary_plane_formats,
ARRAY_SIZE(vmw_primary_plane_formats), ARRAY_SIZE(vmw_primary_plane_formats),
...@@ -873,7 +874,7 @@ static int vmw_sou_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -873,7 +874,7 @@ static int vmw_sou_init(struct vmw_private *dev_priv, unsigned unit)
drm_plane_enable_fb_damage_clips(primary); drm_plane_enable_fb_damage_clips(primary);
/* Initialize cursor plane */ /* Initialize cursor plane */
ret = drm_universal_plane_init(dev, &sou->base.cursor, ret = drm_universal_plane_init(dev, &cursor->base,
0, &vmw_sou_cursor_funcs, 0, &vmw_sou_cursor_funcs,
vmw_cursor_plane_formats, vmw_cursor_plane_formats,
ARRAY_SIZE(vmw_cursor_plane_formats), ARRAY_SIZE(vmw_cursor_plane_formats),
...@@ -884,7 +885,7 @@ static int vmw_sou_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -884,7 +885,7 @@ static int vmw_sou_init(struct vmw_private *dev_priv, unsigned unit)
goto err_free; goto err_free;
} }
drm_plane_helper_add(cursor, &vmw_sou_cursor_plane_helper_funcs); drm_plane_helper_add(&cursor->base, &vmw_sou_cursor_plane_helper_funcs);
ret = drm_connector_init(dev, connector, &vmw_sou_connector_funcs, ret = drm_connector_init(dev, connector, &vmw_sou_connector_funcs,
DRM_MODE_CONNECTOR_VIRTUAL); DRM_MODE_CONNECTOR_VIRTUAL);
...@@ -913,8 +914,8 @@ static int vmw_sou_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -913,8 +914,8 @@ static int vmw_sou_init(struct vmw_private *dev_priv, unsigned unit)
goto err_free_encoder; goto err_free_encoder;
} }
ret = drm_crtc_init_with_planes(dev, crtc, &sou->base.primary, ret = drm_crtc_init_with_planes(dev, crtc, primary,
&sou->base.cursor, &cursor->base,
&vmw_screen_object_crtc_funcs, NULL); &vmw_screen_object_crtc_funcs, NULL);
if (ret) { if (ret) {
DRM_ERROR("Failed to initialize CRTC\n"); DRM_ERROR("Failed to initialize CRTC\n");
......
// SPDX-License-Identifier: GPL-2.0 OR MIT // SPDX-License-Identifier: GPL-2.0 OR MIT
/****************************************************************************** /******************************************************************************
* *
* COPYRIGHT (C) 2014-2015 VMware, Inc., Palo Alto, CA., USA * COPYRIGHT (C) 2014-2022 VMware, Inc., Palo Alto, CA., USA
* *
* Permission is hereby granted, free of charge, to any person obtaining a * Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the * copy of this software and associated documentation files (the
...@@ -1685,7 +1685,7 @@ drm_plane_helper_funcs vmw_stdu_cursor_plane_helper_funcs = { ...@@ -1685,7 +1685,7 @@ drm_plane_helper_funcs vmw_stdu_cursor_plane_helper_funcs = {
.atomic_check = vmw_du_cursor_plane_atomic_check, .atomic_check = vmw_du_cursor_plane_atomic_check,
.atomic_update = vmw_du_cursor_plane_atomic_update, .atomic_update = vmw_du_cursor_plane_atomic_update,
.prepare_fb = vmw_du_cursor_plane_prepare_fb, .prepare_fb = vmw_du_cursor_plane_prepare_fb,
.cleanup_fb = vmw_du_plane_cleanup_fb, .cleanup_fb = vmw_du_cursor_plane_cleanup_fb,
}; };
static const struct static const struct
...@@ -1723,11 +1723,11 @@ static int vmw_stdu_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -1723,11 +1723,11 @@ static int vmw_stdu_init(struct vmw_private *dev_priv, unsigned unit)
struct drm_device *dev = &dev_priv->drm; struct drm_device *dev = &dev_priv->drm;
struct drm_connector *connector; struct drm_connector *connector;
struct drm_encoder *encoder; struct drm_encoder *encoder;
struct drm_plane *primary, *cursor; struct drm_plane *primary;
struct vmw_cursor_plane *cursor;
struct drm_crtc *crtc; struct drm_crtc *crtc;
int ret; int ret;
stdu = kzalloc(sizeof(*stdu), GFP_KERNEL); stdu = kzalloc(sizeof(*stdu), GFP_KERNEL);
if (!stdu) if (!stdu)
return -ENOMEM; return -ENOMEM;
...@@ -1759,7 +1759,7 @@ static int vmw_stdu_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -1759,7 +1759,7 @@ static int vmw_stdu_init(struct vmw_private *dev_priv, unsigned unit)
drm_plane_enable_fb_damage_clips(primary); drm_plane_enable_fb_damage_clips(primary);
/* Initialize cursor plane */ /* Initialize cursor plane */
ret = drm_universal_plane_init(dev, cursor, ret = drm_universal_plane_init(dev, &cursor->base,
0, &vmw_stdu_cursor_funcs, 0, &vmw_stdu_cursor_funcs,
vmw_cursor_plane_formats, vmw_cursor_plane_formats,
ARRAY_SIZE(vmw_cursor_plane_formats), ARRAY_SIZE(vmw_cursor_plane_formats),
...@@ -1770,7 +1770,7 @@ static int vmw_stdu_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -1770,7 +1770,7 @@ static int vmw_stdu_init(struct vmw_private *dev_priv, unsigned unit)
goto err_free; goto err_free;
} }
drm_plane_helper_add(cursor, &vmw_stdu_cursor_plane_helper_funcs); drm_plane_helper_add(&cursor->base, &vmw_stdu_cursor_plane_helper_funcs);
ret = drm_connector_init(dev, connector, &vmw_stdu_connector_funcs, ret = drm_connector_init(dev, connector, &vmw_stdu_connector_funcs,
DRM_MODE_CONNECTOR_VIRTUAL); DRM_MODE_CONNECTOR_VIRTUAL);
...@@ -1799,8 +1799,8 @@ static int vmw_stdu_init(struct vmw_private *dev_priv, unsigned unit) ...@@ -1799,8 +1799,8 @@ static int vmw_stdu_init(struct vmw_private *dev_priv, unsigned unit)
goto err_free_encoder; goto err_free_encoder;
} }
ret = drm_crtc_init_with_planes(dev, crtc, &stdu->base.primary, ret = drm_crtc_init_with_planes(dev, crtc, primary,
&stdu->base.cursor, &cursor->base,
&vmw_stdu_crtc_funcs, NULL); &vmw_stdu_crtc_funcs, NULL);
if (ret) { if (ret) {
DRM_ERROR("Failed to initialize CRTC\n"); DRM_ERROR("Failed to initialize CRTC\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment