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

Change-Id: I95f040ed93f9532cc6977e9284d2be1256f1b734
2023-01-24 11:20:58 -08:00

540 lines
16 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"
#include <ctype.h>
extern LexRec val;
static
XConfigSymTabRec DeviceTab[] =
{
{ENDSECTION, "endsection"},
{IDENTIFIER, "identifier"},
{VENDOR, "vendorname"},
{BOARD, "boardname"},
{CHIPSET, "chipset"},
{RAMDAC, "ramdac"},
{DACSPEED, "dacspeed"},
{CLOCKS, "clocks"},
{OPTION, "option"},
{VIDEORAM, "videoram"},
{BIOSBASE, "biosbase"},
{MEMBASE, "membase"},
{IOBASE, "iobase"},
{CLOCKCHIP, "clockchip"},
{CHIPID, "chipid"},
{CHIPREV, "chiprev"},
{CARD, "card"},
{DRIVER, "driver"},
{BUSID, "busid"},
{TEXTCLOCKFRQ, "textclockfreq"},
{IRQ, "irq"},
{SCREEN, "screen"},
{-1, ""},
};
#define CLEANUP xconfigFreeDeviceList
XConfigDevicePtr
xconfigParseDeviceSection (void)
{
int i;
int has_ident = FALSE;
int token;
PARSE_PROLOGUE (XConfigDevicePtr, XConfigDeviceRec)
/* Zero is a valid value for these */
ptr->chipid = -1;
ptr->chiprev = -1;
ptr->irq = -1;
ptr->screen = -1;
while ((token = xconfigGetToken (DeviceTab)) != ENDSECTION)
{
switch (token)
{
case COMMENT:
ptr->comment = xconfigAddComment(ptr->comment, val.str);
break;
case IDENTIFIER:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Identifier");
if (has_ident == TRUE)
Error (MULTIPLE_MSG, "Identifier");
ptr->identifier = val.str;
has_ident = TRUE;
break;
case VENDOR:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Vendor");
ptr->vendor = val.str;
break;
case BOARD:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Board");
ptr->board = val.str;
break;
case CHIPSET:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Chipset");
ptr->chipset = val.str;
break;
case CARD:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Card");
ptr->card = val.str;
break;
case DRIVER:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Driver");
ptr->driver = val.str;
break;
case RAMDAC:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "Ramdac");
ptr->ramdac = val.str;
break;
case DACSPEED:
for (i = 0; i < CONF_MAXDACSPEEDS; i++)
ptr->dacSpeeds[i] = 0;
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
{
Error (DACSPEED_MSG, CONF_MAXDACSPEEDS);
}
else
{
ptr->dacSpeeds[0] = (int) (val.realnum * 1000.0 + 0.5);
for (i = 1; i < CONF_MAXDACSPEEDS; i++)
{
if (xconfigGetSubToken (&(ptr->comment)) == NUMBER)
ptr->dacSpeeds[i] = (int)
(val.realnum * 1000.0 + 0.5);
else
{
xconfigUnGetToken (token);
break;
}
}
}
break;
case VIDEORAM:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "VideoRam");
ptr->videoram = val.num;
break;
case BIOSBASE:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "BIOSBase");
ptr->bios_base = val.num;
break;
case MEMBASE:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "MemBase");
ptr->mem_base = val.num;
break;
case IOBASE:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "IOBase");
ptr->io_base = val.num;
break;
case CLOCKCHIP:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "ClockChip");
ptr->clockchip = val.str;
break;
case CHIPID:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "ChipID");
ptr->chipid = val.num;
break;
case CHIPREV:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "ChipRev");
ptr->chiprev = val.num;
break;
case CLOCKS:
token = xconfigGetSubToken(&(ptr->comment));
for( i = ptr->clocks;
token == NUMBER && i < CONF_MAXCLOCKS; i++ ) {
ptr->clock[i] = (int)(val.realnum * 1000.0 + 0.5);
token = xconfigGetSubToken(&(ptr->comment));
}
ptr->clocks = i;
xconfigUnGetToken (token);
break;
case TEXTCLOCKFRQ:
if ((token = xconfigGetSubToken(&(ptr->comment))) != NUMBER)
Error (NUMBER_MSG, "TextClockFreq");
ptr->textclockfreq = (int)(val.realnum * 1000.0 + 0.5);
break;
case OPTION:
ptr->options = xconfigParseOption(ptr->options);
break;
case BUSID:
if (xconfigGetSubToken (&(ptr->comment)) != STRING)
Error (QUOTE_MSG, "BusID");
ptr->busid = val.str;
break;
case IRQ:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (QUOTE_MSG, "IRQ");
ptr->irq = val.num;
break;
case SCREEN:
if (xconfigGetSubToken (&(ptr->comment)) != NUMBER)
Error (NUMBER_MSG, "Screen");
ptr->screen = val.num;
break;
case EOF_TOKEN:
Error (UNEXPECTED_EOF_MSG, NULL);
break;
default:
Error (INVALID_KEYWORD_MSG, xconfigTokenString ());
break;
}
}
if (!has_ident)
Error (NO_IDENT_MSG, NULL);
return ptr;
}
#undef CLEANUP
void
xconfigPrintDeviceSection (FILE * cf, XConfigDevicePtr ptr)
{
int i;
while (ptr)
{
fprintf (cf, "Section \"Device\"\n");
if (ptr->comment)
fprintf (cf, "%s", ptr->comment);
if (ptr->identifier)
fprintf (cf, " Identifier \"%s\"\n", ptr->identifier);
if (ptr->driver)
fprintf (cf, " Driver \"%s\"\n", ptr->driver);
if (ptr->vendor)
fprintf (cf, " VendorName \"%s\"\n", ptr->vendor);
if (ptr->board)
fprintf (cf, " BoardName \"%s\"\n", ptr->board);
if (ptr->chipset)
fprintf (cf, " ChipSet \"%s\"\n", ptr->chipset);
if (ptr->card)
fprintf (cf, " Card \"%s\"\n", ptr->card);
if (ptr->ramdac)
fprintf (cf, " RamDac \"%s\"\n", ptr->ramdac);
if (ptr->dacSpeeds[0] > 0 ) {
fprintf (cf, " DacSpeed ");
for (i = 0; i < CONF_MAXDACSPEEDS
&& ptr->dacSpeeds[i] > 0; i++ )
fprintf (cf, "%g ", (double) (ptr->dacSpeeds[i])/ 1000.0 );
fprintf (cf, "\n");
}
if (ptr->videoram)
fprintf (cf, " VideoRam %d\n", ptr->videoram);
if (ptr->bios_base)
fprintf (cf, " BiosBase 0x%lx\n", ptr->bios_base);
if (ptr->mem_base)
fprintf (cf, " MemBase 0x%lx\n", ptr->mem_base);
if (ptr->io_base)
fprintf (cf, " IOBase 0x%lx\n", ptr->io_base);
if (ptr->clockchip)
fprintf (cf, " ClockChip \"%s\"\n", ptr->clockchip);
if (ptr->chipid != -1)
fprintf (cf, " ChipId 0x%x\n", ptr->chipid);
if (ptr->chiprev != -1)
fprintf (cf, " ChipRev 0x%x\n", ptr->chiprev);
xconfigPrintOptionList(cf, ptr->options, 1);
if (ptr->clocks > 0 ) {
fprintf (cf, " Clocks ");
for (i = 0; i < ptr->clocks; i++ )
fprintf (cf, "%.1f ", (double)ptr->clock[i] / 1000.0 );
fprintf (cf, "\n");
}
if (ptr->textclockfreq) {
fprintf (cf, " TextClockFreq %.1f\n",
(double)ptr->textclockfreq / 1000.0);
}
if (ptr->busid)
fprintf (cf, " BusID \"%s\"\n", ptr->busid);
if (ptr->screen > -1)
fprintf (cf, " Screen %d\n", ptr->screen);
if (ptr->irq >= 0)
fprintf (cf, " IRQ %d\n", ptr->irq);
fprintf (cf, "EndSection\n\n");
ptr = ptr->next;
}
}
void
xconfigFreeDeviceList (XConfigDevicePtr *ptr)
{
XConfigDevicePtr prev;
if (ptr == NULL || *ptr == NULL)
return;
while (*ptr)
{
TEST_FREE ((*ptr)->identifier);
TEST_FREE ((*ptr)->vendor);
TEST_FREE ((*ptr)->board);
TEST_FREE ((*ptr)->chipset);
TEST_FREE ((*ptr)->card);
TEST_FREE ((*ptr)->driver);
TEST_FREE ((*ptr)->ramdac);
TEST_FREE ((*ptr)->clockchip);
TEST_FREE ((*ptr)->comment);
xconfigFreeOptionList (&((*ptr)->options));
prev = *ptr;
*ptr = (*ptr)->next;
free (prev);
}
}
int
xconfigValidateDevice (XConfigPtr p)
{
XConfigDevicePtr device = p->devices;
if (!device) {
xconfigErrorMsg(ValidationErrorMsg, "At least one Device section "
"is required.");
return (FALSE);
}
while (device) {
if (!device->driver) {
xconfigErrorMsg(ValidationErrorMsg, UNDEFINED_DRIVER_MSG,
device->identifier);
return (FALSE);
}
device = device->next;
}
return (TRUE);
}
XConfigDevicePtr
xconfigFindDevice (const char *ident, XConfigDevicePtr p)
{
while (p)
{
if (xconfigNameCompare (ident, p->identifier) == 0)
return (p);
p = p->next;
}
return (NULL);
}
/*
* Determine what bus type the busID string represents. The start of the
* bus-dependent part of the string is returned as retID.
*/
static int isPci(const char* busID, const char **retID)
{
char *p, *s;
int ret = FALSE;
/* If no type field, Default to PCI */
if (isdigit(busID[0])) {
if (retID)
*retID = busID;
return TRUE;
}
s = strdup(busID);
p = strtok(s, ":");
if (p == NULL || *p == 0) {
free(s);
return FALSE;
}
if (!xconfigNameCompare(p, "pci") || !xconfigNameCompare(p, "agp")) {
if (retID)
*retID = busID + strlen(p) + 1;
ret = TRUE;
}
free(s);
return ret;
}
/*
* Parse a BUS ID string, and return the PCI bus parameters if it was
* in the correct format for a PCI bus id.
*/
int xconfigParsePciBusString(const char *busID,
int *bus, int *device, int *func)
{
/*
* The format is assumed to be "bus[@domain]:device[:func]", where domain,
* bus, device and func are decimal integers. func may be omitted and
* assumed to be zero.
*/
char *p, *s, *d;
const char *id;
int i;
if (!isPci(busID, &id))
return FALSE;
s = strdup(id);
p = strtok(s, ":");
if (p == NULL || *p == 0) {
free(s);
return FALSE;
}
d = strpbrk(p, "@");
if (d != NULL) {
*(d++) = 0;
for (i = 0; d[i] != 0; i++) {
if (!isdigit(d[i])) {
free(s);
return FALSE;
}
}
}
for (i = 0; p[i] != 0; i++) {
if (!isdigit(p[i])) {
free(s);
return FALSE;
}
}
*bus = atoi(p);
if (d != NULL && *d != 0)
*bus += atoi(d) << 8;
p = strtok(NULL, ":");
if (p == NULL || *p == 0) {
free(s);
return FALSE;
}
for (i = 0; p[i] != 0; i++) {
if (!isdigit(p[i])) {
free(s);
return FALSE;
}
}
*device = atoi(p);
*func = 0;
p = strtok(NULL, ":");
if (p == NULL || *p == 0) {
free(s);
return TRUE;
}
for (i = 0; p[i] != 0; i++) {
if (!isdigit(p[i])) {
free(s);
return FALSE;
}
}
*func = atoi(p);
free(s);
return TRUE;
}
/*
* xconfigFormatPciBusString : The function checks for the availability
* of PCI domain & accordingly formats the busid string.
*/
void xconfigFormatPciBusString(char *str, int len,
int domain, int bus, int device, int func)
{
if (domain) {
snprintf(str, len, "PCI:%d@%d:%d:%d", bus, domain, device, func);
} else {
snprintf(str, len, "PCI:%d:%d:%d", bus, device, func);
}
str[len - 1] = '\0';
}
/*
* xconfigAddInactiveDevice() - add a device to the inactive section of
* the xconfig layout.
*/
void xconfigAddInactiveDevice(XConfigPtr config, XConfigLayoutPtr layout,
int device_n)
{
XConfigDevicePtr device;
XConfigInactivePtr inac;
device = add_device(config, -1, -1, -1, NULL, device_n,
"modesetting", "Unknown", FALSE /* active */);
inac = xconfigAlloc(sizeof (XConfigInactiveRec));
inac->next = NULL;
inac->device = device;
inac->device_name = xconfigStrdup(device->identifier);
xconfigAddListItem((GenericListPtr *)(&layout->inactives),
(GenericListPtr) inac);
} /* xconfigAddInactiveDevice() */