summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/i915/intel_dsi.h
diff options
context:
space:
mode:
authorJani Nikula <jani.nikula@intel.com>2015-11-24 22:21:55 +0300
committerDaniel Vetter <daniel.vetter@ffwll.ch>2015-11-25 11:29:21 +0300
commit373701b1fc7d7c0013ae4fffd8103615c150751e (patch)
tree8ac8879cb421dd4ae80cb9a7bc377e222e2d91df /drivers/gpu/drm/i915/intel_dsi.h
parented293f7754934b26c6f3db0dbc39ec2ed990f286 (diff)
downloadlinux-373701b1fc7d7c0013ae4fffd8103615c150751e.tar.xz
drm: fix potential dangling else problems in for_each_ macros
We have serious dangling else bugs waiting to happen in our for_each_ style macros with ifs. Consider, for example, #define drm_for_each_plane_mask(plane, dev, plane_mask) \ list_for_each_entry((plane), &(dev)->mode_config.plane_list, head) \ if ((plane_mask) & (1 << drm_plane_index(plane))) If this is used in context: if (condition) drm_for_each_plane_mask(plane, dev, plane_mask); else foo(); foo() will be called for each plane *not* in plane_mask, if condition holds, and not at all if condition doesn't hold. Fix this by reversing the conditions in the macros, and adding an else branch for the "for each" block, so that other if/else blocks can't interfere. Provide a "for_each_if" helper macro to make it easier to get this right. Signed-off-by: Jani Nikula <jani.nikula@intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/1448392916-2281-1-git-send-email-jani.nikula@intel.com Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_dsi.h')
0 files changed, 0 insertions, 0 deletions