Files
nv-xconfig/nvidia-xconfig-540.4.0/XF86Config-parser/Screen.c
svcmobrel-release 793d53d490 Updating prebuilts and/or headers
b1bc157844c5570f911b2bf45249bd26ce73efef - nvidia-xconfig-540.4.0/Makefile
4cc77b90af91e615a64ae04893fdffa7939db84c - nvidia-xconfig-540.4.0/COPYING
f14e9577e537037d4778d490ef70f13b0e94a70a - nvidia-xconfig-540.4.0/option_table.h
647e7896275a1113ec99352d573823a05001f57e - nvidia-xconfig-540.4.0/lscf.c
1e39095238886dfc6a69f7ec750e10c05a93e7d1 - nvidia-xconfig-540.4.0/nvidia-xconfig.1.m4
a5ad539267b73169480e7898b284823639c4db3a - nvidia-xconfig-540.4.0/tree.c
b3d0f9f27c4d9cb7940d04e1dd387d357a16024c - nvidia-xconfig-540.4.0/nvidia-xconfig.c
46f2ea329459b0b16cb36cc14cec0de737d0963e - nvidia-xconfig-540.4.0/options.c
6f6f68f976250f2646450e571f9ab2d7eee1ac80 - nvidia-xconfig-540.4.0/nvidia-cfg.h
913b088cb559f31e09a1baf89d85d75cb43079b4 - nvidia-xconfig-540.4.0/nvidia-xconfig.h
bfa37f78ba458f14a1865bbf3f67eb84987a7e1c - nvidia-xconfig-540.4.0/extract_edids.c
d37da5a118e0418b267a48d05fd144611316b42c - nvidia-xconfig-540.4.0/gen-manpage-opts.c
41bcac41393c9a465c30c07cf1ab386647a16687 - nvidia-xconfig-540.4.0/util.c
9b0c02164398be2795fea7cb13c9e1b062d24bfb - nvidia-xconfig-540.4.0/query_gpu_info.c
c946eefad99cec9366d8abbd4e45c5d138d3b7be - nvidia-xconfig-540.4.0/make_usable.c
10edc2c301fd331439b38d001c0df41669c238b2 - nvidia-xconfig-540.4.0/multiple_screens.c
c7b8d8ca0f7c9dcc2cdca4f8e77d1122c71892ef - nvidia-xconfig-540.4.0/XF86Config-parser/Read.c
a9bc06f33bf525c2b08be2dc3cd64a59c4c7946d - nvidia-xconfig-540.4.0/XF86Config-parser/Configint.h
2022a4a3c2a1b23a67ae74f50a3849f5f3a45e4b - nvidia-xconfig-540.4.0/XF86Config-parser/Keyboard.c
83b0a8efd6a508db54995688ab353591bdb242a2 - nvidia-xconfig-540.4.0/XF86Config-parser/Flags.c
e67d630ef396ab7d34524c333f3a77fc42ba8fc6 - nvidia-xconfig-540.4.0/XF86Config-parser/configProcs.h
f3d611bdbddfa64675a0810ef81dada57e224bcd - nvidia-xconfig-540.4.0/XF86Config-parser/Extensions.c
5ffb2caa5077a2e6ec1c5ece807e71503fb2fbce - nvidia-xconfig-540.4.0/XF86Config-parser/Module.c
7344be997921dec57959691e986763ee686888d5 - nvidia-xconfig-540.4.0/XF86Config-parser/Device.c
33211ca0a10f50e2c87b9e8feef6c1ab381b57a1 - nvidia-xconfig-540.4.0/XF86Config-parser/DRI.c
953b945f3b117d6fb44f1f738af17b6380a9ec72 - nvidia-xconfig-540.4.0/XF86Config-parser/Monitor.c
6c210ad0eaee1db3fec48ff01746cb054b4f9aaa - nvidia-xconfig-540.4.0/XF86Config-parser/Video.c
4407207cf890539dc604cff5b834c994b307729a - nvidia-xconfig-540.4.0/XF86Config-parser/Write.c
de1c758e29f217e1a99e4c076d54ac84bce98b18 - nvidia-xconfig-540.4.0/XF86Config-parser/Screen.c
c66a0a141e25e31b568fb9df41f17d7fb9e6d3b9 - nvidia-xconfig-540.4.0/XF86Config-parser/xf86Parser.h
9cbc29da282aa957f28b7fc83caf1e3b19ee2a52 - nvidia-xconfig-540.4.0/XF86Config-parser/Vendor.c
18711ff932af2202869a30f3b32d6d7fe7811c84 - nvidia-xconfig-540.4.0/XF86Config-parser/Layout.c
cda3a4ab05bf48ba28af35b5c4c632e968afc7fa - nvidia-xconfig-540.4.0/XF86Config-parser/Util.c
ec19d673a6a7d1d8f855f2d32d3e8f63046c3625 - nvidia-xconfig-540.4.0/XF86Config-parser/Files.c
ac878b26ded86a3c502a6a81fc4c4a96162afefb - nvidia-xconfig-540.4.0/XF86Config-parser/Merge.c
0a274c4bc54b6ae0f6d009e443bda0cb033d66b5 - nvidia-xconfig-540.4.0/XF86Config-parser/Pointer.c
3f2238c88d737bd329a9bca1ac4b0bcf77bb9ac2 - nvidia-xconfig-540.4.0/XF86Config-parser/xf86tokens.h
45ceb0129668346ae3e52d81bb6e2f97efadf9d0 - nvidia-xconfig-540.4.0/XF86Config-parser/Input.c
4d9b03ea3badceb6bdfdf6589e6731140ec44079 - nvidia-xconfig-540.4.0/XF86Config-parser/Generate.c
04efe162cf6d97882f2bb87f3712d9a65c2320f3 - nvidia-xconfig-540.4.0/XF86Config-parser/Scan.c
5d55b94375c2055cfa1578e4c7f34c90e63a33f7 - nvidia-xconfig-540.4.0/common-utils/gen-manpage-opts-helper.c
384e36102dcd08ed4c5de05b5e3b8a7cdb2e257d - nvidia-xconfig-540.4.0/common-utils/nvgetopt.c
dc2678d8a9d794a4b2b2718fce57ec087f21f54b - nvidia-xconfig-540.4.0/common-utils/common-utils.h
8db48a58d1654ed69920366bef10f38b789a1a84 - nvidia-xconfig-540.4.0/common-utils/msg.c
e572cac43202f6c2af1c80b9e3901215126093ed - nvidia-xconfig-540.4.0/common-utils/nvgetopt.h
8a346196b052cfb1e06dd83d2ad1fe71e928d2b3 - nvidia-xconfig-540.4.0/common-utils/common-utils.c
1654638c567bc7f2bd70b54d807b498ab14c1061 - nvidia-xconfig-540.4.0/common-utils/nvpci-utils.h
8259a24058c714629f9819cc8c830ea9b202bb27 - nvidia-xconfig-540.4.0/common-utils/gen-manpage-opts-helper.h
524990f5497f9bbeb3d148b5e7dc8d2267c3163d - nvidia-xconfig-540.4.0/common-utils/nvpci-utils.c
abb5c1b445d9353f2d2840bda848cd16109710a4 - nvidia-xconfig-540.4.0/common-utils/msg.h

