[PATCH] drm: fix lut value extraction function
Daniel Vetter
daniel at ffwll.ch
Mon Apr 18 12:36:39 UTC 2016
On Mon, Apr 18, 2016 at 12:09:51PM +0100, Lionel Landwerlin wrote:
> Ping?
>
> On 22/03/16 14:10, Lionel Landwerlin wrote:
> >When extracting the value at full precision (16 bits), no need to
> >round the value.
> >
> >This was spotted by Jani when running sparse. Unfortunately this fix
> >doesn't get rid of the warning.
It sounded like no bug, and the patch itself fails to appease sparse. And
I didn't check what's upsetting sparse itself, so figured "nothing to do
here until a real fix shows up".
Should I do something here?
-Daniel
> >
> >Signed-off-by: Lionel Landwerlin <lionel.g.landwerlin at intel.com>
> >Reported-by: Jani Nikula <jani.nikula at intel.com>
> >Cc: Daniel Stone <daniels at collabora.com>
> >Cc: Daniel Vetter <daniel.vetter at ffwll.ch>
> >Cc: Matt Roper <matthew.d.roper at intel.com>
> >Cc: dri-devel at lists.freedesktop.org
> >Fixes: 5488dc16fde7 ("drm: introduce pipe color correction properties")
> >---
> > include/drm/drm_crtc.h | 8 ++++++--
> > 1 file changed, 6 insertions(+), 2 deletions(-)
> >
> >diff --git a/include/drm/drm_crtc.h b/include/drm/drm_crtc.h
> >index e0170bf..da63b4d 100644
> >--- a/include/drm/drm_crtc.h
> >+++ b/include/drm/drm_crtc.h
> >@@ -2600,10 +2600,14 @@ static inline struct drm_property *drm_property_find(struct drm_device *dev,
> > static inline uint32_t drm_color_lut_extract(uint32_t user_input,
> > uint32_t bit_precision)
> > {
> >- uint32_t val = user_input + (1 << (16 - bit_precision - 1));
> >+ uint32_t val = user_input;
> > uint32_t max = 0xffff >> (16 - bit_precision);
> >- val >>= 16 - bit_precision;
> >+ /* Round only if we're not using full precision. */
> >+ if (bit_precision < 16) {
> >+ val += 1UL << (16 - bit_precision - 1);
> >+ val >>= 16 - bit_precision;
> >+ }
> > return clamp_val(val, 0, max);
> > }
>
--
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch
More information about the dri-devel
mailing list