summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMichel Daenzer <michel@daenzer.net>2006-03-03 16:41:41 +0000
committerMichel Daenzer <michel@daenzer.net>2006-03-03 16:41:41 +0000
commite19ccfa18fee046c54d7a9401e4e0098b2300598 (patch)
tree0b211073b83ba8ed9a5e021b2b464d9ffeda4e3d /src
parentca00035eccb6e3495b27f8e64f2d016d8d2a9ce2 (diff)
Add Option "FBTexPercent" to override the amount of video RAM reserved for
OpenGL textures with EXA.
Diffstat (limited to 'src')
-rw-r--r--src/radeon_driver.c32
-rw-r--r--src/radeon_exa.c8
2 files changed, 32 insertions, 8 deletions
diff --git a/src/radeon_driver.c b/src/radeon_driver.c
index 4a078e8c..937545ff 100644
--- a/src/radeon_driver.c
+++ b/src/radeon_driver.c
@@ -1,5 +1,5 @@
/* $XFree86: xc/programs/Xserver/hw/xfree86/drivers/ati/radeon_driver.c,v 1.117 2004/02/19 22:38:12 tsi Exp $ */
-/* $XdotOrg: driver/xf86-video-ati/src/radeon_driver.c,v 1.90 2006/03/01 21:35:14 benh Exp $ */
+/* $XdotOrg: driver/xf86-video-ati/src/radeon_driver.c,v 1.91 2006-03-02 02:05:17 benh Exp $ */
/*
* Copyright 2000 ATI Technologies Inc., Markham, Ontario, and
* VA Linux Systems Inc., Fremont, California.
@@ -156,6 +156,9 @@ typedef enum {
OPTION_PAGE_FLIP,
OPTION_NO_BACKBUFFER,
OPTION_XV_DMA,
+#ifdef USE_EXA
+ OPTION_FBTEX_PERCENT,
+#endif
#endif
OPTION_PANEL_OFF,
OPTION_DDC_MODE,
@@ -218,6 +221,9 @@ static const OptionInfoRec RADEONOptions[] = {
{ OPTION_PAGE_FLIP, "EnablePageFlip", OPTV_BOOLEAN, {0}, FALSE },
{ OPTION_NO_BACKBUFFER, "NoBackBuffer", OPTV_BOOLEAN, {0}, FALSE },
{ OPTION_XV_DMA, "DMAForXv", OPTV_BOOLEAN, {0}, FALSE },
+#ifdef USE_EXA
+ { OPTION_FBTEX_PERCENT, "FBTexPercent", OPTV_INTEGER, {0}, FALSE },
+#endif
#endif
{ OPTION_PANEL_OFF, "PanelOff", OPTV_BOOLEAN, {0}, FALSE },
{ OPTION_DDC_MODE, "DDCMode", OPTV_BOOLEAN, {0}, FALSE },
@@ -5747,8 +5753,28 @@ _X_EXPORT Bool RADEONScreenInit(int scrnIndex, ScreenPtr pScreen,
RADEONTRACE(("Setting up accel memmap\n"));
#ifdef USE_EXA
- if (info->useEXA && !RADEONSetupMemEXA(pScreen))
- return FALSE;
+ if (info->useEXA) {
+#ifdef XF86DRI
+ /* Reserve approx. half of offscreen memory for local textures by
+ * default, can be overridden with Option "FBTexPercent".
+ * Round down to a whole number of texture regions.
+ */
+ info->textureSize = 50;
+
+ if (xf86GetOptValInteger(info->Options, OPTION_FBTEX_PERCENT,
+ &(info->textureSize))) {
+ if (info->textureSize < 0 || info->textureSize > 100) {
+ xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
+ "Illegal texture memory percentage: %dx, setting to default 50%\n",
+ info->textureSize);
+ info->textureSize = 50;
+ }
+ }
+#endif /* XF86DRI */
+
+ if (!RADEONSetupMemEXA(pScreen))
+ return FALSE;
+ }
#endif
#if defined(XF86DRI) && defined(USE_XAA)
diff --git a/src/radeon_exa.c b/src/radeon_exa.c
index 3cbadf01..56927c14 100644
--- a/src/radeon_exa.c
+++ b/src/radeon_exa.c
@@ -438,11 +438,9 @@ Bool RADEONSetupMemEXA (ScreenPtr pScreen)
depth_size / 1024, info->depthOffset);
}
- /* Reserve approx. half of remaining offscreen memory for local
- * textures. Round down to a whole number of texture regions.
- */
- info->textureSize = (info->exa.card.memorySize -
- info->exa.card.offScreenBase) / 2;
+ info->textureSize *= (info->exa.card.memorySize -
+ info->exa.card.offScreenBase) / 100;
+
l = RADEONLog2(info->textureSize / RADEON_NR_TEX_REGIONS);
if (l < RADEON_LOG_TEX_GRANULARITY)
l = RADEON_LOG_TEX_GRANULARITY;