xref: /OK3568_Linux_fs/external/xserver/hw/xfree86/common/xf86VidMode.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Copyright (c) 1999-2003 by The XFree86 Project, Inc.
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Permission is hereby granted, free of charge, to any person obtaining a
5*4882a593Smuzhiyun  * copy of this software and associated documentation files (the "Software"),
6*4882a593Smuzhiyun  * to deal in the Software without restriction, including without limitation
7*4882a593Smuzhiyun  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*4882a593Smuzhiyun  * and/or sell copies of the Software, and to permit persons to whom the
9*4882a593Smuzhiyun  * Software is furnished to do so, subject to the following conditions:
10*4882a593Smuzhiyun  *
11*4882a593Smuzhiyun  * The above copyright notice and this permission notice shall be included in
12*4882a593Smuzhiyun  * all copies or substantial portions of the Software.
13*4882a593Smuzhiyun  *
14*4882a593Smuzhiyun  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15*4882a593Smuzhiyun  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16*4882a593Smuzhiyun  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
17*4882a593Smuzhiyun  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18*4882a593Smuzhiyun  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19*4882a593Smuzhiyun  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20*4882a593Smuzhiyun  * OTHER DEALINGS IN THE SOFTWARE.
21*4882a593Smuzhiyun  *
22*4882a593Smuzhiyun  * Except as contained in this notice, the name of the copyright holder(s)
23*4882a593Smuzhiyun  * and author(s) shall not be used in advertising or otherwise to promote
24*4882a593Smuzhiyun  * the sale, use or other dealings in this Software without prior written
25*4882a593Smuzhiyun  * authorization from the copyright holder(s) and author(s).
26*4882a593Smuzhiyun  */
27*4882a593Smuzhiyun 
28*4882a593Smuzhiyun /*
29*4882a593Smuzhiyun  * This file contains the VidMode functions required by the extension.
30*4882a593Smuzhiyun  * These have been added to avoid the need for the higher level extension
31*4882a593Smuzhiyun  * code to access the private XFree86 data structures directly. Wherever
32*4882a593Smuzhiyun  * possible this code uses the functions in xf86Mode.c to do the work,
33*4882a593Smuzhiyun  * so that two version of code that do similar things don't have to be
34*4882a593Smuzhiyun  * maintained.
35*4882a593Smuzhiyun  */
36*4882a593Smuzhiyun 
37*4882a593Smuzhiyun #ifdef HAVE_XORG_CONFIG_H
38*4882a593Smuzhiyun #include <xorg-config.h>
39*4882a593Smuzhiyun #endif
40*4882a593Smuzhiyun 
41*4882a593Smuzhiyun #include <X11/X.h>
42*4882a593Smuzhiyun #include "os.h"
43*4882a593Smuzhiyun #include "xf86.h"
44*4882a593Smuzhiyun #include "xf86Priv.h"
45*4882a593Smuzhiyun #include "extinit.h"
46*4882a593Smuzhiyun 
47*4882a593Smuzhiyun #ifdef XF86VIDMODE
48*4882a593Smuzhiyun #include "vidmodestr.h"
49*4882a593Smuzhiyun #include "xf86Privstr.h"
50*4882a593Smuzhiyun #include "xf86Extensions.h"
51*4882a593Smuzhiyun #include "xf86cmap.h"
52*4882a593Smuzhiyun 
53*4882a593Smuzhiyun static vidMonitorValue
xf86VidModeGetMonitorValue(ScreenPtr pScreen,int valtyp,int indx)54*4882a593Smuzhiyun xf86VidModeGetMonitorValue(ScreenPtr pScreen, int valtyp, int indx)
55*4882a593Smuzhiyun {
56*4882a593Smuzhiyun     vidMonitorValue ret = { NULL, };
57*4882a593Smuzhiyun     MonPtr monitor;
58*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
59*4882a593Smuzhiyun 
60*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
61*4882a593Smuzhiyun     monitor = pScrn->monitor;
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun     switch (valtyp) {
64*4882a593Smuzhiyun     case VIDMODE_MON_VENDOR:
65*4882a593Smuzhiyun         ret.ptr = monitor->vendor;
66*4882a593Smuzhiyun         break;
67*4882a593Smuzhiyun     case VIDMODE_MON_MODEL:
68*4882a593Smuzhiyun         ret.ptr = monitor->model;
69*4882a593Smuzhiyun         break;
70*4882a593Smuzhiyun     case VIDMODE_MON_NHSYNC:
71*4882a593Smuzhiyun         ret.i = monitor->nHsync;
72*4882a593Smuzhiyun         break;
73*4882a593Smuzhiyun     case VIDMODE_MON_NVREFRESH:
74*4882a593Smuzhiyun         ret.i = monitor->nVrefresh;
75*4882a593Smuzhiyun         break;
76*4882a593Smuzhiyun     case VIDMODE_MON_HSYNC_LO:
77*4882a593Smuzhiyun         ret.f = (100.0 * monitor->hsync[indx].lo);
78*4882a593Smuzhiyun         break;
79*4882a593Smuzhiyun     case VIDMODE_MON_HSYNC_HI:
80*4882a593Smuzhiyun         ret.f = (100.0 * monitor->hsync[indx].hi);
81*4882a593Smuzhiyun         break;
82*4882a593Smuzhiyun     case VIDMODE_MON_VREFRESH_LO:
83*4882a593Smuzhiyun         ret.f = (100.0 * monitor->vrefresh[indx].lo);
84*4882a593Smuzhiyun         break;
85*4882a593Smuzhiyun     case VIDMODE_MON_VREFRESH_HI:
86*4882a593Smuzhiyun         ret.f = (100.0 * monitor->vrefresh[indx].hi);
87*4882a593Smuzhiyun         break;
88*4882a593Smuzhiyun     }
89*4882a593Smuzhiyun     return ret;
90*4882a593Smuzhiyun }
91*4882a593Smuzhiyun 
92*4882a593Smuzhiyun static Bool
xf86VidModeGetCurrentModeline(ScreenPtr pScreen,DisplayModePtr * mode,int * dotClock)93*4882a593Smuzhiyun xf86VidModeGetCurrentModeline(ScreenPtr pScreen, DisplayModePtr *mode, int *dotClock)
94*4882a593Smuzhiyun {
95*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
96*4882a593Smuzhiyun 
97*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
98*4882a593Smuzhiyun 
99*4882a593Smuzhiyun     if (pScrn->currentMode) {
100*4882a593Smuzhiyun         *mode = pScrn->currentMode;
101*4882a593Smuzhiyun         *dotClock = pScrn->currentMode->Clock;
102*4882a593Smuzhiyun 
103*4882a593Smuzhiyun         return TRUE;
104*4882a593Smuzhiyun     }
105*4882a593Smuzhiyun     return FALSE;
106*4882a593Smuzhiyun }
107*4882a593Smuzhiyun 
108*4882a593Smuzhiyun static int
xf86VidModeGetDotClock(ScreenPtr pScreen,int Clock)109*4882a593Smuzhiyun xf86VidModeGetDotClock(ScreenPtr pScreen, int Clock)
110*4882a593Smuzhiyun {
111*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
112*4882a593Smuzhiyun 
113*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
114*4882a593Smuzhiyun     if ((pScrn->progClock) || (Clock >= MAXCLOCKS))
115*4882a593Smuzhiyun         return Clock;
116*4882a593Smuzhiyun     else
117*4882a593Smuzhiyun         return pScrn->clock[Clock];
118*4882a593Smuzhiyun }
119*4882a593Smuzhiyun 
120*4882a593Smuzhiyun static int
xf86VidModeGetNumOfClocks(ScreenPtr pScreen,Bool * progClock)121*4882a593Smuzhiyun xf86VidModeGetNumOfClocks(ScreenPtr pScreen, Bool *progClock)
122*4882a593Smuzhiyun {
123*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
124*4882a593Smuzhiyun 
125*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
126*4882a593Smuzhiyun     if (pScrn->progClock) {
127*4882a593Smuzhiyun         *progClock = TRUE;
128*4882a593Smuzhiyun         return 0;
129*4882a593Smuzhiyun     }
130*4882a593Smuzhiyun     else {
131*4882a593Smuzhiyun         *progClock = FALSE;
132*4882a593Smuzhiyun         return pScrn->numClocks;
133*4882a593Smuzhiyun     }
134*4882a593Smuzhiyun }
135*4882a593Smuzhiyun 
136*4882a593Smuzhiyun static Bool
xf86VidModeGetClocks(ScreenPtr pScreen,int * Clocks)137*4882a593Smuzhiyun xf86VidModeGetClocks(ScreenPtr pScreen, int *Clocks)
138*4882a593Smuzhiyun {
139*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
140*4882a593Smuzhiyun     int i;
141*4882a593Smuzhiyun 
142*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
143*4882a593Smuzhiyun 
144*4882a593Smuzhiyun     if (pScrn->progClock)
145*4882a593Smuzhiyun         return FALSE;
146*4882a593Smuzhiyun 
147*4882a593Smuzhiyun     for (i = 0; i < pScrn->numClocks; i++)
148*4882a593Smuzhiyun         *Clocks++ = pScrn->clock[i];
149*4882a593Smuzhiyun 
150*4882a593Smuzhiyun     return TRUE;
151*4882a593Smuzhiyun }
152*4882a593Smuzhiyun 
153*4882a593Smuzhiyun static Bool
xf86VidModeGetNextModeline(ScreenPtr pScreen,DisplayModePtr * mode,int * dotClock)154*4882a593Smuzhiyun xf86VidModeGetNextModeline(ScreenPtr pScreen, DisplayModePtr *mode, int *dotClock)
155*4882a593Smuzhiyun {
156*4882a593Smuzhiyun     VidModePtr pVidMode;
157*4882a593Smuzhiyun     DisplayModePtr p;
158*4882a593Smuzhiyun 
159*4882a593Smuzhiyun     pVidMode = VidModeGetPtr(pScreen);
160*4882a593Smuzhiyun 
161*4882a593Smuzhiyun     for (p = pVidMode->Next; p != NULL && p != pVidMode->First; p = p->next) {
162*4882a593Smuzhiyun         if (p->status == MODE_OK) {
163*4882a593Smuzhiyun             pVidMode->Next = p->next;
164*4882a593Smuzhiyun             *mode = p;
165*4882a593Smuzhiyun             *dotClock = xf86VidModeGetDotClock(pScreen, p->Clock);
166*4882a593Smuzhiyun             return TRUE;
167*4882a593Smuzhiyun         }
168*4882a593Smuzhiyun     }
169*4882a593Smuzhiyun 
170*4882a593Smuzhiyun     return FALSE;
171*4882a593Smuzhiyun }
172*4882a593Smuzhiyun 
173*4882a593Smuzhiyun static Bool
xf86VidModeGetFirstModeline(ScreenPtr pScreen,DisplayModePtr * mode,int * dotClock)174*4882a593Smuzhiyun xf86VidModeGetFirstModeline(ScreenPtr pScreen, DisplayModePtr *mode, int *dotClock)
175*4882a593Smuzhiyun {
176*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
177*4882a593Smuzhiyun     VidModePtr pVidMode;
178*4882a593Smuzhiyun 
179*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
180*4882a593Smuzhiyun     if (pScrn->modes == NULL)
181*4882a593Smuzhiyun         return FALSE;
182*4882a593Smuzhiyun 
183*4882a593Smuzhiyun     pVidMode = VidModeGetPtr(pScreen);
184*4882a593Smuzhiyun     pVidMode->First = pScrn->modes;
185*4882a593Smuzhiyun     pVidMode->Next = pVidMode->First->next;
186*4882a593Smuzhiyun 
187*4882a593Smuzhiyun     if (pVidMode->First->status == MODE_OK) {
188*4882a593Smuzhiyun         *mode = pVidMode->First;
189*4882a593Smuzhiyun         *dotClock = xf86VidModeGetDotClock(pScreen, pVidMode->First->Clock);
190*4882a593Smuzhiyun         return TRUE;
191*4882a593Smuzhiyun     }
192*4882a593Smuzhiyun 
193*4882a593Smuzhiyun     return xf86VidModeGetNextModeline(pScreen, mode, dotClock);
194*4882a593Smuzhiyun }
195*4882a593Smuzhiyun 
196*4882a593Smuzhiyun static Bool
xf86VidModeDeleteModeline(ScreenPtr pScreen,DisplayModePtr mode)197*4882a593Smuzhiyun xf86VidModeDeleteModeline(ScreenPtr pScreen, DisplayModePtr mode)
198*4882a593Smuzhiyun {
199*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
200*4882a593Smuzhiyun 
201*4882a593Smuzhiyun     if (mode == NULL)
202*4882a593Smuzhiyun         return FALSE;
203*4882a593Smuzhiyun 
204*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
205*4882a593Smuzhiyun     xf86DeleteMode(&(pScrn->modes), mode);
206*4882a593Smuzhiyun     return TRUE;
207*4882a593Smuzhiyun }
208*4882a593Smuzhiyun 
209*4882a593Smuzhiyun static Bool
xf86VidModeZoomViewport(ScreenPtr pScreen,int zoom)210*4882a593Smuzhiyun xf86VidModeZoomViewport(ScreenPtr pScreen, int zoom)
211*4882a593Smuzhiyun {
212*4882a593Smuzhiyun     xf86ZoomViewport(pScreen, zoom);
213*4882a593Smuzhiyun     return TRUE;
214*4882a593Smuzhiyun }
215*4882a593Smuzhiyun 
216*4882a593Smuzhiyun static Bool
xf86VidModeSetViewPort(ScreenPtr pScreen,int x,int y)217*4882a593Smuzhiyun xf86VidModeSetViewPort(ScreenPtr pScreen, int x, int y)
218*4882a593Smuzhiyun {
219*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
220*4882a593Smuzhiyun 
221*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
222*4882a593Smuzhiyun     pScrn->frameX0 = min(max(x, 0),
223*4882a593Smuzhiyun                          pScrn->virtualX - pScrn->currentMode->HDisplay);
224*4882a593Smuzhiyun     pScrn->frameX1 = pScrn->frameX0 + pScrn->currentMode->HDisplay - 1;
225*4882a593Smuzhiyun     pScrn->frameY0 = min(max(y, 0),
226*4882a593Smuzhiyun                          pScrn->virtualY - pScrn->currentMode->VDisplay);
227*4882a593Smuzhiyun     pScrn->frameY1 = pScrn->frameY0 + pScrn->currentMode->VDisplay - 1;
228*4882a593Smuzhiyun     if (pScrn->AdjustFrame != NULL)
229*4882a593Smuzhiyun         (pScrn->AdjustFrame) (pScrn, pScrn->frameX0, pScrn->frameY0);
230*4882a593Smuzhiyun 
231*4882a593Smuzhiyun     return TRUE;
232*4882a593Smuzhiyun }
233*4882a593Smuzhiyun 
234*4882a593Smuzhiyun static Bool
xf86VidModeGetViewPort(ScreenPtr pScreen,int * x,int * y)235*4882a593Smuzhiyun xf86VidModeGetViewPort(ScreenPtr pScreen, int *x, int *y)
236*4882a593Smuzhiyun {
237*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
238*4882a593Smuzhiyun 
239*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
240*4882a593Smuzhiyun     *x = pScrn->frameX0;
241*4882a593Smuzhiyun     *y = pScrn->frameY0;
242*4882a593Smuzhiyun     return TRUE;
243*4882a593Smuzhiyun }
244*4882a593Smuzhiyun 
245*4882a593Smuzhiyun static Bool
xf86VidModeSwitchMode(ScreenPtr pScreen,DisplayModePtr mode)246*4882a593Smuzhiyun xf86VidModeSwitchMode(ScreenPtr pScreen, DisplayModePtr mode)
247*4882a593Smuzhiyun {
248*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
249*4882a593Smuzhiyun     DisplayModePtr pTmpMode;
250*4882a593Smuzhiyun     Bool retval;
251*4882a593Smuzhiyun 
252*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
253*4882a593Smuzhiyun     /* save in case we fail */
254*4882a593Smuzhiyun     pTmpMode = pScrn->currentMode;
255*4882a593Smuzhiyun     /* Force a mode switch */
256*4882a593Smuzhiyun     pScrn->currentMode = NULL;
257*4882a593Smuzhiyun     retval = xf86SwitchMode(pScrn->pScreen, mode);
258*4882a593Smuzhiyun     /* we failed: restore it */
259*4882a593Smuzhiyun     if (retval == FALSE)
260*4882a593Smuzhiyun         pScrn->currentMode = pTmpMode;
261*4882a593Smuzhiyun     return retval;
262*4882a593Smuzhiyun }
263*4882a593Smuzhiyun 
264*4882a593Smuzhiyun static Bool
xf86VidModeLockZoom(ScreenPtr pScreen,Bool lock)265*4882a593Smuzhiyun xf86VidModeLockZoom(ScreenPtr pScreen, Bool lock)
266*4882a593Smuzhiyun {
267*4882a593Smuzhiyun     if (xf86Info.dontZoom)
268*4882a593Smuzhiyun         return FALSE;
269*4882a593Smuzhiyun 
270*4882a593Smuzhiyun     xf86LockZoom(pScreen, lock);
271*4882a593Smuzhiyun     return TRUE;
272*4882a593Smuzhiyun }
273*4882a593Smuzhiyun 
274*4882a593Smuzhiyun static ModeStatus
xf86VidModeCheckModeForMonitor(ScreenPtr pScreen,DisplayModePtr mode)275*4882a593Smuzhiyun xf86VidModeCheckModeForMonitor(ScreenPtr pScreen, DisplayModePtr mode)
276*4882a593Smuzhiyun {
277*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
278*4882a593Smuzhiyun 
279*4882a593Smuzhiyun     if (mode == NULL)
280*4882a593Smuzhiyun         return MODE_ERROR;
281*4882a593Smuzhiyun 
282*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
283*4882a593Smuzhiyun 
284*4882a593Smuzhiyun     return xf86CheckModeForMonitor(mode, pScrn->monitor);
285*4882a593Smuzhiyun }
286*4882a593Smuzhiyun 
287*4882a593Smuzhiyun static ModeStatus
xf86VidModeCheckModeForDriver(ScreenPtr pScreen,DisplayModePtr mode)288*4882a593Smuzhiyun xf86VidModeCheckModeForDriver(ScreenPtr pScreen, DisplayModePtr mode)
289*4882a593Smuzhiyun {
290*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
291*4882a593Smuzhiyun 
292*4882a593Smuzhiyun     if (mode == NULL)
293*4882a593Smuzhiyun         return MODE_ERROR;
294*4882a593Smuzhiyun 
295*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
296*4882a593Smuzhiyun 
297*4882a593Smuzhiyun     return xf86CheckModeForDriver(pScrn, mode, 0);
298*4882a593Smuzhiyun }
299*4882a593Smuzhiyun 
300*4882a593Smuzhiyun static void
xf86VidModeSetCrtcForMode(ScreenPtr pScreen,DisplayModePtr mode)301*4882a593Smuzhiyun xf86VidModeSetCrtcForMode(ScreenPtr pScreen, DisplayModePtr mode)
302*4882a593Smuzhiyun {
303*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
304*4882a593Smuzhiyun     DisplayModePtr ScreenModes;
305*4882a593Smuzhiyun 
306*4882a593Smuzhiyun     if (mode == NULL)
307*4882a593Smuzhiyun         return;
308*4882a593Smuzhiyun 
309*4882a593Smuzhiyun     /* Ugly hack so that the xf86Mode.c function can be used without change */
310*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
311*4882a593Smuzhiyun     ScreenModes = pScrn->modes;
312*4882a593Smuzhiyun     pScrn->modes = mode;
313*4882a593Smuzhiyun 
314*4882a593Smuzhiyun     xf86SetCrtcForModes(pScrn, pScrn->adjustFlags);
315*4882a593Smuzhiyun     pScrn->modes = ScreenModes;
316*4882a593Smuzhiyun     return;
317*4882a593Smuzhiyun }
318*4882a593Smuzhiyun 
319*4882a593Smuzhiyun static Bool
xf86VidModeAddModeline(ScreenPtr pScreen,DisplayModePtr mode)320*4882a593Smuzhiyun xf86VidModeAddModeline(ScreenPtr pScreen, DisplayModePtr mode)
321*4882a593Smuzhiyun {
322*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
323*4882a593Smuzhiyun 
324*4882a593Smuzhiyun     if (mode == NULL)
325*4882a593Smuzhiyun         return FALSE;
326*4882a593Smuzhiyun 
327*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
328*4882a593Smuzhiyun 
329*4882a593Smuzhiyun     mode->name = strdup(""); /* freed by deletemode */
330*4882a593Smuzhiyun     mode->status = MODE_OK;
331*4882a593Smuzhiyun     mode->next = pScrn->modes->next;
332*4882a593Smuzhiyun     mode->prev = pScrn->modes;
333*4882a593Smuzhiyun     pScrn->modes->next = mode;
334*4882a593Smuzhiyun     if (mode->next != NULL)
335*4882a593Smuzhiyun         mode->next->prev = mode;
336*4882a593Smuzhiyun 
337*4882a593Smuzhiyun     return TRUE;
338*4882a593Smuzhiyun }
339*4882a593Smuzhiyun 
340*4882a593Smuzhiyun static int
xf86VidModeGetNumOfModes(ScreenPtr pScreen)341*4882a593Smuzhiyun xf86VidModeGetNumOfModes(ScreenPtr pScreen)
342*4882a593Smuzhiyun {
343*4882a593Smuzhiyun     DisplayModePtr mode = NULL;
344*4882a593Smuzhiyun     int dotClock = 0, nummodes = 0;
345*4882a593Smuzhiyun 
346*4882a593Smuzhiyun     if (!xf86VidModeGetFirstModeline(pScreen, &mode, &dotClock))
347*4882a593Smuzhiyun         return nummodes;
348*4882a593Smuzhiyun 
349*4882a593Smuzhiyun     do {
350*4882a593Smuzhiyun         nummodes++;
351*4882a593Smuzhiyun         if (!xf86VidModeGetNextModeline(pScreen, &mode, &dotClock))
352*4882a593Smuzhiyun             return nummodes;
353*4882a593Smuzhiyun     } while (TRUE);
354*4882a593Smuzhiyun }
355*4882a593Smuzhiyun 
356*4882a593Smuzhiyun static Bool
xf86VidModeSetGamma(ScreenPtr pScreen,float red,float green,float blue)357*4882a593Smuzhiyun xf86VidModeSetGamma(ScreenPtr pScreen, float red, float green, float blue)
358*4882a593Smuzhiyun {
359*4882a593Smuzhiyun     Gamma gamma;
360*4882a593Smuzhiyun 
361*4882a593Smuzhiyun     gamma.red = red;
362*4882a593Smuzhiyun     gamma.green = green;
363*4882a593Smuzhiyun     gamma.blue = blue;
364*4882a593Smuzhiyun     if (xf86ChangeGamma(pScreen, gamma) != Success)
365*4882a593Smuzhiyun         return FALSE;
366*4882a593Smuzhiyun     else
367*4882a593Smuzhiyun         return TRUE;
368*4882a593Smuzhiyun }
369*4882a593Smuzhiyun 
370*4882a593Smuzhiyun static Bool
xf86VidModeGetGamma(ScreenPtr pScreen,float * red,float * green,float * blue)371*4882a593Smuzhiyun xf86VidModeGetGamma(ScreenPtr pScreen, float *red, float *green, float *blue)
372*4882a593Smuzhiyun {
373*4882a593Smuzhiyun     ScrnInfoPtr pScrn;
374*4882a593Smuzhiyun 
375*4882a593Smuzhiyun     pScrn = xf86ScreenToScrn(pScreen);
376*4882a593Smuzhiyun     *red = pScrn->gamma.red;
377*4882a593Smuzhiyun     *green = pScrn->gamma.green;
378*4882a593Smuzhiyun     *blue = pScrn->gamma.blue;
379*4882a593Smuzhiyun     return TRUE;
380*4882a593Smuzhiyun }
381*4882a593Smuzhiyun 
382*4882a593Smuzhiyun static Bool
xf86VidModeSetGammaRamp(ScreenPtr pScreen,int size,CARD16 * r,CARD16 * g,CARD16 * b)383*4882a593Smuzhiyun xf86VidModeSetGammaRamp(ScreenPtr pScreen, int size, CARD16 *r, CARD16 *g, CARD16 *b)
384*4882a593Smuzhiyun {
385*4882a593Smuzhiyun     xf86ChangeGammaRamp(pScreen, size, r, g, b);
386*4882a593Smuzhiyun     return TRUE;
387*4882a593Smuzhiyun }
388*4882a593Smuzhiyun 
389*4882a593Smuzhiyun static Bool
xf86VidModeGetGammaRamp(ScreenPtr pScreen,int size,CARD16 * r,CARD16 * g,CARD16 * b)390*4882a593Smuzhiyun xf86VidModeGetGammaRamp(ScreenPtr pScreen, int size, CARD16 *r, CARD16 *g, CARD16 *b)
391*4882a593Smuzhiyun {
392*4882a593Smuzhiyun     xf86GetGammaRamp(pScreen, size, r, g, b);
393*4882a593Smuzhiyun     return TRUE;
394*4882a593Smuzhiyun }
395*4882a593Smuzhiyun 
396*4882a593Smuzhiyun static Bool
xf86VidModeInit(ScreenPtr pScreen)397*4882a593Smuzhiyun xf86VidModeInit(ScreenPtr pScreen)
398*4882a593Smuzhiyun {
399*4882a593Smuzhiyun     VidModePtr pVidMode;
400*4882a593Smuzhiyun 
401*4882a593Smuzhiyun     if (!xf86GetVidModeEnabled()) {
402*4882a593Smuzhiyun         DebugF("!xf86GetVidModeEnabled()\n");
403*4882a593Smuzhiyun         return FALSE;
404*4882a593Smuzhiyun     }
405*4882a593Smuzhiyun 
406*4882a593Smuzhiyun     pVidMode = VidModeInit(pScreen);
407*4882a593Smuzhiyun     if (!pVidMode)
408*4882a593Smuzhiyun         return FALSE;
409*4882a593Smuzhiyun 
410*4882a593Smuzhiyun     pVidMode->Flags = 0;
411*4882a593Smuzhiyun     pVidMode->Next = NULL;
412*4882a593Smuzhiyun 
413*4882a593Smuzhiyun     pVidMode->GetMonitorValue = xf86VidModeGetMonitorValue;
414*4882a593Smuzhiyun     pVidMode->GetCurrentModeline = xf86VidModeGetCurrentModeline;
415*4882a593Smuzhiyun     pVidMode->GetFirstModeline = xf86VidModeGetFirstModeline;
416*4882a593Smuzhiyun     pVidMode->GetNextModeline = xf86VidModeGetNextModeline;
417*4882a593Smuzhiyun     pVidMode->DeleteModeline = xf86VidModeDeleteModeline;
418*4882a593Smuzhiyun     pVidMode->ZoomViewport = xf86VidModeZoomViewport;
419*4882a593Smuzhiyun     pVidMode->GetViewPort = xf86VidModeGetViewPort;
420*4882a593Smuzhiyun     pVidMode->SetViewPort = xf86VidModeSetViewPort;
421*4882a593Smuzhiyun     pVidMode->SwitchMode = xf86VidModeSwitchMode;
422*4882a593Smuzhiyun     pVidMode->LockZoom = xf86VidModeLockZoom;
423*4882a593Smuzhiyun     pVidMode->GetNumOfClocks = xf86VidModeGetNumOfClocks;
424*4882a593Smuzhiyun     pVidMode->GetClocks = xf86VidModeGetClocks;
425*4882a593Smuzhiyun     pVidMode->CheckModeForMonitor = xf86VidModeCheckModeForMonitor;
426*4882a593Smuzhiyun     pVidMode->CheckModeForDriver = xf86VidModeCheckModeForDriver;
427*4882a593Smuzhiyun     pVidMode->SetCrtcForMode = xf86VidModeSetCrtcForMode;
428*4882a593Smuzhiyun     pVidMode->AddModeline = xf86VidModeAddModeline;
429*4882a593Smuzhiyun     pVidMode->GetDotClock = xf86VidModeGetDotClock;
430*4882a593Smuzhiyun     pVidMode->GetNumOfModes = xf86VidModeGetNumOfModes;
431*4882a593Smuzhiyun     pVidMode->SetGamma = xf86VidModeSetGamma;
432*4882a593Smuzhiyun     pVidMode->GetGamma = xf86VidModeGetGamma;
433*4882a593Smuzhiyun     pVidMode->SetGammaRamp = xf86VidModeSetGammaRamp;
434*4882a593Smuzhiyun     pVidMode->GetGammaRamp = xf86VidModeGetGammaRamp;
435*4882a593Smuzhiyun     pVidMode->GetGammaRampSize = xf86GetGammaRampSize; /* use xf86cmap API directly */
436*4882a593Smuzhiyun 
437*4882a593Smuzhiyun     return TRUE;
438*4882a593Smuzhiyun }
439*4882a593Smuzhiyun 
440*4882a593Smuzhiyun void
XFree86VidModeExtensionInit(void)441*4882a593Smuzhiyun XFree86VidModeExtensionInit(void)
442*4882a593Smuzhiyun {
443*4882a593Smuzhiyun     int i;
444*4882a593Smuzhiyun     Bool enabled = FALSE;
445*4882a593Smuzhiyun 
446*4882a593Smuzhiyun     DebugF("XFree86VidModeExtensionInit");
447*4882a593Smuzhiyun 
448*4882a593Smuzhiyun     /* This means that the DDX doesn't want the vidmode extension enabled */
449*4882a593Smuzhiyun     if (!xf86GetVidModeEnabled())
450*4882a593Smuzhiyun         return;
451*4882a593Smuzhiyun 
452*4882a593Smuzhiyun     for (i = 0; i < screenInfo.numScreens; i++) {
453*4882a593Smuzhiyun         if (xf86VidModeInit (screenInfo.screens[i]))
454*4882a593Smuzhiyun             enabled = TRUE;
455*4882a593Smuzhiyun     }
456*4882a593Smuzhiyun     /* This means that the DDX doesn't want the vidmode extension enabled */
457*4882a593Smuzhiyun     if (!enabled)
458*4882a593Smuzhiyun         return;
459*4882a593Smuzhiyun 
460*4882a593Smuzhiyun    VidModeAddExtension(xf86GetVidModeAllowNonLocal());
461*4882a593Smuzhiyun }
462*4882a593Smuzhiyun 
463*4882a593Smuzhiyun #endif                          /* XF86VIDMODE */
464