From 85e4bdb8f375b343011d07e685a9cac9108f3734 Mon Sep 17 00:00:00 2001 From: Eino-Ville Talvala Date: Tue, 23 Aug 2011 18:37:01 +0200 Subject: [PATCH 5/7] Attempt to fix VRFB Upstream-Status: Pending http://dominion.thruhere.net/git/cgit.cgi/xf86-video-omapfb/commit/?h=koen/fixups&id=6833fc9f795265e4943d248103fbaf3463b515d6 Signed-off-by: Sebastian Krzyszkowiak Signed-off-by: Martin Jansa --- src/image-format-conversions.c | 4 +-- src/image-format-conversions.h | 2 +- src/omapfb-driver.c | 28 +++++++++++++--- src/omapfb-xv-blizzard.c | 1 + src/omapfb-xv-generic.c | 72 +++++++++++++++++++++++++++++++++--------- src/omapfb-xv.c | 3 ++ 6 files changed, 88 insertions(+), 22 deletions(-) diff --git a/src/image-format-conversions.c b/src/image-format-conversions.c index dcefa9b..d43427d 100644 --- a/src/image-format-conversions.c +++ b/src/image-format-conversions.c @@ -38,13 +38,13 @@ #include "image-format-conversions.h" /* Basic line-based copy for packed formats */ -void packed_line_copy(int w, int h, int stride, uint8_t *src, uint8_t *dest) +void packed_line_copy(int w, int h, int src_stride, int dst_stride, uint8_t *src, uint8_t *dest) { int i; int len = w * 2; for (i = 0; i < h; i++) { - memcpy(dest + i * len, src + i * stride, len); + memcpy(dest + i * dst_stride, src + i * src_stride, len); } } diff --git a/src/image-format-conversions.h b/src/image-format-conversions.h index 584896a..ba7caf2 100644 --- a/src/image-format-conversions.h +++ b/src/image-format-conversions.h @@ -27,7 +27,7 @@ #include /* Basic line-based copy for packed formats */ -void packed_line_copy(int w, int h, int stride, uint8_t *src, uint8_t *dest); +void packed_line_copy(int w, int h, int src_stride, int dst_stride, uint8_t *src, uint8_t *dest); /* Basic C implementation of YV12/I420 to UYVY conversion */ void uv12_to_uyvy(int w, int h, int y_pitch, int uv_pitch, uint8_t *y_p, uint8_t *u_p, uint8_t *v_p, uint8_t *dest); diff --git a/src/omapfb-driver.c b/src/omapfb-driver.c index 48aa09c..07989f5 100644 --- a/src/omapfb-driver.c +++ b/src/omapfb-driver.c @@ -66,6 +66,7 @@ #define OMAPFB_VERSION 1000 #define OMAPFB_DRIVER_NAME "OMAPFB" #define OMAPFB_NAME "omapfb" +#define ENFORCE_MODES static Bool OMAPFBProbe(DriverPtr drv, int flags); static Bool OMAPFBPreInit(ScrnInfoPtr pScrn, int flags); @@ -105,11 +106,13 @@ static SymTabRec OMAPFBChipsets[] = { typedef enum { OPTION_ACCELMETHOD, OPTION_FB, + OPTION_ROTATE, } FBDevOpts; static const OptionInfoRec OMAPFBOptions[] = { { OPTION_ACCELMETHOD, "AccelMethod", OPTV_STRING, {0}, FALSE }, { OPTION_FB, "fb", OPTV_STRING, {0}, FALSE }, + { OPTION_ROTATE, "rotation", OPTV_STRING, {0}, FALSE }, { -1, NULL, OPTV_NONE, {0}, FALSE } }; @@ -286,6 +289,7 @@ OMAPFBPreInit(ScrnInfoPtr pScrn, int flags) { OMAPFBPtr ofb; EntityInfoPtr pEnt; + char *rotate; rgb zeros = { 0, 0, 0 }; struct stat st; @@ -379,6 +383,8 @@ OMAPFBPreInit(ScrnInfoPtr pScrn, int flags) pScrn->progClock = TRUE; pScrn->chipset = "omapfb"; + xf86DrvMsg(pScrn->scrnIndex, X_INFO, "Rotate test version 0.02\n"); + /* Start with configured virtual size */ pScrn->virtualX = pScrn->display->virtualX; pScrn->virtualY = pScrn->display->virtualY; @@ -496,12 +502,21 @@ OMAPFBScreenInit(int scrnIndex, ScreenPtr pScreen, int argc, char **argv) ofb->CloseScreen = pScreen->CloseScreen; pScreen->CloseScreen = OMAPFBCloseScreen; + /* Enforce the default mode (this is silly I guess) */ +#ifdef ENFORCE_MODES + //xf86DrvMsg(pScrn->scrnIndex, X_INFO, "Enforcing modes\n"); + //set_mode(ofb, &ofb->default_mode); + //pScrn->displayWidth = ofb->fixed_info.line_length / + // (ofb->state_info.bits_per_pixel>>3); //ofb->state_info.xres; +#endif + /* Map our framebuffer memory */ + ofb->mem_info.size = ofb->fixed_info.line_length * ofb->state_info.yres; ofb->fb = mmap (NULL, ofb->mem_info.size, PROT_READ | PROT_WRITE, MAP_SHARED, ofb->fd, 0); - if (ofb->fb == NULL) { - xf86DrvMsg(scrnIndex, X_ERROR, "Mapping framebuffer memory failed\n"); + if (ofb->fb == MAP_FAILED) { + xf86DrvMsg(scrnIndex, X_ERROR, "Mapping framebuffer memory failed, wanted %d bytes.\n", ofb->mem_info.size); return FALSE; } @@ -578,8 +593,13 @@ OMAPFBScreenInit(int scrnIndex, ScreenPtr pScreen, int argc, char **argv) } else if (!ofb->dss) { ofb->plane_info.enabled = 1; - ofb->plane_info.out_width = ofb->state_info.xres; - ofb->plane_info.out_height = ofb->state_info.yres; + if (ofb->state_info.rotate == 0 || ofb->state_info.rotate == 2) { + ofb->plane_info.out_width = ofb->state_info.xres; + ofb->plane_info.out_height = ofb->state_info.yres; + } else { + ofb->plane_info.out_width = ofb->state_info.yres; + ofb->plane_info.out_height = ofb->state_info.xres; + } if (ioctl (ofb->fd, OMAPFB_SETUP_PLANE, &ofb->plane_info)) { xf86DrvMsg(scrnIndex, X_ERROR, diff --git a/src/omapfb-xv-blizzard.c b/src/omapfb-xv-blizzard.c index 406ffc6..b71d2aa 100644 --- a/src/omapfb-xv-blizzard.c +++ b/src/omapfb-xv-blizzard.c @@ -220,6 +220,7 @@ int OMAPFBXVPutImageBlizzard (ScrnInfoPtr pScrn, packed_line_copy(src_w & ~3, src_h & ~3, ((src_w + 1) & ~1) * 2, + ofb->port->fixed_info.line_length, (uint8_t*)buf, (uint8_t*)ofb->port->fb); break; diff --git a/src/omapfb-xv-generic.c b/src/omapfb-xv-generic.c index e6f89fe..b33f344 100644 --- a/src/omapfb-xv-generic.c +++ b/src/omapfb-xv-generic.c @@ -62,7 +62,7 @@ int OMAPXVAllocPlane(ScrnInfoPtr pScrn) { OMAPFBPtr ofb = OMAPFB(pScrn); - /* The memory size is already set in OMAPFBXVQueryImageAttributes */ + /* The memory size is already set before we get here */ if (ioctl(ofb->port->fd, OMAPFB_SETUP_MEM, &ofb->port->mem_info) != 0) { xf86DrvMsg(pScrn->scrnIndex, X_ERROR, "Failed to allocate video plane memory\n"); @@ -73,19 +73,20 @@ int OMAPXVAllocPlane(ScrnInfoPtr pScrn) ofb->port->fb = mmap (NULL, ofb->port->mem_info.size, PROT_READ | PROT_WRITE, MAP_SHARED, ofb->port->fd, 0); - if (ofb->port->fb == NULL) { + if (ofb->port->fb == MAP_FAILED) { xf86DrvMsg(pScrn->scrnIndex, X_ERROR, "Mapping video memory failed\n"); return XvBadAlloc; } /* Update the state info */ + /* Let's not - it's bad if (ioctl (ofb->port->fd, FBIOGET_VSCREENINFO, &ofb->port->state_info)) { xf86Msg(X_ERROR, "%s: Reading state info failed\n", __FUNCTION__); return XvBadAlloc; } - + */ return Success; } @@ -93,6 +94,7 @@ int OMAPXVAllocPlane(ScrnInfoPtr pScrn) int OMAPXVSetupVideoPlane(ScrnInfoPtr pScrn) { OMAPFBPtr ofb = OMAPFB(pScrn); + int ret; if (ioctl (ofb->port->fd, FBIOPUT_VSCREENINFO, &ofb->port->state_info)) { @@ -104,6 +106,31 @@ int OMAPXVSetupVideoPlane(ScrnInfoPtr pScrn) xf86Msg(X_ERROR, "%s: Reading state info failed\n", __FUNCTION__); return XvBadAlloc; } + /* Changing rotation/nonstd flags can change the fixed info! */ + if (ioctl (ofb->port->fd, FBIOGET_FSCREENINFO, &ofb->port->fixed_info)) + { + xf86Msg(X_ERROR, "%s: Reading state info failed\n", __FUNCTION__); + return XvBadAlloc; + } + /* Correct fixed info requires recalculation of needed memory */ + ofb->port->mem_info.size = ofb->port->fixed_info.line_length * ofb->port->state_info.yres; + + /* Allocate buffer memory */ + ret = OMAPXVAllocPlane(pScrn); + if (ret != Success) + return ret; + + /* Workaround for reset of mode after memory allo */ + if (ioctl (ofb->port->fd, FBIOPUT_VSCREENINFO, &ofb->port->state_info)) + { + xf86Msg(X_ERROR, "%s: setting state info failed\n", __FUNCTION__); + return XvBadAlloc; + } + if (ioctl (ofb->port->fd, FBIOGET_VSCREENINFO, &ofb->port->state_info)) + { + xf86Msg(X_ERROR, "%s: Reading state info failed\n", __FUNCTION__); + return XvBadAlloc; + } if(ioctl(ofb->port->fd, OMAPFB_SETUP_PLANE, &ofb->port->plane_info) != 0) { @@ -124,6 +151,8 @@ int OMAPFBXVPutImageGeneric (ScrnInfoPtr pScrn, DrawablePtr pDraw) { OMAPFBPtr ofb = OMAPFB(pScrn); + short drw_temp; + short rot_xres, rot_yres; if (!ofb->port->plane_info.enabled || ofb->port->update_window.x != src_x @@ -163,13 +192,6 @@ int OMAPFBXVPutImageGeneric (ScrnInfoPtr pScrn, return Success; } - /* If we don't have the plane running, enable it */ - if (!ofb->port->plane_info.enabled) { - ret = OMAPXVAllocPlane(pScrn); - if (ret != Success) - return ret; - } - /* Set up the state info, xres and yres will be used for * scaling to the values in the plane info struct */ @@ -179,12 +201,31 @@ int OMAPFBXVPutImageGeneric (ScrnInfoPtr pScrn, ofb->port->state_info.yres_virtual = 0; ofb->port->state_info.xoffset = 0; ofb->port->state_info.yoffset = 0; - ofb->port->state_info.rotate = 0; + //ofb->port->state_info.rotate = 0; ofb->port->state_info.grayscale = 0; ofb->port->state_info.activate = FB_ACTIVATE_NOW; ofb->port->state_info.bits_per_pixel = 0; ofb->port->state_info.nonstd = xv_to_omapfb_format(image); + /* Plane info does not rotate with state_info */ + if (ofb->port->state_info.rotate == 1 || + ofb->port->state_info.rotate == 3) { + drw_temp = drw_x; + drw_x = drw_y; + drw_y = drw_temp; + + drw_temp = drw_w; + drw_w = drw_h; + drw_h = drw_temp; + + rot_xres = ofb->port->state_info.yres; + rot_yres = ofb->port->state_info.xres; + } else { + rot_xres = ofb->port->state_info.xres; + rot_yres = ofb->port->state_info.yres; + } + + /* Set up the video plane info */ ofb->port->plane_info.enabled = 1; ofb->port->plane_info.pos_x = drw_x; @@ -193,13 +234,13 @@ int OMAPFBXVPutImageGeneric (ScrnInfoPtr pScrn, ofb->port->plane_info.out_height = drw_h & ~15; /* Cap output to screen size */ - if (ofb->port->plane_info.out_width > ofb->state_info.xres) { + if (ofb->port->plane_info.out_width > rot_xres) { ofb->port->plane_info.pos_x = 0; - ofb->port->plane_info.out_width = ofb->state_info.xres; + ofb->port->plane_info.out_width = rot_xres; } - if (ofb->port->plane_info.out_height > ofb->state_info.yres) { + if (ofb->port->plane_info.out_height > rot_yres) { ofb->port->plane_info.pos_y = 0; - ofb->port->plane_info.out_height = ofb->state_info.yres; + ofb->port->plane_info.out_height = rot_yres; } ret = OMAPXVSetupVideoPlane(pScrn); @@ -223,6 +264,7 @@ int OMAPFBXVPutImageGeneric (ScrnInfoPtr pScrn, packed_line_copy(src_w & ~15, src_h & ~15, ((src_w + 1) & ~1) * 2, + ofb->port->fixed_info.line_length, (uint8_t*)buf, (uint8_t*)ofb->port->fb); break; diff --git a/src/omapfb-xv.c b/src/omapfb-xv.c index 1df651e..0fee2c6 100644 --- a/src/omapfb-xv.c +++ b/src/omapfb-xv.c @@ -169,8 +169,11 @@ static int OMAPFBXVQueryImageAttributes (ScrnInfoPtr pScrn, h = *height; w = (w + 1) & ~1; + + /* Can't calculate these here - don't know line length ofb->port->mem_info.size = w << 1; ofb->port->mem_info.size *= h; + */ return size; } -- 2.3.0