Commit 8568209b authored by Hans de Goede's avatar Hans de Goede Committed by Greg Kroah-Hartman

staging: vboxvideo: Cleanup vbox_set_up_input_mapping()

This cleanups 2 things:

1) The first time we loop over the crtc-s, to compare framebuffers, fb1 may
get set to NULL by the fb1 = CRTC_FB(crtci); statement and then we call
to_vbox_framebuffer() on it. The result of this call is only used for
an address comparison, so we don't end up dereferencing the bad pointer,
but still it is better to not do this.

2) Since we already figure out the first crtc with a fb in the first loop
and store that in fb1, there is no need to loop over the crtc-s again just
to find the first crtc with a fb again.
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent ca2c4bee
...@@ -169,7 +169,7 @@ static bool vbox_set_up_input_mapping(struct vbox_private *vbox) ...@@ -169,7 +169,7 @@ static bool vbox_set_up_input_mapping(struct vbox_private *vbox)
{ {
struct drm_crtc *crtci; struct drm_crtc *crtci;
struct drm_connector *connectori; struct drm_connector *connectori;
struct drm_framebuffer *fb1 = NULL; struct drm_framebuffer *fb, *fb1 = NULL;
bool single_framebuffer = true; bool single_framebuffer = true;
bool old_single_framebuffer = vbox->single_framebuffer; bool old_single_framebuffer = vbox->single_framebuffer;
u16 width = 0, height = 0; u16 width = 0, height = 0;
...@@ -180,25 +180,25 @@ static bool vbox_set_up_input_mapping(struct vbox_private *vbox) ...@@ -180,25 +180,25 @@ static bool vbox_set_up_input_mapping(struct vbox_private *vbox)
* Same fall-back if this is the fbdev frame-buffer. * Same fall-back if this is the fbdev frame-buffer.
*/ */
list_for_each_entry(crtci, &vbox->ddev.mode_config.crtc_list, head) { list_for_each_entry(crtci, &vbox->ddev.mode_config.crtc_list, head) {
fb = CRTC_FB(crtci);
if (!fb)
continue;
if (!fb1) { if (!fb1) {
fb1 = CRTC_FB(crtci); fb1 = fb;
if (to_vbox_framebuffer(fb1) == &vbox->fbdev->afb) if (to_vbox_framebuffer(fb1) == &vbox->fbdev->afb)
break; break;
} else if (CRTC_FB(crtci) && fb1 != CRTC_FB(crtci)) { } else if (fb != fb1) {
single_framebuffer = false; single_framebuffer = false;
} }
} }
if (!fb1)
return false;
if (single_framebuffer) { if (single_framebuffer) {
vbox->single_framebuffer = true; vbox->single_framebuffer = true;
list_for_each_entry(crtci, &vbox->ddev.mode_config.crtc_list, vbox->input_mapping_width = fb1->width;
head) { vbox->input_mapping_height = fb1->height;
if (!CRTC_FB(crtci))
continue;
vbox->input_mapping_width = CRTC_FB(crtci)->width;
vbox->input_mapping_height = CRTC_FB(crtci)->height;
break;
}
return old_single_framebuffer != vbox->single_framebuffer; return old_single_framebuffer != vbox->single_framebuffer;
} }
/* Otherwise calculate the total span of all screens. */ /* Otherwise calculate the total span of all screens. */
......
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