2006-11-26 11:13:41 -07:00
|
|
|
/*
|
2011-11-05 07:32:40 -06:00
|
|
|
* Copyright © 2006 Intel Corporation
|
2006-11-26 11:13:41 -07:00
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
|
|
* to deal in the Software without restriction, including without limitation
|
|
|
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
|
|
* and/or sell copies of the Software, and to permit persons to whom the
|
|
|
|
* Software is furnished to do so, subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice (including the next
|
|
|
|
* paragraph) shall be included in all copies or substantial portions of the
|
|
|
|
* Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
|
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
* SOFTWARE.
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Eric Anholt <anholt@FreeBSD.org>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include <xorg-config.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "exa_priv.h"
|
|
|
|
|
|
|
|
#include "xf86str.h"
|
|
|
|
#include "xf86.h"
|
|
|
|
|
|
|
|
typedef struct _ExaXorgScreenPrivRec {
|
2012-06-10 07:21:05 -06:00
|
|
|
CloseScreenProcPtr SavedCloseScreen;
|
2013-06-07 11:28:45 -06:00
|
|
|
xf86EnableDisableFBAccessProc *SavedEnableDisableFBAccess;
|
2012-06-10 07:21:05 -06:00
|
|
|
OptionInfoPtr options;
|
2006-11-26 11:13:41 -07:00
|
|
|
} ExaXorgScreenPrivRec, *ExaXorgScreenPrivPtr;
|
|
|
|
|
2010-12-05 08:36:02 -07:00
|
|
|
static DevPrivateKeyRec exaXorgScreenPrivateKeyRec;
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2010-12-05 08:36:02 -07:00
|
|
|
#define exaXorgScreenPrivateKey (&exaXorgScreenPrivateKeyRec)
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
EXAOPT_MIGRATION_HEURISTIC,
|
|
|
|
EXAOPT_NO_COMPOSITE,
|
|
|
|
EXAOPT_NO_UTS,
|
|
|
|
EXAOPT_NO_DFS,
|
2008-11-02 08:26:08 -07:00
|
|
|
EXAOPT_OPTIMIZE_MIGRATION
|
2006-11-26 11:13:41 -07:00
|
|
|
} EXAOpts;
|
|
|
|
|
|
|
|
static const OptionInfoRec EXAOptions[] = {
|
2012-06-10 07:21:05 -06:00
|
|
|
{EXAOPT_MIGRATION_HEURISTIC, "MigrationHeuristic",
|
|
|
|
OPTV_ANYSTR, {0}, FALSE},
|
|
|
|
{EXAOPT_NO_COMPOSITE, "EXANoComposite",
|
|
|
|
OPTV_BOOLEAN, {0}, FALSE},
|
|
|
|
{EXAOPT_NO_UTS, "EXANoUploadToScreen",
|
|
|
|
OPTV_BOOLEAN, {0}, FALSE},
|
|
|
|
{EXAOPT_NO_DFS, "EXANoDownloadFromScreen",
|
|
|
|
OPTV_BOOLEAN, {0}, FALSE},
|
|
|
|
{EXAOPT_OPTIMIZE_MIGRATION, "EXAOptimizeMigration",
|
|
|
|
OPTV_BOOLEAN, {0}, FALSE},
|
|
|
|
{-1, NULL,
|
|
|
|
OPTV_NONE, {0}, FALSE}
|
2006-11-26 11:13:41 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
static Bool
|
2013-06-07 11:28:45 -06:00
|
|
|
exaXorgCloseScreen(ScreenPtr pScreen)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
2013-06-07 11:28:45 -06:00
|
|
|
ScrnInfoPtr pScrn = xf86ScreenToScrn(pScreen);
|
2008-11-02 08:26:08 -07:00
|
|
|
ExaXorgScreenPrivPtr pScreenPriv = (ExaXorgScreenPrivPtr)
|
2012-06-10 07:21:05 -06:00
|
|
|
dixLookupPrivate(&pScreen->devPrivates, exaXorgScreenPrivateKey);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScreen->CloseScreen = pScreenPriv->SavedCloseScreen;
|
|
|
|
|
|
|
|
pScrn->EnableDisableFBAccess = pScreenPriv->SavedEnableDisableFBAccess;
|
|
|
|
|
2010-12-05 08:36:02 -07:00
|
|
|
free(pScreenPriv->options);
|
|
|
|
free(pScreenPriv);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2013-06-07 11:28:45 -06:00
|
|
|
return pScreen->CloseScreen(pScreen);
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2013-06-07 11:28:45 -06:00
|
|
|
exaXorgEnableDisableFBAccess(ScrnInfoPtr pScrn, Bool enable)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
2013-06-07 11:28:45 -06:00
|
|
|
ScreenPtr pScreen = xf86ScrnToScreen(pScrn);
|
2008-11-02 08:26:08 -07:00
|
|
|
ExaXorgScreenPrivPtr pScreenPriv = (ExaXorgScreenPrivPtr)
|
2012-06-10 07:21:05 -06:00
|
|
|
dixLookupPrivate(&pScreen->devPrivates, exaXorgScreenPrivateKey);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
if (!enable)
|
2013-06-07 11:28:45 -06:00
|
|
|
exaEnableDisableFBAccess(pScreen, enable);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
if (pScreenPriv->SavedEnableDisableFBAccess)
|
2013-06-07 11:28:45 -06:00
|
|
|
pScreenPriv->SavedEnableDisableFBAccess(pScrn, enable);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
if (enable)
|
2013-06-07 11:28:45 -06:00
|
|
|
exaEnableDisableFBAccess(pScreen, enable);
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This will be called during exaDriverInit, giving us the chance to set options
|
|
|
|
* and hook in our EnableDisableFBAccess.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
exaDDXDriverInit(ScreenPtr pScreen)
|
|
|
|
{
|
|
|
|
ExaScreenPriv(pScreen);
|
2013-06-07 11:28:45 -06:00
|
|
|
ScrnInfoPtr pScrn = xf86ScreenToScrn(pScreen);
|
2006-11-26 11:13:41 -07:00
|
|
|
ExaXorgScreenPrivPtr pScreenPriv;
|
|
|
|
|
2010-12-05 08:36:02 -07:00
|
|
|
if (!dixRegisterPrivateKey(&exaXorgScreenPrivateKeyRec, PRIVATE_SCREEN, 0))
|
2012-06-10 07:21:05 -06:00
|
|
|
return;
|
2010-12-05 08:36:02 -07:00
|
|
|
|
|
|
|
pScreenPriv = calloc(1, sizeof(ExaXorgScreenPrivRec));
|
2006-11-26 11:13:41 -07:00
|
|
|
if (pScreenPriv == NULL)
|
2012-06-10 07:21:05 -06:00
|
|
|
return;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
pScreenPriv->options = xnfalloc(sizeof(EXAOptions));
|
2006-11-26 11:13:41 -07:00
|
|
|
memcpy(pScreenPriv->options, EXAOptions, sizeof(EXAOptions));
|
2012-06-10 07:21:05 -06:00
|
|
|
xf86ProcessOptions(pScrn->scrnIndex, pScrn->options, pScreenPriv->options);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
if (pExaScr->info->flags & EXA_OFFSCREEN_PIXMAPS) {
|
2012-06-10 07:21:05 -06:00
|
|
|
if (!(pExaScr->info->flags & EXA_HANDLES_PIXMAPS) &&
|
|
|
|
pExaScr->info->offScreenBase < pExaScr->info->memorySize) {
|
|
|
|
char *heuristicName;
|
|
|
|
|
|
|
|
heuristicName = xf86GetOptValString(pScreenPriv->options,
|
|
|
|
EXAOPT_MIGRATION_HEURISTIC);
|
|
|
|
if (heuristicName != NULL) {
|
|
|
|
if (strcmp(heuristicName, "greedy") == 0)
|
|
|
|
pExaScr->migration = ExaMigrationGreedy;
|
|
|
|
else if (strcmp(heuristicName, "always") == 0)
|
|
|
|
pExaScr->migration = ExaMigrationAlways;
|
|
|
|
else if (strcmp(heuristicName, "smart") == 0)
|
|
|
|
pExaScr->migration = ExaMigrationSmart;
|
|
|
|
else {
|
|
|
|
xf86DrvMsg(pScreen->myNum, X_WARNING,
|
|
|
|
"EXA: unknown migration heuristic %s\n",
|
|
|
|
heuristicName);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pExaScr->optimize_migration =
|
|
|
|
xf86ReturnOptValBool(pScreenPriv->options,
|
|
|
|
EXAOPT_OPTIMIZE_MIGRATION, TRUE);
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
if (xf86ReturnOptValBool(pScreenPriv->options, EXAOPT_NO_COMPOSITE, FALSE)) {
|
|
|
|
xf86DrvMsg(pScreen->myNum, X_CONFIG,
|
|
|
|
"EXA: Disabling Composite operation "
|
|
|
|
"(RENDER acceleration)\n");
|
|
|
|
pExaScr->info->CheckComposite = NULL;
|
|
|
|
pExaScr->info->PrepareComposite = NULL;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2008-11-02 08:26:08 -07:00
|
|
|
if (xf86ReturnOptValBool(pScreenPriv->options, EXAOPT_NO_UTS, FALSE)) {
|
2012-06-10 07:21:05 -06:00
|
|
|
xf86DrvMsg(pScreen->myNum, X_CONFIG, "EXA: Disabling UploadToScreen\n");
|
|
|
|
pExaScr->info->UploadToScreen = NULL;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2008-11-02 08:26:08 -07:00
|
|
|
if (xf86ReturnOptValBool(pScreenPriv->options, EXAOPT_NO_DFS, FALSE)) {
|
2012-06-10 07:21:05 -06:00
|
|
|
xf86DrvMsg(pScreen->myNum, X_CONFIG,
|
|
|
|
"EXA: Disabling DownloadFromScreen\n");
|
|
|
|
pExaScr->info->DownloadFromScreen = NULL;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2008-11-02 08:26:08 -07:00
|
|
|
dixSetPrivate(&pScreen->devPrivates, exaXorgScreenPrivateKey, pScreenPriv);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScreenPriv->SavedEnableDisableFBAccess = pScrn->EnableDisableFBAccess;
|
|
|
|
pScrn->EnableDisableFBAccess = exaXorgEnableDisableFBAccess;
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
pScreenPriv->SavedCloseScreen = pScreen->CloseScreen;
|
|
|
|
pScreen->CloseScreen = exaXorgCloseScreen;
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
static XF86ModuleVersionInfo exaVersRec = {
|
|
|
|
"exa",
|
|
|
|
MODULEVENDORSTRING,
|
|
|
|
MODINFOSTRING1,
|
|
|
|
MODINFOSTRING2,
|
|
|
|
XORG_VERSION_CURRENT,
|
|
|
|
EXA_VERSION_MAJOR, EXA_VERSION_MINOR, EXA_VERSION_RELEASE,
|
|
|
|
ABI_CLASS_VIDEODRV, /* requires the video driver ABI */
|
|
|
|
ABI_VIDEODRV_VERSION,
|
|
|
|
MOD_CLASS_NONE,
|
|
|
|
{0, 0, 0, 0}
|
2006-11-26 11:13:41 -07:00
|
|
|
};
|
|
|
|
|
2008-11-02 08:26:08 -07:00
|
|
|
_X_EXPORT XF86ModuleData exaModuleData = { &exaVersRec, NULL, NULL };
|