提交 0b4d7cbf 编写于 作者: K Kumar, Mahesh 提交者: Maarten Lankhorst

drm/i915: Fixed point fixed16 wrapper cleanup

As per suggestion from Jani, cleanup the code. Cleanup includes
 - Instead of left shifting & check, compare with U32/16_MAX
 - Use typecast instead of clamp_t
Signed-off-by: NMahesh Kumar <mahesh1.kumar@intel.com>
Cc: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: NJani Nikula <jani.nikula@intel.com>
Reviewed-by: NMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Signed-off-by: NMaarten Lankhorst <maarten.lankhorst@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20170817134529.2839-2-mahesh1.kumar@intel.com
上级 c9636244
...@@ -126,7 +126,7 @@ static inline uint_fixed_16_16_t u32_to_fixed16(uint32_t val) ...@@ -126,7 +126,7 @@ static inline uint_fixed_16_16_t u32_to_fixed16(uint32_t val)
{ {
uint_fixed_16_16_t fp; uint_fixed_16_16_t fp;
WARN_ON(val >> 16); WARN_ON(val > U16_MAX);
fp.val = val << 16; fp.val = val << 16;
return fp; return fp;
...@@ -163,8 +163,8 @@ static inline uint_fixed_16_16_t max_fixed16(uint_fixed_16_16_t max1, ...@@ -163,8 +163,8 @@ static inline uint_fixed_16_16_t max_fixed16(uint_fixed_16_16_t max1,
static inline uint_fixed_16_16_t clamp_u64_to_fixed16(uint64_t val) static inline uint_fixed_16_16_t clamp_u64_to_fixed16(uint64_t val)
{ {
uint_fixed_16_16_t fp; uint_fixed_16_16_t fp;
WARN_ON(val >> 32); WARN_ON(val > U32_MAX);
fp.val = clamp_t(uint32_t, val, 0, ~0); fp.val = (uint32_t) val;
return fp; return fp;
} }
...@@ -181,8 +181,8 @@ static inline uint32_t mul_round_up_u32_fixed16(uint32_t val, ...@@ -181,8 +181,8 @@ static inline uint32_t mul_round_up_u32_fixed16(uint32_t val,
intermediate_val = (uint64_t) val * mul.val; intermediate_val = (uint64_t) val * mul.val;
intermediate_val = DIV_ROUND_UP_ULL(intermediate_val, 1 << 16); intermediate_val = DIV_ROUND_UP_ULL(intermediate_val, 1 << 16);
WARN_ON(intermediate_val >> 32); WARN_ON(intermediate_val > U32_MAX);
return clamp_t(uint32_t, intermediate_val, 0, ~0); return (uint32_t) intermediate_val;
} }
static inline uint_fixed_16_16_t mul_fixed16(uint_fixed_16_16_t val, static inline uint_fixed_16_16_t mul_fixed16(uint_fixed_16_16_t val,
...@@ -211,8 +211,8 @@ static inline uint32_t div_round_up_u32_fixed16(uint32_t val, ...@@ -211,8 +211,8 @@ static inline uint32_t div_round_up_u32_fixed16(uint32_t val,
interm_val = (uint64_t)val << 16; interm_val = (uint64_t)val << 16;
interm_val = DIV_ROUND_UP_ULL(interm_val, d.val); interm_val = DIV_ROUND_UP_ULL(interm_val, d.val);
WARN_ON(interm_val >> 32); WARN_ON(interm_val > U32_MAX);
return clamp_t(uint32_t, interm_val, 0, ~0); return (uint32_t) interm_val;
} }
static inline uint_fixed_16_16_t mul_u32_fixed16(uint32_t val, static inline uint_fixed_16_16_t mul_u32_fixed16(uint32_t val,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册