Commit 40497c52 authored by Hans de Goede's avatar Hans de Goede Committed by Greg Kroah-Hartman

staging: vboxvideo: Stop disabling/enabling accel support on master set / drop

Userspace mode-setting (and thus also VESA) is not supported together with
modesetting. KMS userspace apps not properly marking the framebuffer as
dirty are also not supported.

So stop trying to accommodate this and simply enable accel
once at driver init.
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent acc962c5
...@@ -207,21 +207,6 @@ static int vbox_master_set(struct drm_device *dev, ...@@ -207,21 +207,6 @@ static int vbox_master_set(struct drm_device *dev,
*/ */
vbox->initial_mode_queried = false; vbox->initial_mode_queried = false;
mutex_lock(&vbox->hw_mutex);
/*
* Disable VBVA when someone releases master in case the next person
* tries tries to do VESA.
*/
/** @todo work out if anyone is likely to and whether it will work. */
/*
* Update: we also disable it because if the new master does not do
* dirty rectangle reporting (e.g. old versions of Plymouth) then at
* least the first screen will still be updated. We enable it as soon
* as we receive a dirty rectangle report.
*/
vbox_disable_accel(vbox);
mutex_unlock(&vbox->hw_mutex);
return 0; return 0;
} }
...@@ -231,10 +216,6 @@ static void vbox_master_drop(struct drm_device *dev, struct drm_file *file_priv) ...@@ -231,10 +216,6 @@ static void vbox_master_drop(struct drm_device *dev, struct drm_file *file_priv)
/* See vbox_master_set() */ /* See vbox_master_set() */
vbox->initial_mode_queried = false; vbox->initial_mode_queried = false;
mutex_lock(&vbox->hw_mutex);
vbox_disable_accel(vbox);
mutex_unlock(&vbox->hw_mutex);
} }
static struct drm_driver driver = { static struct drm_driver driver = {
......
...@@ -166,8 +166,6 @@ void vbox_mode_fini(struct vbox_private *vbox); ...@@ -166,8 +166,6 @@ void vbox_mode_fini(struct vbox_private *vbox);
#define DRM_MODE_FB_CMD drm_mode_fb_cmd2 #define DRM_MODE_FB_CMD drm_mode_fb_cmd2
void vbox_enable_accel(struct vbox_private *vbox);
void vbox_disable_accel(struct vbox_private *vbox);
void vbox_report_caps(struct vbox_private *vbox); void vbox_report_caps(struct vbox_private *vbox);
void vbox_framebuffer_dirty_rectangles(struct drm_framebuffer *fb, void vbox_framebuffer_dirty_rectangles(struct drm_framebuffer *fb,
......
...@@ -27,40 +27,6 @@ static void vbox_user_framebuffer_destroy(struct drm_framebuffer *fb) ...@@ -27,40 +27,6 @@ static void vbox_user_framebuffer_destroy(struct drm_framebuffer *fb)
kfree(fb); kfree(fb);
} }
void vbox_enable_accel(struct vbox_private *vbox)
{
unsigned int i;
struct vbva_buffer *vbva;
if (!vbox->vbva_info || !vbox->vbva_buffers) {
/* Should never happen... */
DRM_ERROR("vboxvideo: failed to set up VBVA.\n");
return;
}
for (i = 0; i < vbox->num_crtcs; ++i) {
if (vbox->vbva_info[i].vbva)
continue;
vbva = (void __force *)vbox->vbva_buffers +
i * VBVA_MIN_BUFFER_SIZE;
if (!vbva_enable(&vbox->vbva_info[i],
vbox->guest_pool, vbva, i)) {
/* very old host or driver error. */
DRM_ERROR("vboxvideo: vbva_enable failed\n");
return;
}
}
}
void vbox_disable_accel(struct vbox_private *vbox)
{
unsigned int i;
for (i = 0; i < vbox->num_crtcs; ++i)
vbva_disable(&vbox->vbva_info[i], vbox->guest_pool, i);
}
void vbox_report_caps(struct vbox_private *vbox) void vbox_report_caps(struct vbox_private *vbox)
{ {
u32 caps = VBVACAPS_DISABLE_CURSOR_INTEGRATION | u32 caps = VBVACAPS_DISABLE_CURSOR_INTEGRATION |
...@@ -72,12 +38,7 @@ void vbox_report_caps(struct vbox_private *vbox) ...@@ -72,12 +38,7 @@ void vbox_report_caps(struct vbox_private *vbox)
hgsmi_send_caps_info(vbox->guest_pool, caps); hgsmi_send_caps_info(vbox->guest_pool, caps);
} }
/* /* Send information about dirty rectangles to VBVA. */
* Send information about dirty rectangles to VBVA. If necessary we enable
* VBVA first, as this is normally disabled after a change of master in case
* the new master does not send dirty rectangle information (is this even
* allowed?)
*/
void vbox_framebuffer_dirty_rectangles(struct drm_framebuffer *fb, void vbox_framebuffer_dirty_rectangles(struct drm_framebuffer *fb,
struct drm_clip_rect *rects, struct drm_clip_rect *rects,
unsigned int num_rects) unsigned int num_rects)
...@@ -97,8 +58,6 @@ void vbox_framebuffer_dirty_rectangles(struct drm_framebuffer *fb, ...@@ -97,8 +58,6 @@ void vbox_framebuffer_dirty_rectangles(struct drm_framebuffer *fb,
crtc_x = crtc->primary->state->src_x >> 16; crtc_x = crtc->primary->state->src_x >> 16;
crtc_y = crtc->primary->state->src_y >> 16; crtc_y = crtc->primary->state->src_y >> 16;
vbox_enable_accel(vbox);
for (i = 0; i < num_rects; ++i) { for (i = 0; i < num_rects; ++i) {
struct vbva_cmd_hdr cmd_hdr; struct vbva_cmd_hdr cmd_hdr;
unsigned int crtc_id = to_vbox_crtc(crtc)->crtc_id; unsigned int crtc_id = to_vbox_crtc(crtc)->crtc_id;
...@@ -162,6 +121,7 @@ int vbox_framebuffer_init(struct vbox_private *vbox, ...@@ -162,6 +121,7 @@ int vbox_framebuffer_init(struct vbox_private *vbox,
static int vbox_accel_init(struct vbox_private *vbox) static int vbox_accel_init(struct vbox_private *vbox)
{ {
struct vbva_buffer *vbva;
unsigned int i; unsigned int i;
vbox->vbva_info = devm_kcalloc(vbox->ddev.dev, vbox->num_crtcs, vbox->vbva_info = devm_kcalloc(vbox->ddev.dev, vbox->num_crtcs,
...@@ -179,18 +139,30 @@ static int vbox_accel_init(struct vbox_private *vbox) ...@@ -179,18 +139,30 @@ static int vbox_accel_init(struct vbox_private *vbox)
if (!vbox->vbva_buffers) if (!vbox->vbva_buffers)
return -ENOMEM; return -ENOMEM;
for (i = 0; i < vbox->num_crtcs; ++i) for (i = 0; i < vbox->num_crtcs; ++i) {
vbva_setup_buffer_context(&vbox->vbva_info[i], vbva_setup_buffer_context(&vbox->vbva_info[i],
vbox->available_vram_size + vbox->available_vram_size +
i * VBVA_MIN_BUFFER_SIZE, i * VBVA_MIN_BUFFER_SIZE,
VBVA_MIN_BUFFER_SIZE); VBVA_MIN_BUFFER_SIZE);
vbva = (void __force *)vbox->vbva_buffers +
i * VBVA_MIN_BUFFER_SIZE;
if (!vbva_enable(&vbox->vbva_info[i],
vbox->guest_pool, vbva, i)) {
/* very old host or driver error. */
DRM_ERROR("vboxvideo: vbva_enable failed\n");
}
}
return 0; return 0;
} }
static void vbox_accel_fini(struct vbox_private *vbox) static void vbox_accel_fini(struct vbox_private *vbox)
{ {
vbox_disable_accel(vbox); unsigned int i;
for (i = 0; i < vbox->num_crtcs; ++i)
vbva_disable(&vbox->vbva_info[i], vbox->guest_pool, i);
pci_iounmap(vbox->ddev.pdev, vbox->vbva_buffers); pci_iounmap(vbox->ddev.pdev, vbox->vbva_buffers);
} }
......
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