1706f2543Smrg/* 2706f2543Smrg * 3706f2543Smrg * Copyright (c) 1997 Metro Link Incorporated 4706f2543Smrg * 5706f2543Smrg * Permission is hereby granted, free of charge, to any person obtaining a 6706f2543Smrg * copy of this software and associated documentation files (the "Software"), 7706f2543Smrg * to deal in the Software without restriction, including without limitation 8706f2543Smrg * the rights to use, copy, modify, merge, publish, distribute, sublicense, 9706f2543Smrg * and/or sell copies of the Software, and to permit persons to whom the 10706f2543Smrg * Software is furnished to do so, subject to the following conditions: 11706f2543Smrg * 12706f2543Smrg * The above copyright notice and this permission notice shall be included in 13706f2543Smrg * all copies or substantial portions of the Software. 14706f2543Smrg * 15706f2543Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16706f2543Smrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17706f2543Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18706f2543Smrg * THE X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 19706f2543Smrg * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF 20706f2543Smrg * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21706f2543Smrg * SOFTWARE. 22706f2543Smrg * 23706f2543Smrg * Except as contained in this notice, the name of the Metro Link shall not be 24706f2543Smrg * used in advertising or otherwise to promote the sale, use or other dealings 25706f2543Smrg * in this Software without prior written authorization from Metro Link. 26706f2543Smrg * 27706f2543Smrg */ 28706f2543Smrg/* 29706f2543Smrg * Copyright (c) 1997-2003 by The XFree86 Project, Inc. 30706f2543Smrg * 31706f2543Smrg * Permission is hereby granted, free of charge, to any person obtaining a 32706f2543Smrg * copy of this software and associated documentation files (the "Software"), 33706f2543Smrg * to deal in the Software without restriction, including without limitation 34706f2543Smrg * the rights to use, copy, modify, merge, publish, distribute, sublicense, 35706f2543Smrg * and/or sell copies of the Software, and to permit persons to whom the 36706f2543Smrg * Software is furnished to do so, subject to the following conditions: 37706f2543Smrg * 38706f2543Smrg * The above copyright notice and this permission notice shall be included in 39706f2543Smrg * all copies or substantial portions of the Software. 40706f2543Smrg * 41706f2543Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 42706f2543Smrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 43706f2543Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 44706f2543Smrg * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR 45706f2543Smrg * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 46706f2543Smrg * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 47706f2543Smrg * OTHER DEALINGS IN THE SOFTWARE. 48706f2543Smrg * 49706f2543Smrg * Except as contained in this notice, the name of the copyright holder(s) 50706f2543Smrg * and author(s) shall not be used in advertising or otherwise to promote 51706f2543Smrg * the sale, use or other dealings in this Software without prior written 52706f2543Smrg * authorization from the copyright holder(s) and author(s). 53706f2543Smrg */ 54706f2543Smrg 55706f2543Smrg 56706f2543Smrg/* View/edit this file with tab stops set to 4 */ 57706f2543Smrg 58706f2543Smrg#ifdef HAVE_XORG_CONFIG_H 59706f2543Smrg#include <xorg-config.h> 60706f2543Smrg#endif 61706f2543Smrg 62706f2543Smrg#include "xf86Parser.h" 63706f2543Smrg#include "xf86tokens.h" 64706f2543Smrg#include "Configint.h" 65706f2543Smrg 66706f2543Smrgextern LexRec val; 67706f2543Smrg 68706f2543Smrgstatic 69706f2543Smrgxf86ConfigSymTabRec DeviceTab[] = 70706f2543Smrg{ 71706f2543Smrg {ENDSECTION, "endsection"}, 72706f2543Smrg {IDENTIFIER, "identifier"}, 73706f2543Smrg {VENDOR, "vendorname"}, 74706f2543Smrg {BOARD, "boardname"}, 75706f2543Smrg {CHIPSET, "chipset"}, 76706f2543Smrg {RAMDAC, "ramdac"}, 77706f2543Smrg {DACSPEED, "dacspeed"}, 78706f2543Smrg {CLOCKS, "clocks"}, 79706f2543Smrg {OPTION, "option"}, 80706f2543Smrg {VIDEORAM, "videoram"}, 81706f2543Smrg {BIOSBASE, "biosbase"}, 82706f2543Smrg {MEMBASE, "membase"}, 83706f2543Smrg {IOBASE, "iobase"}, 84706f2543Smrg {CLOCKCHIP, "clockchip"}, 85706f2543Smrg {CHIPID, "chipid"}, 86706f2543Smrg {CHIPREV, "chiprev"}, 87706f2543Smrg {CARD, "card"}, 88706f2543Smrg {DRIVER, "driver"}, 89706f2543Smrg {BUSID, "busid"}, 90706f2543Smrg {TEXTCLOCKFRQ, "textclockfreq"}, 91706f2543Smrg {IRQ, "irq"}, 92706f2543Smrg {SCREEN, "screen"}, 93706f2543Smrg {-1, ""}, 94706f2543Smrg}; 95706f2543Smrg 96706f2543Smrg#define CLEANUP xf86freeDeviceList 97706f2543Smrg 98706f2543SmrgXF86ConfDevicePtr 99706f2543Smrgxf86parseDeviceSection (void) 100706f2543Smrg{ 101706f2543Smrg int i; 102706f2543Smrg int has_ident = FALSE; 103706f2543Smrg int token; 104706f2543Smrg parsePrologue (XF86ConfDevicePtr, XF86ConfDeviceRec) 105706f2543Smrg 106706f2543Smrg /* Zero is a valid value for these */ 107706f2543Smrg ptr->dev_chipid = -1; 108706f2543Smrg ptr->dev_chiprev = -1; 109706f2543Smrg ptr->dev_irq = -1; 110706f2543Smrg while ((token = xf86getToken (DeviceTab)) != ENDSECTION) 111706f2543Smrg { 112706f2543Smrg switch (token) 113706f2543Smrg { 114706f2543Smrg case COMMENT: 115706f2543Smrg ptr->dev_comment = xf86addComment(ptr->dev_comment, val.str); 116706f2543Smrg break; 117706f2543Smrg case IDENTIFIER: 118706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != STRING) 119706f2543Smrg Error (QUOTE_MSG, "Identifier"); 120706f2543Smrg if (has_ident == TRUE) 121706f2543Smrg Error (MULTIPLE_MSG, "Identifier"); 122706f2543Smrg ptr->dev_identifier = val.str; 123706f2543Smrg has_ident = TRUE; 124706f2543Smrg break; 125706f2543Smrg case VENDOR: 126706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != STRING) 127706f2543Smrg Error (QUOTE_MSG, "Vendor"); 128706f2543Smrg ptr->dev_vendor = val.str; 129706f2543Smrg break; 130706f2543Smrg case BOARD: 131706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != STRING) 132706f2543Smrg Error (QUOTE_MSG, "Board"); 133706f2543Smrg ptr->dev_board = val.str; 134706f2543Smrg break; 135706f2543Smrg case CHIPSET: 136706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != STRING) 137706f2543Smrg Error (QUOTE_MSG, "Chipset"); 138706f2543Smrg ptr->dev_chipset = val.str; 139706f2543Smrg break; 140706f2543Smrg case CARD: 141706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != STRING) 142706f2543Smrg Error (QUOTE_MSG, "Card"); 143706f2543Smrg ptr->dev_card = val.str; 144706f2543Smrg break; 145706f2543Smrg case DRIVER: 146706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != STRING) 147706f2543Smrg Error (QUOTE_MSG, "Driver"); 148706f2543Smrg ptr->dev_driver = val.str; 149706f2543Smrg break; 150706f2543Smrg case RAMDAC: 151706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != STRING) 152706f2543Smrg Error (QUOTE_MSG, "Ramdac"); 153706f2543Smrg ptr->dev_ramdac = val.str; 154706f2543Smrg break; 155706f2543Smrg case DACSPEED: 156706f2543Smrg for (i = 0; i < CONF_MAXDACSPEEDS; i++) 157706f2543Smrg ptr->dev_dacSpeeds[i] = 0; 158706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != NUMBER) 159706f2543Smrg { 160706f2543Smrg Error (DACSPEED_MSG, CONF_MAXDACSPEEDS); 161706f2543Smrg } 162706f2543Smrg else 163706f2543Smrg { 164706f2543Smrg ptr->dev_dacSpeeds[0] = (int) (val.realnum * 1000.0 + 0.5); 165706f2543Smrg for (i = 1; i < CONF_MAXDACSPEEDS; i++) 166706f2543Smrg { 167706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) == NUMBER) 168706f2543Smrg ptr->dev_dacSpeeds[i] = (int) 169706f2543Smrg (val.realnum * 1000.0 + 0.5); 170706f2543Smrg else 171706f2543Smrg { 172706f2543Smrg xf86unGetToken (token); 173706f2543Smrg break; 174706f2543Smrg } 175706f2543Smrg } 176706f2543Smrg } 177706f2543Smrg break; 178706f2543Smrg case VIDEORAM: 179706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != NUMBER) 180706f2543Smrg Error (NUMBER_MSG, "VideoRam"); 181706f2543Smrg ptr->dev_videoram = val.num; 182706f2543Smrg break; 183706f2543Smrg case BIOSBASE: 184706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != NUMBER) 185706f2543Smrg Error (NUMBER_MSG, "BIOSBase"); 186706f2543Smrg ptr->dev_bios_base = val.num; 187706f2543Smrg break; 188706f2543Smrg case MEMBASE: 189706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != NUMBER) 190706f2543Smrg Error (NUMBER_MSG, "MemBase"); 191706f2543Smrg ptr->dev_mem_base = val.num; 192706f2543Smrg break; 193706f2543Smrg case IOBASE: 194706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != NUMBER) 195706f2543Smrg Error (NUMBER_MSG, "IOBase"); 196706f2543Smrg ptr->dev_io_base = val.num; 197706f2543Smrg break; 198706f2543Smrg case CLOCKCHIP: 199706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != STRING) 200706f2543Smrg Error (QUOTE_MSG, "ClockChip"); 201706f2543Smrg ptr->dev_clockchip = val.str; 202706f2543Smrg break; 203706f2543Smrg case CHIPID: 204706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != NUMBER) 205706f2543Smrg Error (NUMBER_MSG, "ChipID"); 206706f2543Smrg ptr->dev_chipid = val.num; 207706f2543Smrg break; 208706f2543Smrg case CHIPREV: 209706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != NUMBER) 210706f2543Smrg Error (NUMBER_MSG, "ChipRev"); 211706f2543Smrg ptr->dev_chiprev = val.num; 212706f2543Smrg break; 213706f2543Smrg 214706f2543Smrg case CLOCKS: 215706f2543Smrg token = xf86getSubToken(&(ptr->dev_comment)); 216706f2543Smrg for( i = ptr->dev_clocks; 217706f2543Smrg token == NUMBER && i < CONF_MAXCLOCKS; i++ ) { 218706f2543Smrg ptr->dev_clock[i] = (int)(val.realnum * 1000.0 + 0.5); 219706f2543Smrg token = xf86getSubToken(&(ptr->dev_comment)); 220706f2543Smrg } 221706f2543Smrg ptr->dev_clocks = i; 222706f2543Smrg xf86unGetToken (token); 223706f2543Smrg break; 224706f2543Smrg case TEXTCLOCKFRQ: 225706f2543Smrg if ((token = xf86getSubToken(&(ptr->dev_comment))) != NUMBER) 226706f2543Smrg Error (NUMBER_MSG, "TextClockFreq"); 227706f2543Smrg ptr->dev_textclockfreq = (int)(val.realnum * 1000.0 + 0.5); 228706f2543Smrg break; 229706f2543Smrg case OPTION: 230706f2543Smrg ptr->dev_option_lst = xf86parseOption(ptr->dev_option_lst); 231706f2543Smrg break; 232706f2543Smrg case BUSID: 233706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != STRING) 234706f2543Smrg Error (QUOTE_MSG, "BusID"); 235706f2543Smrg ptr->dev_busid = val.str; 236706f2543Smrg break; 237706f2543Smrg case IRQ: 238706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != NUMBER) 239706f2543Smrg Error (QUOTE_MSG, "IRQ"); 240706f2543Smrg ptr->dev_irq = val.num; 241706f2543Smrg break; 242706f2543Smrg case SCREEN: 243706f2543Smrg if (xf86getSubToken (&(ptr->dev_comment)) != NUMBER) 244706f2543Smrg Error (NUMBER_MSG, "Screen"); 245706f2543Smrg ptr->dev_screen = val.num; 246706f2543Smrg break; 247706f2543Smrg case EOF_TOKEN: 248706f2543Smrg Error (UNEXPECTED_EOF_MSG, NULL); 249706f2543Smrg break; 250706f2543Smrg default: 251706f2543Smrg Error (INVALID_KEYWORD_MSG, xf86tokenString ()); 252706f2543Smrg break; 253706f2543Smrg } 254706f2543Smrg } 255706f2543Smrg 256706f2543Smrg if (!has_ident) 257706f2543Smrg Error (NO_IDENT_MSG, NULL); 258706f2543Smrg 259706f2543Smrg#ifdef DEBUG 260706f2543Smrg printf ("Device section parsed\n"); 261706f2543Smrg#endif 262706f2543Smrg 263706f2543Smrg return ptr; 264706f2543Smrg} 265706f2543Smrg 266706f2543Smrg#undef CLEANUP 267706f2543Smrg 268706f2543Smrgvoid 269706f2543Smrgxf86printDeviceSection (FILE * cf, XF86ConfDevicePtr ptr) 270706f2543Smrg{ 271706f2543Smrg int i; 272706f2543Smrg 273706f2543Smrg while (ptr) 274706f2543Smrg { 275706f2543Smrg fprintf (cf, "Section \"Device\"\n"); 276706f2543Smrg if (ptr->dev_comment) 277706f2543Smrg fprintf (cf, "%s", ptr->dev_comment); 278706f2543Smrg if (ptr->dev_identifier) 279706f2543Smrg fprintf (cf, "\tIdentifier \"%s\"\n", ptr->dev_identifier); 280706f2543Smrg if (ptr->dev_driver) 281706f2543Smrg fprintf (cf, "\tDriver \"%s\"\n", ptr->dev_driver); 282706f2543Smrg if (ptr->dev_vendor) 283706f2543Smrg fprintf (cf, "\tVendorName \"%s\"\n", ptr->dev_vendor); 284706f2543Smrg if (ptr->dev_board) 285706f2543Smrg fprintf (cf, "\tBoardName \"%s\"\n", ptr->dev_board); 286706f2543Smrg if (ptr->dev_chipset) 287706f2543Smrg fprintf (cf, "\tChipSet \"%s\"\n", ptr->dev_chipset); 288706f2543Smrg if (ptr->dev_card) 289706f2543Smrg fprintf (cf, "\tCard \"%s\"\n", ptr->dev_card); 290706f2543Smrg if (ptr->dev_ramdac) 291706f2543Smrg fprintf (cf, "\tRamDac \"%s\"\n", ptr->dev_ramdac); 292706f2543Smrg if (ptr->dev_dacSpeeds[0] > 0 ) { 293706f2543Smrg fprintf (cf, "\tDacSpeed "); 294706f2543Smrg for (i = 0; i < CONF_MAXDACSPEEDS 295706f2543Smrg && ptr->dev_dacSpeeds[i] > 0; i++ ) 296706f2543Smrg fprintf (cf, "%g ", (double) (ptr->dev_dacSpeeds[i])/ 1000.0 ); 297706f2543Smrg fprintf (cf, "\n"); 298706f2543Smrg } 299706f2543Smrg if (ptr->dev_videoram) 300706f2543Smrg fprintf (cf, "\tVideoRam %d\n", ptr->dev_videoram); 301706f2543Smrg if (ptr->dev_bios_base) 302706f2543Smrg fprintf (cf, "\tBiosBase 0x%lx\n", ptr->dev_bios_base); 303706f2543Smrg if (ptr->dev_mem_base) 304706f2543Smrg fprintf (cf, "\tMemBase 0x%lx\n", ptr->dev_mem_base); 305706f2543Smrg if (ptr->dev_io_base) 306706f2543Smrg fprintf (cf, "\tIOBase 0x%lx\n", ptr->dev_io_base); 307706f2543Smrg if (ptr->dev_clockchip) 308706f2543Smrg fprintf (cf, "\tClockChip \"%s\"\n", ptr->dev_clockchip); 309706f2543Smrg if (ptr->dev_chipid != -1) 310706f2543Smrg fprintf (cf, "\tChipId 0x%x\n", ptr->dev_chipid); 311706f2543Smrg if (ptr->dev_chiprev != -1) 312706f2543Smrg fprintf (cf, "\tChipRev 0x%x\n", ptr->dev_chiprev); 313706f2543Smrg 314706f2543Smrg xf86printOptionList(cf, ptr->dev_option_lst, 1); 315706f2543Smrg if (ptr->dev_clocks > 0 ) { 316706f2543Smrg fprintf (cf, "\tClocks "); 317706f2543Smrg for (i = 0; i < ptr->dev_clocks; i++ ) 318706f2543Smrg fprintf (cf, "%.1f ", (double)ptr->dev_clock[i] / 1000.0 ); 319706f2543Smrg fprintf (cf, "\n"); 320706f2543Smrg } 321706f2543Smrg if (ptr->dev_textclockfreq) { 322706f2543Smrg fprintf (cf, "\tTextClockFreq %.1f\n", 323706f2543Smrg (double)ptr->dev_textclockfreq / 1000.0); 324706f2543Smrg } 325706f2543Smrg if (ptr->dev_busid) 326706f2543Smrg fprintf (cf, "\tBusID \"%s\"\n", ptr->dev_busid); 327706f2543Smrg if (ptr->dev_screen > 0) 328706f2543Smrg fprintf (cf, "\tScreen %d\n", ptr->dev_screen); 329706f2543Smrg if (ptr->dev_irq >= 0) 330706f2543Smrg fprintf (cf, "\tIRQ %d\n", ptr->dev_irq); 331706f2543Smrg fprintf (cf, "EndSection\n\n"); 332706f2543Smrg ptr = ptr->list.next; 333706f2543Smrg } 334706f2543Smrg} 335706f2543Smrg 336706f2543Smrgvoid 337706f2543Smrgxf86freeDeviceList (XF86ConfDevicePtr ptr) 338706f2543Smrg{ 339706f2543Smrg XF86ConfDevicePtr prev; 340706f2543Smrg 341706f2543Smrg while (ptr) 342706f2543Smrg { 343706f2543Smrg TestFree (ptr->dev_identifier); 344706f2543Smrg TestFree (ptr->dev_vendor); 345706f2543Smrg TestFree (ptr->dev_board); 346706f2543Smrg TestFree (ptr->dev_chipset); 347706f2543Smrg TestFree (ptr->dev_card); 348706f2543Smrg TestFree (ptr->dev_driver); 349706f2543Smrg TestFree (ptr->dev_ramdac); 350706f2543Smrg TestFree (ptr->dev_clockchip); 351706f2543Smrg TestFree (ptr->dev_comment); 352706f2543Smrg xf86optionListFree (ptr->dev_option_lst); 353706f2543Smrg 354706f2543Smrg prev = ptr; 355706f2543Smrg ptr = ptr->list.next; 356706f2543Smrg free (prev); 357706f2543Smrg } 358706f2543Smrg} 359706f2543Smrg 360706f2543SmrgXF86ConfDevicePtr 361706f2543Smrgxf86findDevice (const char *ident, XF86ConfDevicePtr p) 362706f2543Smrg{ 363706f2543Smrg while (p) 364706f2543Smrg { 365706f2543Smrg if (xf86nameCompare (ident, p->dev_identifier) == 0) 366706f2543Smrg return p; 367706f2543Smrg 368706f2543Smrg p = p->list.next; 369706f2543Smrg } 370706f2543Smrg return NULL; 371706f2543Smrg} 372706f2543Smrg 373706f2543SmrgXF86ConfDevicePtr 374706f2543Smrgxf86findDeviceByDriver (const char *driver, XF86ConfDevicePtr p) 375706f2543Smrg{ 376706f2543Smrg while (p) 377706f2543Smrg { 378706f2543Smrg if (xf86nameCompare (driver, p->dev_driver) == 0) 379706f2543Smrg return p; 380706f2543Smrg 381706f2543Smrg p = p->list.next; 382706f2543Smrg } 383706f2543Smrg return NULL; 384706f2543Smrg} 385