Change-Id: I923b8a9c53e3923f3261fb29c72380b5a1f7ab3e
2024-09-27 12:48:41 -07:00

735 lines
22 KiB
C

/*
*
* Copyright (c) 1997 Metro Link Incorporated
*
* 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 X CONSORTIUM 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 Metro Link shall not be
* used in advertising or otherwise to promote the sale, use or other dealings
* in this Software without prior written authorization from Metro Link.
*
*/
/*
* Copyright (c) 1997-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).
*/
/* View/edit this file with tab stops set to 4 */
#include "xf86Parser.h"
#include "xf86tokens.h"
#include "Configint.h"
extern LexRec val;
static XConfigSymTabRec DisplayTab[] =
{
{ENDSUBSECTION, "endsubsection"},
{MODES, "modes"},
{VIEWPORT, "viewport"},
{VIRTUAL, "virtual"},
{VISUAL, "visual"},
{BLACK_TOK, "black"},
{WHITE_TOK, "white"},
{DEPTH, "depth"},
{BPP, "fbbpp"},
{WEIGHT, "weight"},
{OPTION, "option"},
{-1, ""},
};
#define CLEANUP xconfigFreeDisplayList
static int addImpliedScreen(XConfigPtr config);
XConfigDisplayPtr
xconfigParseDisplaySubSection (void)
{
int token;
PARSE_PROLOGUE (XConfigDisplayPtr, XConfigDisplayRec)
ptr->black.red = ptr->black.green = ptr->black.blue = -1;
ptr->white.red = ptr->white.green = ptr->white.blue = -1;
ptr->frameX0 = ptr->frameY0 = -1;
while ((token = xconfigGetToken (DisplayTab)) != ENDSUBSECTION)
{
switch (token)
{
case COMMENT:
ptr->comment = xconfigAddComment(ptr->comment, val.str);
break;
case VIEWPORT:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (VIEWPORT_MSG, NULL);
ptr->frameX0 = val.num;
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (VIEWPORT_MSG, NULL);
ptr->frameY0 = val.num;
break;
case VIRTUAL:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (VIRTUAL_MSG, NULL);
ptr->virtualX = val.num;
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (VIRTUAL_MSG, NULL);
ptr->virtualY = val.num;
break;
case DEPTH:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "Display");
ptr->depth = val.num;
break;
case BPP:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "Display");
ptr->bpp = val.num;
break;
case VISUAL:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Display");
ptr->visual = val.str;
break;
case WEIGHT:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (WEIGHT_MSG, NULL);
ptr->weight.red = val.num;
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (WEIGHT_MSG, NULL);
ptr->weight.green = val.num;
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (WEIGHT_MSG, NULL);
ptr->weight.blue = val.num;
break;
case BLACK_TOK:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (BLACK_MSG, NULL);
ptr->black.red = val.num;
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (BLACK_MSG, NULL);
ptr->black.green = val.num;
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (BLACK_MSG, NULL);
ptr->black.blue = val.num;
break;
case WHITE_TOK:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (WHITE_MSG, NULL);
ptr->white.red = val.num;
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (WHITE_MSG, NULL);
ptr->white.green = val.num;
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (WHITE_MSG, NULL);
ptr->white.blue = val.num;
break;
case MODES:
{
XConfigModePtr mptr;
while ((token =
xconfigGetSubTokenWithTab(&(ptr->comment),
DisplayTab)) == STRING)
{
mptr = calloc (1, sizeof (XConfigModeRec));
mptr->mode_name = val.str;
mptr->next = NULL;
xconfigAddListItem((GenericListPtr *)(&ptr->modes),
(GenericListPtr) mptr);
}
xconfigUnGetToken (token);
}
break;
case OPTION:
ptr->options = xconfigParseOption(ptr->options);
break;
case EOF_TOKEN:
Error (UNEXPECTED_EOF_MSG, NULL);
break;
default:
Error (INVALID_KEYWORD_MSG, xconfigTokenString ());
break;
}
}
return ptr;
}
#undef CLEANUP
static XConfigSymTabRec ScreenTab[] =
{
{ENDSECTION, "endsection"},
{IDENTIFIER, "identifier"},
{OBSDRIVER, "driver"},
{MDEVICE, "device"},
{MONITOR, "monitor"},
{VIDEOADAPTOR, "videoadaptor"},
{SCREENNO, "screenno"},
{SUBSECTION, "subsection"},
{DEFAULTDEPTH, "defaultcolordepth"},
{DEFAULTDEPTH, "defaultdepth"},
{DEFAULTBPP, "defaultbpp"},
{DEFAULTFBBPP, "defaultfbbpp"},
{OPTION, "option"},
{-1, ""},
};
#define CLEANUP xconfigFreeScreenList
XConfigScreenPtr
xconfigParseScreenSection (void)
{
int has_ident = FALSE;
int has_driver= FALSE;
int token;
PARSE_PROLOGUE (XConfigScreenPtr, XConfigScreenRec)
while ((token = xconfigGetToken (ScreenTab)) != ENDSECTION)
{
switch (token)
{
case COMMENT:
ptr->comment = xconfigAddComment(ptr->comment, val.str);
break;
case IDENTIFIER:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Identifier");
ptr->identifier = val.str;
if (has_ident || has_driver)
Error (ONLY_ONE_MSG,"Identifier or Driver");
has_ident = TRUE;
break;
case OBSDRIVER:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Driver");
ptr->obsolete_driver = val.str;
if (has_ident || has_driver)
Error (ONLY_ONE_MSG,"Identifier or Driver");
has_driver = TRUE;
break;
case DEFAULTDEPTH:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "DefaultDepth");
ptr->defaultdepth = val.num;
break;
case DEFAULTBPP:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "DefaultBPP");
ptr->defaultbpp = val.num;
break;
case DEFAULTFBBPP:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "DefaultFbBPP");
ptr->defaultfbbpp = val.num;
break;
case MDEVICE:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Device");
ptr->device_name = val.str;
break;
case MONITOR:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Monitor");
ptr->monitor_name = val.str;
break;
case VIDEOADAPTOR:
{
XConfigAdaptorLinkPtr aptr;
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "VideoAdaptor");
/* Don't allow duplicates */
for (aptr = ptr->adaptors; aptr;
aptr = (XConfigAdaptorLinkPtr) aptr->next)
if (xconfigNameCompare (val.str, aptr->adaptor_name) == 0)
break;
if (aptr == NULL)
{
aptr = calloc (1, sizeof (XConfigAdaptorLinkRec));
aptr->next = NULL;
aptr->adaptor_name = val.str;
xconfigAddListItem ((GenericListPtr *)(&ptr->adaptors),
(GenericListPtr) aptr);
}
}
break;
case OPTION:
ptr->options = xconfigParseOption(ptr->options);
break;
case SUBSECTION:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "SubSection");
{
free(val.str);
HANDLE_LIST (displays, xconfigParseDisplaySubSection,
XConfigDisplayPtr);
}
break;
case EOF_TOKEN:
Error (UNEXPECTED_EOF_MSG, NULL);
break;
default:
Error (INVALID_KEYWORD_MSG, xconfigTokenString ());
break;
}
}
if (!has_ident && !has_driver)
Error (NO_IDENT_MSG, NULL);
return ptr;
}
void
xconfigPrintScreenSection (FILE * cf, XConfigScreenPtr ptr)
{
XConfigAdaptorLinkPtr aptr;
XConfigDisplayPtr dptr;
XConfigModePtr mptr;
while (ptr)
{
fprintf (cf, "Section \"Screen\"\n");
if (ptr->comment)
fprintf (cf, "%s", ptr->comment);
if (ptr->identifier)
fprintf (cf, " Identifier \"%s\"\n", ptr->identifier);
if (ptr->obsolete_driver)
fprintf (cf, " Driver \"%s\"\n", ptr->obsolete_driver);
if (ptr->device_name)
fprintf (cf, " Device \"%s\"\n", ptr->device_name);
if (ptr->monitor_name)
fprintf (cf, " Monitor \"%s\"\n", ptr->monitor_name);
if (ptr->defaultdepth)
fprintf (cf, " DefaultDepth %d\n",
ptr->defaultdepth);
if (ptr->defaultbpp)
fprintf (cf, " DefaultBPP %d\n",
ptr->defaultbpp);
if (ptr->defaultfbbpp)
fprintf (cf, " DefaultFbBPP %d\n",
ptr->defaultfbbpp);
xconfigPrintOptionList(cf, ptr->options, 1);
for (aptr = ptr->adaptors; aptr; aptr = aptr->next)
{
fprintf (cf, " VideoAdaptor \"%s\"\n", aptr->adaptor_name);
}
for (dptr = ptr->displays; dptr; dptr = dptr->next)
{
fprintf (cf, " SubSection \"Display\"\n");
if (dptr->comment)
fprintf (cf, "%s", dptr->comment);
if (dptr->frameX0 >= 0 || dptr->frameY0 >= 0)
{
fprintf (cf, " Viewport %d %d\n",
dptr->frameX0, dptr->frameY0);
}
if (dptr->virtualX != 0 || dptr->virtualY != 0)
{
fprintf (cf, " Virtual %d %d\n",
dptr->virtualX, dptr->virtualY);
}
if (dptr->depth)
{
fprintf (cf, " Depth %d\n", dptr->depth);
}
if (dptr->bpp)
{
fprintf (cf, " FbBPP %d\n", dptr->bpp);
}
if (dptr->visual)
{
fprintf (cf, " Visual \"%s\"\n", dptr->visual);
}
if (dptr->weight.red != 0)
{
fprintf (cf, " Weight %d %d %d\n",
dptr->weight.red, dptr->weight.green, dptr->weight.blue);
}
if (dptr->black.red != -1)
{
fprintf (cf, " Black 0x%04x 0x%04x 0x%04x\n",
dptr->black.red, dptr->black.green, dptr->black.blue);
}
if (dptr->white.red != -1)
{
fprintf (cf, " White 0x%04x 0x%04x 0x%04x\n",
dptr->white.red, dptr->white.green, dptr->white.blue);
}
if (dptr->modes)
{
fprintf (cf, " Modes ");
}
for (mptr = dptr->modes; mptr; mptr = mptr->next)
{
fprintf (cf, " \"%s\"", mptr->mode_name);
}
if (dptr->modes)
{
fprintf (cf, "\n");
}
xconfigPrintOptionList(cf, dptr->options, 2);
fprintf (cf, " EndSubSection\n");
}
fprintf (cf, "EndSection\n\n");
ptr = ptr->next;
}
}
void
xconfigFreeScreenList (XConfigScreenPtr *ptr)
{
XConfigScreenPtr prev;
if (ptr == NULL || *ptr == NULL)
return;
while (*ptr)
{
TEST_FREE ((*ptr)->identifier);
TEST_FREE ((*ptr)->monitor_name);
TEST_FREE ((*ptr)->device_name);
TEST_FREE ((*ptr)->comment);
xconfigFreeOptionList (&((*ptr)->options));
xconfigFreeAdaptorLinkList (&((*ptr)->adaptors));
xconfigFreeDisplayList (&((*ptr)->displays));
prev = *ptr;
*ptr = (*ptr)->next;
free (prev);
}
}
void
xconfigFreeAdaptorLinkList (XConfigAdaptorLinkPtr *ptr)
{
XConfigAdaptorLinkPtr prev;
if (ptr == NULL || *ptr == NULL)
return;
while (*ptr)
{
TEST_FREE ((*ptr)->adaptor_name);
prev = *ptr;
*ptr = (*ptr)->next;
free (prev);
}
}
void
xconfigFreeDisplayList (XConfigDisplayPtr *ptr)
{
XConfigDisplayPtr prev;
if (ptr == NULL || *ptr == NULL)
return;
while (*ptr)
{
xconfigFreeModeList (&((*ptr)->modes));
xconfigFreeOptionList (&((*ptr)->options));
prev = *ptr;
*ptr = (*ptr)->next;
free (prev);
}
}
void
xconfigFreeModeList (XConfigModePtr *ptr)
{
XConfigModePtr prev;
if (ptr == NULL || *ptr == NULL)
return;
while (*ptr)
{
TEST_FREE ((*ptr)->mode_name);
prev = *ptr;
*ptr = (*ptr)->next;
free (prev);
}
}
int
xconfigValidateScreen (XConfigPtr p)
{
XConfigScreenPtr screen = p->screens;
XConfigMonitorPtr monitor;
XConfigDevicePtr device;
XConfigAdaptorLinkPtr adaptor;
/*
* if we do not have a screen, just return TRUE; we'll add a
* screen later during the Sanitize step
*/
if (!screen) return TRUE;
while (screen)
{
if (screen->obsolete_driver && !screen->identifier)
screen->identifier = screen->obsolete_driver;
monitor = xconfigFindMonitor (screen->monitor_name, p->monitors);
if (screen->monitor_name)
{
if (!monitor)
{
xconfigErrorMsg(ValidationErrorMsg, UNDEFINED_MONITOR_MSG,
screen->monitor_name, screen->identifier);
return (FALSE);
}
else
{
screen->monitor = monitor;
if (!xconfigValidateMonitor(p, screen))
return (FALSE);
}
}
device = xconfigFindDevice (screen->device_name, p->devices);
if (!device)
{
xconfigErrorMsg(ValidationErrorMsg, UNDEFINED_DEVICE_MSG,
screen->device_name, screen->identifier);
return (FALSE);
}
else
screen->device = device;
adaptor = screen->adaptors;
while (adaptor) {
adaptor->adaptor = xconfigFindVideoAdaptor(adaptor->adaptor_name,
p->videoadaptors);
if (!adaptor->adaptor) {
xconfigErrorMsg(ValidationErrorMsg, UNDEFINED_ADAPTOR_MSG,
adaptor->adaptor_name,
screen->identifier);
return (FALSE);
} else if (adaptor->adaptor->fwdref) {
xconfigErrorMsg(ValidationErrorMsg, ADAPTOR_REF_TWICE_MSG,
adaptor->adaptor_name,
adaptor->adaptor->fwdref);
return (FALSE);
}
adaptor->adaptor->fwdref = xconfigStrdup(screen->identifier);
adaptor = adaptor->next;
}
screen = screen->next;
}
return (TRUE);
}
int xconfigSanitizeScreen(XConfigPtr p)
{
XConfigScreenPtr screen = p->screens;
XConfigMonitorPtr monitor;
if (!addImpliedScreen(p)) {
return FALSE;
}
while (screen) {
/*
* if no monitor for this screen (either the monitor name, or
* the actual monitor pointer), find a monitor: resolve
* discrepancies between screen->monitor_name and
* screen->monitor; otherwise use the first monitor in the
* config; if we still don't have a monitor, add a new one
*/
if (!screen->monitor_name || !screen->monitor) {
monitor = NULL;
if (!monitor && screen->monitor) {
monitor = screen->monitor;
}
if (!monitor && screen->monitor_name) {
monitor = xconfigFindMonitor(screen->monitor_name,
p->monitors);
}
if (!monitor && p->monitors) {
monitor = p->monitors;
}
if (!monitor) {
monitor = xconfigAddMonitor(p, 0);
}
if (monitor) {
screen->monitor = monitor;
if (screen->monitor_name) {
free(screen->monitor_name);
}
screen->monitor_name = xconfigStrdup(monitor->identifier);
if (!xconfigValidateMonitor(p, screen)) {
return FALSE;
}
}
}
screen = screen->next;
}
return TRUE;
}
XConfigScreenPtr
xconfigFindScreen (const char *ident, XConfigScreenPtr p)
{
while (p)
{
if (xconfigNameCompare (ident, p->identifier) == 0)
return (p);
p = p->next;
}
return (NULL);
}
XConfigModePtr
xconfigFindMode (const char *name, XConfigModePtr p)
{
while (p)
{
if (xconfigNameCompare (name, p->mode_name) == 0)
return (p);
p = p->next;
}
return (NULL);
}
void
xconfigAddMode(XConfigModePtr *pHead, const char *name)
{
XConfigModePtr mode;
mode = xconfigAlloc(sizeof(XConfigModeRec));
mode->mode_name = xconfigStrdup(name);
mode->next = *pHead;
*pHead = mode;
}
void
xconfigRemoveMode(XConfigModePtr *pHead, const char *name)
{
XConfigModePtr p = *pHead;
XConfigModePtr last = NULL;
while (p) {
if (xconfigNameCompare(p->mode_name, name) == 0) {
if (last) {
last->next = p->next;
} else {
*pHead = p->next;
}
free(p->mode_name);
free(p);
return;
}
last = p;
p = p->next;
}
}
static int addImpliedScreen(XConfigPtr config)
{
XConfigScreenPtr screen;
XConfigDevicePtr device;
XConfigMonitorPtr monitor;
if (config->screens) return TRUE;
xconfigErrorMsg(WarnMsg, "No Screen specified, constructing implicit "
"screen section.\n");
/* allocate the new screen section */
screen = calloc(1, sizeof(XConfigScreenRec));
if (!screen) return FALSE;
screen->identifier = xconfigStrdup("Default Screen");
/*
* Use the first device section if there is one.
*/
if (config->devices) {
device = config->devices;
screen->device_name = xconfigStrdup(device->identifier);
screen->device = device;
}
/*
* Use the first monitor section if there is one.
*/
if (config->monitors) {
monitor = config->monitors;
screen->monitor_name = xconfigStrdup(monitor->identifier);
screen->monitor = monitor;
}
config->screens = screen;
return TRUE;
}