mirror of
https://github.com/archlinuxarm/PKGBUILDs.git
synced 2024-12-28 23:21:53 +00:00
325 lines
11 KiB
Diff
325 lines
11 KiB
Diff
From 85e4bdb8f375b343011d07e685a9cac9108f3734 Mon Sep 17 00:00:00 2001
|
|
From: Eino-Ville Talvala <talvala@stanford.edu>
|
|
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 <dos@dosowisko.net>
|
|
Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
|
|
---
|
|
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 <stdint.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);
|
|
|
|
/* 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
|
|
|