summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Deucher <alex@botch2.(none)>2007-09-01 12:23:07 -0400
committerAlex Deucher <alex@botch2.(none)>2007-09-01 12:23:07 -0400
commit49933e2f7d590811f2bc8c0d51a09f3b7f14845e (patch)
tree9ae96e8ce4e6529965fcaf2fbb470901dce9f6a3
parentd49a60bc939c9f3e9d57c23e44263f5bb52f09fb (diff)
RADEON: automatically disable tiling if requested virtual desktop exceeds surface limits
Also, tweak default desktop sizes and add some informational messages
-rw-r--r--src/radeon_driver.c33
1 files changed, 17 insertions, 16 deletions
diff --git a/src/radeon_driver.c b/src/radeon_driver.c
index 9472f937..14d31bda 100644
--- a/src/radeon_driver.c
+++ b/src/radeon_driver.c
@@ -2692,30 +2692,28 @@ _X_EXPORT Bool RADEONPreInit(ScrnInfoPtr pScrn, int flags)
crtc_max_X = pScrn->display->virtualX;
crtc_max_Y = pScrn->display->virtualY;
if (info->allowColorTiling) {
- if (crtc_max_X > info->MaxSurfaceWidth)
- crtc_max_X = info->MaxSurfaceWidth;
- if (crtc_max_Y > info->MaxLines)
- crtc_max_Y = info->MaxLines;
- } else {
- if (crtc_max_X > 8192)
- crtc_max_X = 8192;
- if (crtc_max_Y > 8192)
- crtc_max_Y = 8192;
+ if (crtc_max_X > info->MaxSurfaceWidth ||
+ crtc_max_Y > info->MaxLines) {
+ info->allowColorTiling = FALSE;
+ xf86DrvMsg(pScrn->scrnIndex, X_WARNING,
+ "Requested desktop size exceeds surface limts for tiling, ColorTiling disabled\n");
+ }
}
+ if (crtc_max_X > 8192)
+ crtc_max_X = 8192;
+ if (crtc_max_Y > 8192)
+ crtc_max_Y = 8192;
} else {
- if (pScrn->videoRam < 16384) {
+ if (pScrn->videoRam <= 16384) {
crtc_max_X = 1600;
crtc_max_Y = 1200;
- } else if (pScrn->videoRam <= 32768) {
- crtc_max_X = 2048;
- crtc_max_Y = 1200;
- } else if (pScrn->videoRam > 32768) {
+ } else {
if (IS_R300_VARIANT) {
crtc_max_X = 2560;
- crtc_max_Y = 2048;
+ crtc_max_Y = 1200;
} else {
crtc_max_X = 2048;
- crtc_max_Y = 2048;
+ crtc_max_Y = 1200;
}
}
}
@@ -2723,6 +2721,9 @@ _X_EXPORT Bool RADEONPreInit(ScrnInfoPtr pScrn, int flags)
crtc_max_X, crtc_max_Y);
xf86DrvMsg(pScrn->scrnIndex, X_INFO,
"For a larger or smaller max desktop size, add a Virtual line to your xorg.conf\n");
+ xf86DrvMsg(pScrn->scrnIndex, X_INFO,
+ "If you are having trouble with 3D, "
+ "reduce the desktop size by adjusting the Virtual line to your xorg.conf\n");
/*xf86CrtcSetSizeRange (pScrn, 320, 200, info->MaxSurfaceWidth, info->MaxLines);*/
xf86CrtcSetSizeRange (pScrn, 320, 200, crtc_max_X, crtc_max_Y);