]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drm/gma500: Fix end of loop tests for list_for_each_entry
authorHarshvardhan Jha <harshvardhan.jha@oracle.com>
Fri, 9 Jul 2021 07:39:59 +0000 (13:09 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 15 Sep 2021 08:00:35 +0000 (10:00 +0200)
[ Upstream commit ea9a897b8affa0f7b4c90182b785dded74e434aa ]

The list_for_each_entry() iterator, "connector" in this code, can never be
NULL.  If we exit the loop without finding the correct  connector then
"connector" points invalid memory that is an offset from the list head.
This will eventually lead to memory corruption and presumably a kernel
crash.

Fixes: 9bd81acdb648 ("gma500: Convert Oaktrail to work with new output handling")
Signed-off-by: Harshvardhan Jha <harshvardhan.jha@oracle.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20210709073959.11443-1-harshvardhan.jha@oracle.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/gpu/drm/gma500/oaktrail_lvds.c

index 432bdcc57ac9e4e4438980a523ea805966feb440..a1332878857b2060925ad6353b98402841a3d4c8 100644 (file)
@@ -117,7 +117,7 @@ static void oaktrail_lvds_mode_set(struct drm_encoder *encoder,
                        continue;
        }
 
-       if (!connector) {
+       if (list_entry_is_head(connector, &mode_config->connector_list, head)) {
                DRM_ERROR("Couldn't find connector when setting mode");
                gma_power_end(dev);
                return;