From d3f5911c85ccfaaf50c05ce80d56dac13fd15701 Mon Sep 17 00:00:00 2001 From: Daniel Stone Date: Fri, 26 Aug 2005 05:30:52 +0000 Subject: Only use vgahw symbols if we're building vgahw for this architecture. TODO: Fix this for the modular tree (maybe an unconditional yes?). Define that we're using a DPMS server and include DPMS headers. (Debian #024b) --- src/r128_driver.c | 42 +++++++++++++++++++++++++++++++++--------- src/radeon_driver.c | 41 +++++++++++++++++++++++++++++++---------- 2 files changed, 64 insertions(+), 19 deletions(-) diff --git a/src/r128_driver.c b/src/r128_driver.c index 33eade74..f812f9ab 100644 --- a/src/r128_driver.c +++ b/src/r128_driver.c @@ -93,10 +93,16 @@ #include "vbe.h" /* fbdevhw & vgahw */ -#include "fbdevhw.h" +#ifdef WITH_VGAHW #include "vgaHW.h" +#endif +#include "fbdevhw.h" #include "dixstruct.h" + /* DPMS support. */ +#define DPMS_SERVER +#include + #include "r128_chipset.h" #ifndef MAX @@ -187,6 +193,7 @@ R128RAMRec R128RAM[] = { /* Memory Specifications { 4, 4, 3, 3, 2, 3, 1, 16, 12, "64-bit DDR SGRAM" }, }; +#ifdef WITH_VGAHW static const char *vgahwSymbols[] = { "vgaHWFreeHWRec", "vgaHWGetHWRec", @@ -197,6 +204,7 @@ static const char *vgahwSymbols[] = { "vgaHWUnlock", NULL }; +#endif static const char *fbdevHWSymbols[] = { "fbdevHWInit", @@ -343,7 +351,10 @@ void R128LoaderRefSymLists(void) * Tell the loader about symbols from other modules that this module might * refer to. */ - xf86LoaderRefSymLists(vgahwSymbols, + xf86LoaderRefSymLists( +#ifdef WITH_VGAHW + vgahwSymbols, +#endif fbSymbols, xaaSymbols, ramdacSymbols, @@ -2098,12 +2109,13 @@ _X_EXPORT Bool R128PreInit(ScrnInfoPtr pScrn, int flags) xf86ProcessOptions(pScrn->scrnIndex, pScrn->options, info->Options); /* By default, don't do VGA IOs on ppc */ -#ifdef __powerpc__ +#if defined(__powerpc__) || !defined(WITH_VGAHW) info->VGAAccess = FALSE; #else info->VGAAccess = TRUE; #endif +#ifdef WITH_VGAHW xf86GetOptValBool(info->Options, OPTION_VGA_ACCESS, &info->VGAAccess); if (info->VGAAccess) { if (!xf86LoadSubModule(pScrn, "vgahw")) @@ -2121,6 +2133,10 @@ _X_EXPORT Bool R128PreInit(ScrnInfoPtr pScrn, int flags) " VGA module load skipped\n"); if (info->VGAAccess) vgaHWGetIOBase(VGAHWPTR(pScrn)); +#else + xf86DrvMsg(pScrn->scrnIndex, X_INFO, "VGAHW support not compiled, VGA " + "module load skipped\n"); +#endif @@ -2212,8 +2228,10 @@ _X_EXPORT Bool R128PreInit(ScrnInfoPtr pScrn, int flags) if (pInt10) xf86FreeInt10(pInt10); +#ifdef WITH_VGAHW if (info->VGAAccess) vgaHWFreeHWRec(pScrn); +#endif R128FreeRec(pScrn); return FALSE; } @@ -3355,23 +3373,25 @@ static void R128Save(ScrnInfoPtr pScrn) } if (!info->IsSecondary) { +#ifdef WITH_VGAHW if (info->VGAAccess) { vgaHWPtr hwp = VGAHWPTR(pScrn); vgaHWUnlock(hwp); -#if defined(__powerpc__) +# if defined(__powerpc__) /* temporary hack to prevent crashing on PowerMacs when trying to * read VGA fonts and colormap, will find a better solution * in the future. TODO: Check if there's actually some VGA stuff * setup in the card at all !! */ vgaHWSave(pScrn, &hwp->SavedReg, VGA_SR_MODE); /* Save mode only */ -#else +# else /* Save mode * & fonts & cmap */ vgaHWSave(pScrn, &hwp->SavedReg, VGA_SR_MODE | VGA_SR_FONTS); -#endif +# endif vgaHWLock(hwp); } +#endif save->dp_datatype = INREG(R128_DP_DATATYPE); save->gen_reset_cntl = INREG(R128_GEN_RESET_CNTL); @@ -3408,18 +3428,19 @@ static void R128Restore(ScrnInfoPtr pScrn) } R128RestoreMode(pScrn, restore); +#ifdef WITH_VGAHW if (info->VGAAccess) { vgaHWPtr hwp = VGAHWPTR(pScrn); if (!info->IsSecondary) { vgaHWUnlock(hwp); -#if defined(__powerpc__) +# if defined(__powerpc__) /* Temporary hack to prevent crashing on PowerMacs when trying to * write VGA fonts, will find a better solution in the future */ vgaHWRestore(pScrn, &hwp->SavedReg, VGA_SR_MODE ); -#else +# else vgaHWRestore(pScrn, &hwp->SavedReg, VGA_SR_MODE | VGA_SR_FONTS ); -#endif +# endif vgaHWLock(hwp); } else { R128EntPtr pR128Ent = R128EntPriv(pScrn); @@ -3439,6 +3460,7 @@ static void R128Restore(ScrnInfoPtr pScrn) } } } +#endif R128WaitForVerticalSync(pScrn); R128Unblank(pScrn); @@ -4432,8 +4454,10 @@ _X_EXPORT void R128FreeScreen(int scrnIndex, int flags) R128InfoPtr info = R128PTR(pScrn); R128TRACE(("R128FreeScreen\n")); +#ifdef WITH_VGAHW if (info->VGAAccess && xf86LoaderCheckSymbol("vgaHWFreeHWRec")) vgaHWFreeHWRec(pScrn); +#endif R128FreeRec(pScrn); } diff --git a/src/radeon_driver.c b/src/radeon_driver.c index 8974a339..b4d2e427 100644 --- a/src/radeon_driver.c +++ b/src/radeon_driver.c @@ -96,9 +96,15 @@ #include "xf86cmap.h" #include "vbe.h" - /* fbdevhw * vgaHW definitions */ -#include "fbdevhw.h" + /* fbdevhw & vgaHW definitions */ +#ifdef WITH_VGAHW #include "vgaHW.h" +#endif +#include "fbdevhw.h" + + /* DPMS support. */ +#define DPMS_SERVER +#include "extensions/dpms.h" #include "radeon_chipset.h" @@ -254,6 +260,7 @@ static const OptionInfoRec RADEONOptions[] = { _X_EXPORT const OptionInfoRec *RADEONOptionsWeak(void) { return RADEONOptions; } +#ifdef WITH_VGAHW static const char *vgahwSymbols[] = { "vgaHWFreeHWRec", "vgaHWGetHWRec", @@ -265,6 +272,7 @@ static const char *vgahwSymbols[] = { "vgaHWGetIOBase", NULL }; +#endif static const char *fbdevHWSymbols[] = { "fbdevHWInit", @@ -421,7 +429,10 @@ void RADEONLoaderRefSymLists(void) * Tell the loader about symbols from other modules that this module might * refer to. */ - xf86LoaderRefSymLists(vgahwSymbols, + xf86LoaderRefSymLists( +#ifdef WITH_VGAHW + vgahwSymbols, +#endif fbSymbols, xaaSymbols, #if 0 @@ -4590,12 +4601,13 @@ _X_EXPORT Bool RADEONPreInit(ScrnInfoPtr pScrn, int flags) xf86ProcessOptions(pScrn->scrnIndex, pScrn->options, info->Options); /* By default, don't do VGA IOs on ppc */ -#ifdef __powerpc__ +#if defined(__powerpc__) || !defined(WITH_VGAHW) info->VGAAccess = FALSE; #else info->VGAAccess = TRUE; #endif +#ifdef WITH_VGAHW xf86GetOptValBool(info->Options, OPTION_VGA_ACCESS, &info->VGAAccess); if (info->VGAAccess) { if (!xf86LoadSubModule(pScrn, "vgahw")) @@ -4613,6 +4625,7 @@ _X_EXPORT Bool RADEONPreInit(ScrnInfoPtr pScrn, int flags) " VGA module load skipped\n"); if (info->VGAAccess) vgaHWGetIOBase(VGAHWPTR(pScrn)); +#endif if (!RADEONPreInitWeight(pScrn)) @@ -4834,8 +4847,10 @@ fail: if (pInt10) xf86FreeInt10(pInt10); +#ifdef WITH_VGAHW if (info->VGAAccess) vgaHWFreeHWRec(pScrn); +#endif fail2: if(info->MMIO) RADEONUnmapMMIO(pScrn); @@ -6542,23 +6557,25 @@ static void RADEONSave(ScrnInfoPtr pScrn) } if (!info->IsSecondary) { +#ifdef WITH_VGAHW if (info->VGAAccess) { vgaHWPtr hwp = VGAHWPTR(pScrn); vgaHWUnlock(hwp); -#if defined(__powerpc__) +# if defined(__powerpc__) /* temporary hack to prevent crashing on PowerMacs when trying to * read VGA fonts and colormap, will find a better solution * in the future. TODO: Check if there's actually some VGA stuff * setup in the card at all !! */ vgaHWSave(pScrn, &hwp->SavedReg, VGA_SR_MODE); /* Save mode only */ -#else +# else /* Save mode * & fonts & cmap */ vgaHWSave(pScrn, &hwp->SavedReg, VGA_SR_MODE | VGA_SR_FONTS); -#endif +# endif vgaHWLock(hwp); } +#endif save->dp_datatype = INREG(RADEON_DP_DATATYPE); save->rbbm_soft_reset = INREG(RADEON_RBBM_SOFT_RESET); save->clock_cntl_index = INREG(RADEON_CLOCK_CNTL_INDEX); @@ -6619,18 +6636,19 @@ static void RADEONRestore(ScrnInfoPtr pScrn) usleep(100000); #endif +#ifdef WITH_VGAHW if (info->VGAAccess) { vgaHWPtr hwp = VGAHWPTR(pScrn); if (!info->IsSecondary) { vgaHWUnlock(hwp); -#if defined(__powerpc__) +# if defined(__powerpc__) /* Temporary hack to prevent crashing on PowerMacs when trying to * write VGA fonts, will find a better solution in the future */ vgaHWRestore(pScrn, &hwp->SavedReg, VGA_SR_MODE ); -#else +# else vgaHWRestore(pScrn, &hwp->SavedReg, VGA_SR_MODE | VGA_SR_FONTS ); -#endif +# endif vgaHWLock(hwp); } else { RADEONEntPtr pRADEONEnt = RADEONEntPriv(pScrn); @@ -6650,6 +6668,7 @@ static void RADEONRestore(ScrnInfoPtr pScrn) } } } +#endif RADEONUnblank(pScrn); #if 0 @@ -8351,8 +8370,10 @@ _X_EXPORT void RADEONFreeScreen(int scrnIndex, int flags) } } +#ifdef WITH_VGAHW if (info->VGAAccess && xf86LoaderCheckSymbol("vgaHWFreeHWRec")) vgaHWFreeHWRec(pScrn); +#endif RADEONFreeRec(pScrn); } -- cgit v1.2.3