1 /****************************************************************************** 2 * 3 * Module Name: aslpredef - support for ACPI predefined names 4 * 5 *****************************************************************************/ 6 7 /* 8 * Copyright (C) 2000 - 2017, Intel Corp. 9 * All rights reserved. 10 * 11 * Redistribution and use in source and binary forms, with or without 12 * modification, are permitted provided that the following conditions 13 * are met: 14 * 1. Redistributions of source code must retain the above copyright 15 * notice, this list of conditions, and the following disclaimer, 16 * without modification. 17 * 2. Redistributions in binary form must reproduce at minimum a disclaimer 18 * substantially similar to the "NO WARRANTY" disclaimer below 19 * ("Disclaimer") and any redistribution must be conditioned upon 20 * including a substantially similar Disclaimer requirement for further 21 * binary redistribution. 22 * 3. Neither the names of the above-listed copyright holders nor the names 23 * of any contributors may be used to endorse or promote products derived 24 * from this software without specific prior written permission. 25 * 26 * Alternatively, this software may be distributed under the terms of the 27 * GNU General Public License ("GPL") version 2 as published by the Free 28 * Software Foundation. 29 * 30 * NO WARRANTY 31 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 32 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 33 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR 34 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 35 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 36 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 37 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 38 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 40 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 41 * POSSIBILITY OF SUCH DAMAGES. 42 */ 43 44 #define ACPI_CREATE_PREDEFINED_TABLE 45 #define ACPI_CREATE_RESOURCE_TABLE 46 47 #include <contrib/dev/acpica/compiler/aslcompiler.h> 48 #include "aslcompiler.y.h" 49 #include <contrib/dev/acpica/include/acpredef.h> 50 #include <contrib/dev/acpica/include/acnamesp.h> 51 52 53 #define _COMPONENT ACPI_COMPILER 54 ACPI_MODULE_NAME ("aslpredef") 55 56 57 /* Local prototypes */ 58 59 static void 60 ApCheckForUnexpectedReturnValue ( 61 ACPI_PARSE_OBJECT *Op, 62 ASL_METHOD_INFO *MethodInfo); 63 64 static UINT32 65 ApCheckForSpecialName ( 66 ACPI_PARSE_OBJECT *Op, 67 char *Name); 68 69 70 /******************************************************************************* 71 * 72 * FUNCTION: ApCheckForPredefinedMethod 73 * 74 * PARAMETERS: Op - A parse node of type "METHOD". 75 * MethodInfo - Saved info about this method 76 * 77 * RETURN: None 78 * 79 * DESCRIPTION: If method is a predefined name, check that the number of 80 * arguments and the return type (returns a value or not) 81 * is correct. 82 * 83 ******************************************************************************/ 84 85 BOOLEAN 86 ApCheckForPredefinedMethod ( 87 ACPI_PARSE_OBJECT *Op, 88 ASL_METHOD_INFO *MethodInfo) 89 { 90 UINT32 Index; 91 UINT32 RequiredArgCount; 92 const ACPI_PREDEFINED_INFO *ThisName; 93 94 95 /* Check for a match against the predefined name list */ 96 97 Index = ApCheckForPredefinedName (Op, Op->Asl.NameSeg); 98 99 switch (Index) 100 { 101 case ACPI_NOT_RESERVED_NAME: /* No underscore or _Txx or _xxx name not matched */ 102 case ACPI_PREDEFINED_NAME: /* Resource Name or reserved scope name */ 103 case ACPI_COMPILER_RESERVED_NAME: /* A _Txx that was not emitted by compiler */ 104 105 /* Just return, nothing to do */ 106 return (FALSE); 107 108 109 case ACPI_EVENT_RESERVED_NAME: /* _Lxx/_Exx/_Wxx/_Qxx methods */ 110 111 Gbl_ReservedMethods++; 112 113 /* NumArguments must be zero for all _Lxx/_Exx/_Wxx/_Qxx methods */ 114 115 if (MethodInfo->NumArguments != 0) 116 { 117 sprintf (MsgBuffer, "%s requires %u", Op->Asl.ExternalName, 0); 118 119 AslError (ASL_WARNING, ASL_MSG_RESERVED_ARG_COUNT_HI, Op, 120 MsgBuffer); 121 } 122 break; 123 124 125 default: 126 /* 127 * Matched a predefined method name - validate the ASL-defined 128 * argument count against the ACPI specification. 129 * 130 * Some methods are allowed to have a "minimum" number of args 131 * (_SCP) because their definition in ACPI has changed over time. 132 */ 133 Gbl_ReservedMethods++; 134 ThisName = &AcpiGbl_PredefinedMethods[Index]; 135 RequiredArgCount = METHOD_GET_ARG_COUNT (ThisName->Info.ArgumentList); 136 137 if (MethodInfo->NumArguments != RequiredArgCount) 138 { 139 sprintf (MsgBuffer, "%4.4s requires %u", 140 ThisName->Info.Name, RequiredArgCount); 141 142 if (MethodInfo->NumArguments < RequiredArgCount) 143 { 144 AslError (ASL_WARNING, ASL_MSG_RESERVED_ARG_COUNT_LO, Op, 145 MsgBuffer); 146 } 147 else if ((MethodInfo->NumArguments > RequiredArgCount) && 148 !(ThisName->Info.ArgumentList & ARG_COUNT_IS_MINIMUM)) 149 { 150 AslError (ASL_WARNING, ASL_MSG_RESERVED_ARG_COUNT_HI, Op, 151 MsgBuffer); 152 } 153 } 154 155 /* 156 * Check if method returns no value, but the predefined name is 157 * required to return a value 158 */ 159 if (MethodInfo->NumReturnNoValue && 160 ThisName->Info.ExpectedBtypes) 161 { 162 AcpiUtGetExpectedReturnTypes (StringBuffer, 163 ThisName->Info.ExpectedBtypes); 164 165 sprintf (MsgBuffer, "%s required for %4.4s", 166 StringBuffer, ThisName->Info.Name); 167 168 AslError (ASL_WARNING, ASL_MSG_RESERVED_RETURN_VALUE, Op, 169 MsgBuffer); 170 } 171 break; 172 } 173 174 return (TRUE); 175 } 176 177 178 /******************************************************************************* 179 * 180 * FUNCTION: ApCheckForUnexpectedReturnValue 181 * 182 * PARAMETERS: Op - A parse node of type "RETURN". 183 * MethodInfo - Saved info about this method 184 * 185 * RETURN: None 186 * 187 * DESCRIPTION: Check for an unexpected return value from a predefined method. 188 * Invoked for predefined methods that are defined to not return 189 * any value. If there is a return value, issue a remark, since 190 * the ASL writer may be confused as to the method definition 191 * and/or functionality. 192 * 193 * Note: We ignore all return values of "Zero", since this is what a standalone 194 * Return() statement will always generate -- so we ignore it here -- 195 * i.e., there is no difference between Return() and Return(Zero). 196 * Also, a null Return() will be disassembled to return(Zero) -- so, we 197 * don't want to generate extraneous remarks/warnings for a disassembled 198 * ASL file. 199 * 200 ******************************************************************************/ 201 202 static void 203 ApCheckForUnexpectedReturnValue ( 204 ACPI_PARSE_OBJECT *Op, 205 ASL_METHOD_INFO *MethodInfo) 206 { 207 ACPI_PARSE_OBJECT *ReturnValueOp; 208 209 210 /* Ignore Return() and Return(Zero) (they are the same) */ 211 212 ReturnValueOp = Op->Asl.Child; 213 if (ReturnValueOp->Asl.ParseOpcode == PARSEOP_ZERO) 214 { 215 return; 216 } 217 218 /* We have a valid return value, but the reserved name did not expect it */ 219 220 AslError (ASL_WARNING, ASL_MSG_RESERVED_NO_RETURN_VAL, 221 Op, MethodInfo->Op->Asl.ExternalName); 222 } 223 224 225 /******************************************************************************* 226 * 227 * FUNCTION: ApCheckPredefinedReturnValue 228 * 229 * PARAMETERS: Op - A parse node of type "RETURN". 230 * MethodInfo - Saved info about this method 231 * 232 * RETURN: None 233 * 234 * DESCRIPTION: If method is a predefined name, attempt to validate the return 235 * value. Only "static" types can be validated - a simple return 236 * of an integer/string/buffer/package or a named reference to 237 * a static object. Values such as a Localx or Argx or a control 238 * method invocation are not checked. Issue a warning if there is 239 * a valid return value, but the reserved method defines no 240 * return value. 241 * 242 ******************************************************************************/ 243 244 void 245 ApCheckPredefinedReturnValue ( 246 ACPI_PARSE_OBJECT *Op, 247 ASL_METHOD_INFO *MethodInfo) 248 { 249 UINT32 Index; 250 ACPI_PARSE_OBJECT *ReturnValueOp; 251 const ACPI_PREDEFINED_INFO *ThisName; 252 253 254 /* 255 * Check parent method for a match against the predefined name list. 256 * 257 * Note: Disable compiler errors/warnings because any errors will be 258 * caught when analyzing the parent method. Eliminates duplicate errors. 259 */ 260 Gbl_AllExceptionsDisabled = TRUE; 261 Index = ApCheckForPredefinedName (MethodInfo->Op, 262 MethodInfo->Op->Asl.NameSeg); 263 Gbl_AllExceptionsDisabled = FALSE; 264 265 switch (Index) 266 { 267 case ACPI_EVENT_RESERVED_NAME: /* _Lxx/_Exx/_Wxx/_Qxx methods */ 268 269 /* No return value expected, warn if there is one */ 270 271 ApCheckForUnexpectedReturnValue (Op, MethodInfo); 272 return; 273 274 case ACPI_NOT_RESERVED_NAME: /* No underscore or _Txx or _xxx name not matched */ 275 case ACPI_PREDEFINED_NAME: /* Resource Name or reserved scope name */ 276 case ACPI_COMPILER_RESERVED_NAME: /* A _Txx that was not emitted by compiler */ 277 278 /* Just return, nothing to do */ 279 return; 280 281 default: /* A standard predefined ACPI name */ 282 283 ThisName = &AcpiGbl_PredefinedMethods[Index]; 284 if (!ThisName->Info.ExpectedBtypes) 285 { 286 /* No return value expected, warn if there is one */ 287 288 ApCheckForUnexpectedReturnValue (Op, MethodInfo); 289 return; 290 } 291 292 /* Get the object returned, it is the next argument */ 293 294 ReturnValueOp = Op->Asl.Child; 295 switch (ReturnValueOp->Asl.ParseOpcode) 296 { 297 case PARSEOP_ZERO: 298 case PARSEOP_ONE: 299 case PARSEOP_ONES: 300 case PARSEOP_INTEGER: 301 case PARSEOP_STRING_LITERAL: 302 case PARSEOP_BUFFER: 303 case PARSEOP_PACKAGE: 304 305 /* Static data return object - check against expected type */ 306 307 ApCheckObjectType (ThisName->Info.Name, ReturnValueOp, 308 ThisName->Info.ExpectedBtypes, ACPI_NOT_PACKAGE_ELEMENT); 309 310 /* For packages, check the individual package elements */ 311 312 if (ReturnValueOp->Asl.ParseOpcode == PARSEOP_PACKAGE) 313 { 314 ApCheckPackage (ReturnValueOp, ThisName); 315 } 316 break; 317 318 default: 319 /* 320 * All other ops are very difficult or impossible to typecheck at 321 * compile time. These include all Localx, Argx, and method 322 * invocations. Also, NAMESEG and NAMESTRING because the type of 323 * any named object can be changed at runtime (for example, 324 * CopyObject will change the type of the target object.) 325 */ 326 break; 327 } 328 } 329 } 330 331 332 /******************************************************************************* 333 * 334 * FUNCTION: ApCheckForPredefinedObject 335 * 336 * PARAMETERS: Op - A parse node 337 * Name - The ACPI name to be checked 338 * 339 * RETURN: None 340 * 341 * DESCRIPTION: Check for a predefined name for a static object (created via 342 * the ASL Name operator). If it is a predefined ACPI name, ensure 343 * that the name does not require any arguments (which would 344 * require a control method implemenation of the name), and that 345 * the type of the object is one of the expected types for the 346 * predefined name. 347 * 348 ******************************************************************************/ 349 350 void 351 ApCheckForPredefinedObject ( 352 ACPI_PARSE_OBJECT *Op, 353 char *Name) 354 { 355 UINT32 Index; 356 ACPI_PARSE_OBJECT *ObjectOp; 357 const ACPI_PREDEFINED_INFO *ThisName; 358 359 360 /* 361 * Check for a real predefined name -- not a resource descriptor name 362 * or a predefined scope name 363 */ 364 Index = ApCheckForPredefinedName (Op, Name); 365 366 switch (Index) 367 { 368 case ACPI_NOT_RESERVED_NAME: /* No underscore or _Txx or _xxx name not matched */ 369 case ACPI_PREDEFINED_NAME: /* Resource Name or reserved scope name */ 370 case ACPI_COMPILER_RESERVED_NAME: /* A _Txx that was not emitted by compiler */ 371 372 /* Nothing to do */ 373 return; 374 375 case ACPI_EVENT_RESERVED_NAME: /* _Lxx/_Exx/_Wxx/_Qxx methods */ 376 377 /* 378 * These names must be control methods, by definition in ACPI spec. 379 * Also because they are defined to return no value. None of them 380 * require any arguments. 381 */ 382 AslError (ASL_ERROR, ASL_MSG_RESERVED_METHOD, Op, 383 "with zero arguments"); 384 return; 385 386 default: 387 388 break; 389 } 390 391 /* A standard predefined ACPI name */ 392 393 /* 394 * If this predefined name requires input arguments, then 395 * it must be implemented as a control method 396 */ 397 ThisName = &AcpiGbl_PredefinedMethods[Index]; 398 if (METHOD_GET_ARG_COUNT (ThisName->Info.ArgumentList) > 0) 399 { 400 AslError (ASL_ERROR, ASL_MSG_RESERVED_METHOD, Op, 401 "with arguments"); 402 return; 403 } 404 405 /* 406 * If no return value is expected from this predefined name, then 407 * it follows that it must be implemented as a control method 408 * (with zero args, because the args > 0 case was handled above) 409 * Examples are: _DIS, _INI, _IRC, _OFF, _ON, _PSx 410 */ 411 if (!ThisName->Info.ExpectedBtypes) 412 { 413 AslError (ASL_ERROR, ASL_MSG_RESERVED_METHOD, Op, 414 "with zero arguments"); 415 return; 416 } 417 418 /* Typecheck the actual object, it is the next argument */ 419 420 ObjectOp = Op->Asl.Child->Asl.Next; 421 ApCheckObjectType (ThisName->Info.Name, Op->Asl.Child->Asl.Next, 422 ThisName->Info.ExpectedBtypes, ACPI_NOT_PACKAGE_ELEMENT); 423 424 /* For packages, check the individual package elements */ 425 426 if (ObjectOp->Asl.ParseOpcode == PARSEOP_PACKAGE) 427 { 428 ApCheckPackage (ObjectOp, ThisName); 429 } 430 } 431 432 433 /******************************************************************************* 434 * 435 * FUNCTION: ApCheckForPredefinedName 436 * 437 * PARAMETERS: Op - A parse node 438 * Name - NameSeg to check 439 * 440 * RETURN: None 441 * 442 * DESCRIPTION: Check a NameSeg against the reserved list. 443 * 444 ******************************************************************************/ 445 446 UINT32 447 ApCheckForPredefinedName ( 448 ACPI_PARSE_OBJECT *Op, 449 char *Name) 450 { 451 UINT32 i; 452 const ACPI_PREDEFINED_INFO *ThisName; 453 454 455 if (Name[0] == 0) 456 { 457 AslError (ASL_ERROR, ASL_MSG_COMPILER_INTERNAL, Op, 458 "zero length name found"); 459 } 460 461 /* All reserved names are prefixed with a single underscore */ 462 463 if (Name[0] != '_') 464 { 465 return (ACPI_NOT_RESERVED_NAME); 466 } 467 468 /* Check for a standard predefined method name */ 469 470 ThisName = AcpiGbl_PredefinedMethods; 471 for (i = 0; ThisName->Info.Name[0]; i++) 472 { 473 if (ACPI_COMPARE_NAME (Name, ThisName->Info.Name)) 474 { 475 /* Return index into predefined array */ 476 return (i); 477 } 478 479 ThisName++; /* Does not account for extra package data, but is OK */ 480 } 481 482 /* Check for resource names and predefined scope names */ 483 484 ThisName = AcpiGbl_ResourceNames; 485 while (ThisName->Info.Name[0]) 486 { 487 if (ACPI_COMPARE_NAME (Name, ThisName->Info.Name)) 488 { 489 return (ACPI_PREDEFINED_NAME); 490 } 491 492 ThisName++; 493 } 494 495 ThisName = AcpiGbl_ScopeNames; 496 while (ThisName->Info.Name[0]) 497 { 498 if (ACPI_COMPARE_NAME (Name, ThisName->Info.Name)) 499 { 500 return (ACPI_PREDEFINED_NAME); 501 } 502 503 ThisName++; 504 } 505 506 /* Check for _Lxx/_Exx/_Wxx/_Qxx/_T_x. Warning if unknown predefined name */ 507 508 return (ApCheckForSpecialName (Op, Name)); 509 } 510 511 512 /******************************************************************************* 513 * 514 * FUNCTION: ApCheckForSpecialName 515 * 516 * PARAMETERS: Op - A parse node 517 * Name - NameSeg to check 518 * 519 * RETURN: None 520 * 521 * DESCRIPTION: Check for the "special" predefined names - 522 * _Lxx, _Exx, _Qxx, _Wxx, and _T_x 523 * 524 ******************************************************************************/ 525 526 static UINT32 527 ApCheckForSpecialName ( 528 ACPI_PARSE_OBJECT *Op, 529 char *Name) 530 { 531 532 /* 533 * Check for the "special" predefined names. We already know that the 534 * first character is an underscore. 535 * GPE: _Lxx 536 * GPE: _Exx 537 * GPE: _Wxx 538 * EC: _Qxx 539 */ 540 if ((Name[1] == 'L') || 541 (Name[1] == 'E') || 542 (Name[1] == 'W') || 543 (Name[1] == 'Q')) 544 { 545 /* The next two characters must be hex digits */ 546 547 if ((isxdigit ((int) Name[2])) && 548 (isxdigit ((int) Name[3]))) 549 { 550 return (ACPI_EVENT_RESERVED_NAME); 551 } 552 } 553 554 /* Check for the names reserved for the compiler itself: _T_x */ 555 556 else if ((Op->Asl.ExternalName[1] == 'T') && 557 (Op->Asl.ExternalName[2] == '_')) 558 { 559 /* Ignore if actually emitted by the compiler */ 560 561 if (Op->Asl.CompileFlags & NODE_COMPILER_EMITTED) 562 { 563 return (ACPI_NOT_RESERVED_NAME); 564 } 565 566 /* 567 * Was not actually emitted by the compiler. This is a special case, 568 * however. If the ASL code being compiled was the result of a 569 * dissasembly, it may possibly contain valid compiler-emitted names 570 * of the form "_T_x". We don't want to issue an error or even a 571 * warning and force the user to manually change the names. So, we 572 * will issue a remark instead. 573 */ 574 AslError (ASL_REMARK, ASL_MSG_COMPILER_RESERVED, 575 Op, Op->Asl.ExternalName); 576 return (ACPI_COMPILER_RESERVED_NAME); 577 } 578 579 /* 580 * The name didn't match any of the known predefined names. Flag it as a 581 * warning, since the entire namespace starting with an underscore is 582 * reserved by the ACPI spec. 583 */ 584 AslError (ASL_WARNING, ASL_MSG_UNKNOWN_RESERVED_NAME, 585 Op, Op->Asl.ExternalName); 586 587 return (ACPI_NOT_RESERVED_NAME); 588 } 589 590 591 /******************************************************************************* 592 * 593 * FUNCTION: ApCheckObjectType 594 * 595 * PARAMETERS: PredefinedName - Name of the predefined object we are checking 596 * Op - Current parse node 597 * ExpectedBtypes - Bitmap of expected return type(s) 598 * PackageIndex - Index of object within parent package (if 599 * applicable - ACPI_NOT_PACKAGE_ELEMENT 600 * otherwise) 601 * 602 * RETURN: None 603 * 604 * DESCRIPTION: Check if the object type is one of the types that is expected 605 * by the predefined name. Only a limited number of object types 606 * can be returned by the predefined names. 607 * 608 ******************************************************************************/ 609 610 ACPI_STATUS 611 ApCheckObjectType ( 612 const char *PredefinedName, 613 ACPI_PARSE_OBJECT *Op, 614 UINT32 ExpectedBtypes, 615 UINT32 PackageIndex) 616 { 617 UINT32 ReturnBtype; 618 char *TypeName; 619 620 621 if (!Op) 622 { 623 return (AE_TYPE); 624 } 625 626 /* Map the parse opcode to a bitmapped return type (RTYPE) */ 627 628 switch (Op->Asl.ParseOpcode) 629 { 630 case PARSEOP_ZERO: 631 case PARSEOP_ONE: 632 case PARSEOP_ONES: 633 case PARSEOP_INTEGER: 634 635 ReturnBtype = ACPI_RTYPE_INTEGER; 636 TypeName = "Integer"; 637 break; 638 639 case PARSEOP_STRING_LITERAL: 640 641 ReturnBtype = ACPI_RTYPE_STRING; 642 TypeName = "String"; 643 break; 644 645 case PARSEOP_BUFFER: 646 647 ReturnBtype = ACPI_RTYPE_BUFFER; 648 TypeName = "Buffer"; 649 break; 650 651 case PARSEOP_PACKAGE: 652 case PARSEOP_VAR_PACKAGE: 653 654 ReturnBtype = ACPI_RTYPE_PACKAGE; 655 TypeName = "Package"; 656 break; 657 658 case PARSEOP_NAMESEG: 659 case PARSEOP_NAMESTRING: 660 /* 661 * Ignore any named references within a package object. 662 * 663 * For Package objects, references are allowed instead of any of the 664 * standard data types (Integer/String/Buffer/Package). These 665 * references are resolved at runtime. NAMESEG and NAMESTRING are 666 * impossible to typecheck at compile time because the type of 667 * any named object can be changed at runtime (for example, 668 * CopyObject will change the type of the target object). 669 */ 670 if (PackageIndex != ACPI_NOT_PACKAGE_ELEMENT) 671 { 672 return (AE_OK); 673 } 674 675 ReturnBtype = ACPI_RTYPE_REFERENCE; 676 TypeName = "Reference"; 677 break; 678 679 default: 680 681 /* Not one of the supported object types */ 682 683 TypeName = UtGetOpName (Op->Asl.ParseOpcode); 684 goto TypeErrorExit; 685 } 686 687 /* Exit if the object is one of the expected types */ 688 689 if (ReturnBtype & ExpectedBtypes) 690 { 691 return (AE_OK); 692 } 693 694 695 TypeErrorExit: 696 697 /* Format the expected types and emit an error message */ 698 699 AcpiUtGetExpectedReturnTypes (StringBuffer, ExpectedBtypes); 700 701 if (PackageIndex == ACPI_NOT_PACKAGE_ELEMENT) 702 { 703 sprintf (MsgBuffer, "%4.4s: found %s, %s required", 704 PredefinedName, TypeName, StringBuffer); 705 } 706 else 707 { 708 sprintf (MsgBuffer, "%4.4s: found %s at index %u, %s required", 709 PredefinedName, TypeName, PackageIndex, StringBuffer); 710 } 711 712 AslError (ASL_ERROR, ASL_MSG_RESERVED_OPERAND_TYPE, Op, MsgBuffer); 713 return (AE_TYPE); 714 } 715 716 717 /******************************************************************************* 718 * 719 * FUNCTION: ApDisplayReservedNames 720 * 721 * PARAMETERS: None 722 * 723 * RETURN: None 724 * 725 * DESCRIPTION: Dump information about the ACPI predefined names and predefined 726 * resource descriptor names. 727 * 728 ******************************************************************************/ 729 730 void 731 ApDisplayReservedNames ( 732 void) 733 { 734 const ACPI_PREDEFINED_INFO *ThisName; 735 UINT32 Count; 736 UINT32 NumTypes; 737 738 739 /* 740 * Predefined names/methods 741 */ 742 printf ("\nPredefined Name Information\n\n"); 743 744 Count = 0; 745 ThisName = AcpiGbl_PredefinedMethods; 746 while (ThisName->Info.Name[0]) 747 { 748 AcpiUtDisplayPredefinedMethod (MsgBuffer, ThisName, FALSE); 749 Count++; 750 ThisName = AcpiUtGetNextPredefinedMethod (ThisName); 751 } 752 753 printf ("%u Predefined Names are recognized\n", Count); 754 755 /* 756 * Resource Descriptor names 757 */ 758 printf ("\nPredefined Names for Resource Descriptor Fields\n\n"); 759 760 Count = 0; 761 ThisName = AcpiGbl_ResourceNames; 762 while (ThisName->Info.Name[0]) 763 { 764 NumTypes = AcpiUtGetResourceBitWidth (MsgBuffer, 765 ThisName->Info.ArgumentList); 766 767 printf ("%4.4s Field is %s bits wide%s\n", 768 ThisName->Info.Name, MsgBuffer, 769 (NumTypes > 1) ? " (depending on descriptor type)" : ""); 770 771 Count++; 772 ThisName++; 773 } 774 775 printf ("%u Resource Descriptor Field Names are recognized\n", Count); 776 777 /* 778 * Predefined scope names 779 */ 780 printf ("\nPredefined Scope/Device Names (automatically created at root)\n\n"); 781 782 ThisName = AcpiGbl_ScopeNames; 783 while (ThisName->Info.Name[0]) 784 { 785 printf ("%4.4s Scope/Device\n", ThisName->Info.Name); 786 ThisName++; 787 } 788 } 789