exynos: fix G2D_DOUBLE_TO_FIXED for non-integer input
authorTobias Jakobi <tjakobi@math.uni-bielefeld.de>
Sun, 1 Jun 2014 16:04:05 +0000 (18:04 +0200)
committerRob Clark <robclark@freedesktop.org>
Fri, 20 Jun 2014 19:53:01 +0000 (15:53 -0400)
The hardware accepts scaling factors formatted in a
fixed-point format. The current macro casts to integer
first, then multiplies by the fp conversion factor.

This does not make any sense. In particular, truly
'fractional' inputs, like 1.5, won't work that way.

Signed-off-by: Tobias Jakobi <tjakobi@math.uni-bielefeld.de>
Signed-off-by: Inki Dae <inki.dae@samsung.com>
exynos/fimg2d.h

index 1aac378..4785e2f 100644 (file)
@@ -25,7 +25,7 @@
 #define G2D_MAX_CMD_LIST_NR    64
 #define G2D_PLANE_MAX_NR       2
 
-#define G2D_DOUBLE_TO_FIXED(d)         ((unsigned int)(d) * 65536.0)
+#define G2D_DOUBLE_TO_FIXED(d)         ((unsigned int)((d) * 65536.0))
 
 enum e_g2d_color_mode {
        /* COLOR FORMAT */