2006-11-26 11:13:41 -07:00
|
|
|
/*
|
|
|
|
* Copyright (c) 1999-2003 by The XFree86 Project, Inc.
|
|
|
|
*
|
|
|
|
* 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 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 COPYRIGHT HOLDER(S) OR AUTHOR(S) 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.
|
|
|
|
*
|
|
|
|
* Except as contained in this notice, the name of the copyright holder(s)
|
|
|
|
* and author(s) shall not be used in advertising or otherwise to promote
|
|
|
|
* the sale, use or other dealings in this Software without prior written
|
|
|
|
* authorization from the copyright holder(s) and author(s).
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file contains the VidMode functions required by the extension.
|
|
|
|
* These have been added to avoid the need for the higher level extension
|
|
|
|
* code to access the private XFree86 data structures directly. Wherever
|
|
|
|
* possible this code uses the functions in xf86Mode.c to do the work,
|
|
|
|
* so that two version of code that do similar things don't have to be
|
|
|
|
* maintained.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef HAVE_XORG_CONFIG_H
|
|
|
|
#include <xorg-config.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <X11/X.h>
|
|
|
|
#include "os.h"
|
|
|
|
#include "xf86.h"
|
|
|
|
#include "xf86Priv.h"
|
|
|
|
|
|
|
|
#ifdef XF86VIDMODE
|
|
|
|
#include "vidmodeproc.h"
|
|
|
|
#include "xf86cmap.h"
|
|
|
|
|
2010-12-05 08:36:02 -07:00
|
|
|
static DevPrivateKeyRec VidModeKeyRec;
|
2009-09-06 13:44:18 -06:00
|
|
|
static DevPrivateKey VidModeKey;
|
2006-11-26 11:13:41 -07:00
|
|
|
static int VidModeCount = 0;
|
2013-06-07 11:28:45 -06:00
|
|
|
static Bool VidModeClose(ScreenPtr pScreen);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2008-11-02 08:26:08 -07:00
|
|
|
#define VMPTR(p) ((VidModePtr)dixLookupPrivate(&(p)->devPrivates, VidModeKey))
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeExtensionInit(ScreenPtr pScreen)
|
|
|
|
{
|
|
|
|
#ifdef XF86VIDMODE
|
|
|
|
VidModePtr pVidMode;
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
if (!xf86GetVidModeEnabled()) {
|
2012-06-10 07:21:05 -06:00
|
|
|
DebugF("!xf86GetVidModeEnabled()\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2010-12-05 08:36:02 -07:00
|
|
|
VidModeKey = &VidModeKeyRec;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2010-12-05 08:36:02 -07:00
|
|
|
if (!dixRegisterPrivateKey(&VidModeKeyRec, PRIVATE_SCREEN, 0))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2010-12-05 08:36:02 -07:00
|
|
|
pVidMode = calloc(sizeof(VidModeRec), 1);
|
|
|
|
if (!pVidMode)
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2010-12-05 08:36:02 -07:00
|
|
|
|
|
|
|
dixSetPrivate(&pScreen->devPrivates, VidModeKey, pVidMode);
|
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
pVidMode->Flags = 0;
|
|
|
|
pVidMode->Next = NULL;
|
|
|
|
pVidMode->CloseScreen = pScreen->CloseScreen;
|
|
|
|
pScreen->CloseScreen = VidModeClose;
|
|
|
|
VidModeCount++;
|
|
|
|
return TRUE;
|
|
|
|
#else
|
2010-07-27 13:02:24 -06:00
|
|
|
DebugF("no vidmode extension\n");
|
2006-11-26 11:13:41 -07:00
|
|
|
return FALSE;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef XF86VIDMODE
|
|
|
|
|
|
|
|
static Bool
|
2013-06-07 11:28:45 -06:00
|
|
|
VidModeClose(ScreenPtr pScreen)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
VidModePtr pVidMode = VMPTR(pScreen);
|
|
|
|
|
|
|
|
/* This shouldn't happen */
|
|
|
|
if (!pVidMode)
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScreen->CloseScreen = pVidMode->CloseScreen;
|
|
|
|
|
|
|
|
if (--VidModeCount == 0) {
|
2012-06-10 07:21:05 -06:00
|
|
|
free(dixLookupPrivate(&pScreen->devPrivates, VidModeKey));
|
|
|
|
dixSetPrivate(&pScreen->devPrivates, VidModeKey, NULL);
|
|
|
|
VidModeKey = NULL;
|
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
|
|
|
}
|
|
|
|
|
|
|
|
Bool
|
|
|
|
VidModeAvailable(int scrnIndex)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
VidModePtr pVidMode;
|
|
|
|
|
2008-11-02 08:26:08 -07:00
|
|
|
if (VidModeKey == NULL) {
|
2012-06-10 07:21:05 -06:00
|
|
|
DebugF("VidModeKey == NULL\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
if (pScrn == NULL) {
|
2012-06-10 07:21:05 -06:00
|
|
|
DebugF("pScrn == NULL\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
pVidMode = VMPTR(pScrn->pScreen);
|
|
|
|
if (pVidMode)
|
2012-06-10 07:21:05 -06:00
|
|
|
return TRUE;
|
2006-11-26 11:13:41 -07:00
|
|
|
else {
|
2012-06-10 07:21:05 -06:00
|
|
|
DebugF("pVidMode == NULL\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeGetCurrentModeline(int scrnIndex, void **mode, int *dotClock)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
|
2008-11-02 08:26:08 -07:00
|
|
|
if (pScrn->currentMode) {
|
2014-09-27 11:52:59 -06:00
|
|
|
*mode = (void *) (pScrn->currentMode);
|
2012-06-10 07:21:05 -06:00
|
|
|
*dotClock = pScrn->currentMode->Clock;
|
2008-11-02 08:26:08 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
return TRUE;
|
2008-11-02 08:26:08 -07:00
|
|
|
}
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
int
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeGetDotClock(int scrnIndex, int Clock)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return 0;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
if ((pScrn->progClock) || (Clock >= MAXCLOCKS))
|
2012-06-10 07:21:05 -06:00
|
|
|
return Clock;
|
|
|
|
else
|
|
|
|
return pScrn->clock[Clock];
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
int
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeGetNumOfClocks(int scrnIndex, Bool *progClock)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return 0;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
2012-06-10 07:21:05 -06:00
|
|
|
if (pScrn->progClock) {
|
|
|
|
*progClock = TRUE;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
*progClock = FALSE;
|
|
|
|
return pScrn->numClocks;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeGetClocks(int scrnIndex, int *Clocks)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
|
|
|
|
if (pScrn->progClock)
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
for (i = 0; i < pScrn->numClocks; i++)
|
|
|
|
*Clocks++ = pScrn->clock[i];
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeGetFirstModeline(int scrnIndex, void **mode, int *dotClock)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
VidModePtr pVidMode;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
2011-12-18 09:08:59 -07:00
|
|
|
if (pScrn->modes == NULL)
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2011-12-18 09:08:59 -07:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
pVidMode = VMPTR(pScrn->pScreen);
|
|
|
|
pVidMode->First = pScrn->modes;
|
2012-06-10 07:21:05 -06:00
|
|
|
pVidMode->Next = pVidMode->First->next;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
if (pVidMode->First->status == MODE_OK) {
|
2014-09-27 11:52:59 -06:00
|
|
|
*mode = (void *) (pVidMode->First);
|
2012-06-10 07:21:05 -06:00
|
|
|
*dotClock = VidModeGetDotClock(scrnIndex, pVidMode->First->Clock);
|
|
|
|
return TRUE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
return VidModeGetNextModeline(scrnIndex, mode, dotClock);
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeGetNextModeline(int scrnIndex, void **mode, int *dotClock)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
VidModePtr pVidMode;
|
|
|
|
DisplayModePtr p;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
pVidMode = VMPTR(pScrn->pScreen);
|
|
|
|
|
|
|
|
for (p = pVidMode->Next; p != NULL && p != pVidMode->First; p = p->next) {
|
2012-06-10 07:21:05 -06:00
|
|
|
if (p->status == MODE_OK) {
|
|
|
|
pVidMode->Next = p->next;
|
2014-09-27 11:52:59 -06:00
|
|
|
*mode = (void *) p;
|
2012-06-10 07:21:05 -06:00
|
|
|
*dotClock = VidModeGetDotClock(scrnIndex, p->Clock);
|
|
|
|
return TRUE;
|
|
|
|
}
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeDeleteModeline(int scrnIndex, void *mode)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if ((mode == NULL) || (!VidModeAvailable(scrnIndex)))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
2012-06-10 07:21:05 -06:00
|
|
|
xf86DeleteMode(&(pScrn->modes), (DisplayModePtr) mode);
|
2006-11-26 11:13:41 -07:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeZoomViewport(int scrnIndex, int zoom)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
xf86ZoomViewport(pScrn->pScreen, zoom);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeSetViewPort(int scrnIndex, int x, int y)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
2012-06-10 07:21:05 -06:00
|
|
|
pScrn->frameX0 = min(max(x, 0),
|
|
|
|
pScrn->virtualX - pScrn->currentMode->HDisplay);
|
2006-11-26 11:13:41 -07:00
|
|
|
pScrn->frameX1 = pScrn->frameX0 + pScrn->currentMode->HDisplay - 1;
|
2012-06-10 07:21:05 -06:00
|
|
|
pScrn->frameY0 = min(max(y, 0),
|
|
|
|
pScrn->virtualY - pScrn->currentMode->VDisplay);
|
2006-11-26 11:13:41 -07:00
|
|
|
pScrn->frameY1 = pScrn->frameY0 + pScrn->currentMode->VDisplay - 1;
|
|
|
|
if (pScrn->AdjustFrame != NULL)
|
2013-06-07 11:28:45 -06:00
|
|
|
(pScrn->AdjustFrame) (pScrn, pScrn->frameX0, pScrn->frameY0);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeGetViewPort(int scrnIndex, int *x, int *y)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
*x = pScrn->frameX0;
|
|
|
|
*y = pScrn->frameY0;
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeSwitchMode(int scrnIndex, void *mode)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
DisplayModePtr pTmpMode;
|
|
|
|
Bool retval;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
/* save in case we fail */
|
|
|
|
pTmpMode = pScrn->currentMode;
|
|
|
|
/* Force a mode switch */
|
|
|
|
pScrn->currentMode = NULL;
|
|
|
|
retval = xf86SwitchMode(pScrn->pScreen, mode);
|
|
|
|
/* we failed: restore it */
|
|
|
|
if (retval == FALSE)
|
2012-06-10 07:21:05 -06:00
|
|
|
pScrn->currentMode = pTmpMode;
|
2006-11-26 11:13:41 -07:00
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeLockZoom(int scrnIndex, Bool lock)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
|
|
|
|
if (xf86Info.dontZoom)
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
xf86LockZoom(pScrn->pScreen, lock);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeGetMonitor(int scrnIndex, void **monitor)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
2014-09-27 11:52:59 -06:00
|
|
|
*monitor = (void *) (pScrn->monitor);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
ModeStatus
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeCheckModeForMonitor(int scrnIndex, void *mode)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if ((mode == NULL) || (!VidModeAvailable(scrnIndex)))
|
2012-06-10 07:21:05 -06:00
|
|
|
return MODE_ERROR;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
return xf86CheckModeForMonitor((DisplayModePtr) mode, pScrn->monitor);
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
ModeStatus
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeCheckModeForDriver(int scrnIndex, void *mode)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if ((mode == NULL) || (!VidModeAvailable(scrnIndex)))
|
2012-06-10 07:21:05 -06:00
|
|
|
return MODE_ERROR;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
return xf86CheckModeForDriver(pScrn, (DisplayModePtr) mode, 0);
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
void
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeSetCrtcForMode(int scrnIndex, void *mode)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
DisplayModePtr ScreenModes;
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
if ((mode == NULL) || (!VidModeAvailable(scrnIndex)))
|
2012-06-10 07:21:05 -06:00
|
|
|
return;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
/* Ugly hack so that the xf86Mode.c function can be used without change */
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
ScreenModes = pScrn->modes;
|
2012-06-10 07:21:05 -06:00
|
|
|
pScrn->modes = (DisplayModePtr) mode;
|
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
xf86SetCrtcForModes(pScrn, pScrn->adjustFlags);
|
|
|
|
pScrn->modes = ScreenModes;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeAddModeline(int scrnIndex, void *mode)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
if ((mode == NULL) || (!VidModeAvailable(scrnIndex)))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->name = strdup(""); /* freed by deletemode */
|
|
|
|
((DisplayModePtr) mode)->status = MODE_OK;
|
|
|
|
((DisplayModePtr) mode)->next = pScrn->modes->next;
|
|
|
|
((DisplayModePtr) mode)->prev = pScrn->modes;
|
|
|
|
pScrn->modes->next = (DisplayModePtr) mode;
|
|
|
|
if (((DisplayModePtr) mode)->next != NULL)
|
|
|
|
((DisplayModePtr) mode)->next->prev = (DisplayModePtr) mode;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
int
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeGetNumOfModes(int scrnIndex)
|
|
|
|
{
|
2014-09-27 11:52:59 -06:00
|
|
|
void *mode = NULL;
|
2012-06-10 07:21:05 -06:00
|
|
|
int dotClock = 0, nummodes = 0;
|
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
if (!VidModeGetFirstModeline(scrnIndex, &mode, &dotClock))
|
2012-06-10 07:21:05 -06:00
|
|
|
return nummodes;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
do {
|
2012-06-10 07:21:05 -06:00
|
|
|
nummodes++;
|
|
|
|
if (!VidModeGetNextModeline(scrnIndex, &mode, &dotClock))
|
|
|
|
return nummodes;
|
2006-11-26 11:13:41 -07:00
|
|
|
} while (TRUE);
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeSetGamma(int scrnIndex, float red, float green, float blue)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
Gamma gamma;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
gamma.red = red;
|
|
|
|
gamma.green = green;
|
|
|
|
gamma.blue = blue;
|
|
|
|
if (xf86ChangeGamma(pScrn->pScreen, gamma) != Success)
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
else
|
2012-06-10 07:21:05 -06:00
|
|
|
return TRUE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeGetGamma(int scrnIndex, float *red, float *green, float *blue)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
*red = pScrn->gamma.red;
|
|
|
|
*green = pScrn->gamma.green;
|
|
|
|
*blue = pScrn->gamma.blue;
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeSetGammaRamp(int scrnIndex, int size, CARD16 *r, CARD16 *g, CARD16 *b)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
|
|
|
return FALSE;
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
xf86ChangeGammaRamp(pScrn->pScreen, size, r, g, b);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
Bool
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeGetGammaRamp(int scrnIndex, int size, CARD16 *r, CARD16 *g, CARD16 *b)
|
|
|
|
{
|
|
|
|
ScrnInfoPtr pScrn;
|
|
|
|
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
pScrn = xf86Screens[scrnIndex];
|
|
|
|
xf86GetGammaRamp(pScrn->pScreen, size, r, g, b);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
int
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeGetGammaRampSize(int scrnIndex)
|
|
|
|
{
|
|
|
|
if (!VidModeAvailable(scrnIndex))
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
return xf86GetGammaRampSize(xf86Screens[scrnIndex]->pScreen);
|
|
|
|
}
|
|
|
|
|
2014-09-27 11:52:59 -06:00
|
|
|
void *
|
2006-11-26 11:13:41 -07:00
|
|
|
VidModeCreateMode(void)
|
|
|
|
{
|
|
|
|
DisplayModePtr mode;
|
2012-06-10 07:21:05 -06:00
|
|
|
|
2010-12-05 08:36:02 -07:00
|
|
|
mode = malloc(sizeof(DisplayModeRec));
|
2006-11-26 11:13:41 -07:00
|
|
|
if (mode != NULL) {
|
2012-06-10 07:21:05 -06:00
|
|
|
mode->name = "";
|
|
|
|
mode->VScan = 1; /* divides refresh rate. default = 1 */
|
|
|
|
mode->Private = NULL;
|
|
|
|
mode->next = mode;
|
|
|
|
mode->prev = mode;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
return mode;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
void
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeCopyMode(void *modefrom, void *modeto)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
2012-06-10 07:21:05 -06:00
|
|
|
memcpy(modeto, modefrom, sizeof(DisplayModeRec));
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
int
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeGetModeValue(void *mode, int valtyp)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
2012-06-10 07:21:05 -06:00
|
|
|
int ret = 0;
|
|
|
|
|
|
|
|
switch (valtyp) {
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_H_DISPLAY:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->HDisplay;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_H_SYNCSTART:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->HSyncStart;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_H_SYNCEND:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->HSyncEnd;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_H_TOTAL:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->HTotal;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_H_SKEW:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->HSkew;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_V_DISPLAY:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->VDisplay;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_V_SYNCSTART:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->VSyncStart;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_V_SYNCEND:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->VSyncEnd;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_V_TOTAL:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->VTotal;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_FLAGS:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->Flags;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_CLOCK:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret = ((DisplayModePtr) mode)->Clock;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return ret;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
void
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeSetModeValue(void *mode, int valtyp, int val)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
2012-06-10 07:21:05 -06:00
|
|
|
switch (valtyp) {
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_H_DISPLAY:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->HDisplay = val;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_H_SYNCSTART:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->HSyncStart = val;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_H_SYNCEND:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->HSyncEnd = val;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_H_TOTAL:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->HTotal = val;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_H_SKEW:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->HSkew = val;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_V_DISPLAY:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->VDisplay = val;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_V_SYNCSTART:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->VSyncStart = val;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_V_SYNCEND:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->VSyncEnd = val;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_V_TOTAL:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->VTotal = val;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_FLAGS:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->Flags = val;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_CLOCK:
|
2012-06-10 07:21:05 -06:00
|
|
|
((DisplayModePtr) mode)->Clock = val;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
vidMonitorValue
|
2014-09-27 11:52:59 -06:00
|
|
|
VidModeGetMonitorValue(void *monitor, int valtyp, int indx)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
2012-06-10 07:21:05 -06:00
|
|
|
vidMonitorValue ret = { NULL, };
|
|
|
|
|
|
|
|
switch (valtyp) {
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_MON_VENDOR:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret.ptr = (((MonPtr) monitor)->vendor);
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_MON_MODEL:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret.ptr = (((MonPtr) monitor)->model);
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_MON_NHSYNC:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret.i = ((MonPtr) monitor)->nHsync;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_MON_NVREFRESH:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret.i = ((MonPtr) monitor)->nVrefresh;
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_MON_HSYNC_LO:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret.f = (100.0 * ((MonPtr) monitor)->hsync[indx].lo);
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_MON_HSYNC_HI:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret.f = (100.0 * ((MonPtr) monitor)->hsync[indx].hi);
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_MON_VREFRESH_LO:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret.f = (100.0 * ((MonPtr) monitor)->vrefresh[indx].lo);
|
|
|
|
break;
|
2006-11-26 11:13:41 -07:00
|
|
|
case VIDMODE_MON_VREFRESH_HI:
|
2012-06-10 07:21:05 -06:00
|
|
|
ret.f = (100.0 * ((MonPtr) monitor)->vrefresh[indx].hi);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return ret;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
#endif /* XF86VIDMODE */
|