summaryrefslogtreecommitdiffstats
path: root/hwc/hwc.c
diff options
context:
space:
mode:
authorLajos Molnar <molnar@ti.com>2011-10-06 22:04:32 -0500
committerErik Gilling <konkers@android.com>2011-12-08 14:19:06 -0800
commit3797fa989f5fee97caea2bbadf433a5a9ac03d8d (patch)
tree4545916d1eef58478549ebc31cce7910f0460b27 /hwc/hwc.c
parent00d8485d3d319633f410e52cab1562fe165af1e3 (diff)
downloadhardware_ti_omap4xxx-3797fa989f5fee97caea2bbadf433a5a9ac03d8d.zip
hardware_ti_omap4xxx-3797fa989f5fee97caea2bbadf433a5a9ac03d8d.tar.gz
hardware_ti_omap4xxx-3797fa989f5fee97caea2bbadf433a5a9ac03d8d.tar.bz2
hwc: use LCD's pixel aspect ratio
Now that LCD provides its dimension, use it instead of assuming 1:1 pixel ratio. Change-Id: I92e90132986aed66d43165d181789efaa2369bbd Signed-off-by: Lajos Molnar <molnar@ti.com>
Diffstat (limited to 'hwc/hwc.c')
-rw-r--r--hwc/hwc.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/hwc/hwc.c b/hwc/hwc.c
index 05ccdec..2a7d3e3 100644
--- a/hwc/hwc.c
+++ b/hwc/hwc.c
@@ -68,6 +68,7 @@ struct omap4_hwc_ext {
/* support */
struct ext_transform_t mirror; /* mirroring settings */
struct ext_transform_t dock; /* docking settings */
+ float lcd_xpy; /* pixel ratio for UI */
__u8 avoid_mode_change; /* use HDMI mode used for mirroring if possible */
/* state */
@@ -543,9 +544,7 @@ static void set_ext_matrix(omap4_hwc_ext_t *ext, struct hwc_rect region)
{
int orig_w = WIDTH(region);
int orig_h = HEIGHT(region);
-
- /* assume 1:1 lcd pixel ratio */
- float xpy = 1.;
+ float xpy = ext->lcd_xpy;
/* reorientation matrix is:
m = (center-from-target-center) * (scale-to-target) * (mirror) * (rotate) * (center-to-original-center) */
@@ -1202,7 +1201,7 @@ static int omap4_hwc_prepare(struct hwc_composer_device *dev, hwc_layer_list_t*
__u32 yres = HEIGHT(hwc_dev->ext.mirror_region);
if (hwc_dev->ext.current.rotation & 1)
swap(xres, yres);
- omap4_hwc_set_best_hdmi_mode(hwc_dev, xres, yres, 1.);
+ omap4_hwc_set_best_hdmi_mode(hwc_dev, xres, yres, hwc_dev->ext.lcd_xpy);
set_ext_matrix(&hwc_dev->ext, hwc_dev->ext.mirror_region);
}
}
@@ -1222,7 +1221,7 @@ static int omap4_hwc_prepare(struct hwc_composer_device *dev, hwc_layer_list_t*
__u32 xres = o->cfg.crop.w, yres = o->cfg.crop.h;
if ((hwc_dev->ext.current.rotation + o->cfg.rotation) & 1)
swap(xres, yres);
- float xpy = (float) o->cfg.win.w / o->cfg.win.h;
+ float xpy = hwc_dev->ext.lcd_xpy * o->cfg.win.w / o->cfg.win.h;
if (o->cfg.rotation & 1)
xpy = o->cfg.crop.h / xpy / o->cfg.crop.w;
else
@@ -1477,8 +1476,8 @@ static void handle_hotplug(omap4_hwc_device_t *hwc_dev, int state)
__u32 yres = HEIGHT(ext->mirror_region);
if (ext->mirror.rotation & 1)
swap(xres, yres);
- ext->mirror_mode = 0;
- int res = omap4_hwc_set_best_hdmi_mode(hwc_dev, xres, yres, 1.);
+ ext->mirror_mode = 0;
+ int res = omap4_hwc_set_best_hdmi_mode(hwc_dev, xres, yres, ext->lcd_xpy);
if (!res) {
ext->mirror_mode = ext->last_mode;
ioctl(hwc_dev->hdmi_fb_fd, FBIOBLANK, FB_BLANK_UNBLANK);
@@ -1668,6 +1667,8 @@ static int omap4_hwc_device_open(const hw_module_t* module, const char* name,
err = -errno;
goto done;
}
+ hwc_dev->ext.lcd_xpy = (float) hwc_dev->fb_dis.width_in_mm / hwc_dev->fb_dis.timings.x_res /
+ hwc_dev->fb_dis.height_in_mm * hwc_dev->fb_dis.timings.y_res;
if (pipe(hwc_dev->pipe_fds) == -1) {
LOGE("failed to event pipe (%d): %m", errno);