Home | History | Annotate | Line # | Download | only in compiler
aslutils.c revision 1.1.1.14
      1       1.1    jruoho /******************************************************************************
      2       1.1    jruoho  *
      3       1.1    jruoho  * Module Name: aslutils -- compiler utilities
      4       1.1    jruoho  *
      5       1.1    jruoho  *****************************************************************************/
      6       1.1    jruoho 
      7   1.1.1.2    jruoho /*
      8  1.1.1.14  christos  * Copyright (C) 2000 - 2018, Intel Corp.
      9       1.1    jruoho  * All rights reserved.
     10       1.1    jruoho  *
     11   1.1.1.2    jruoho  * Redistribution and use in source and binary forms, with or without
     12   1.1.1.2    jruoho  * modification, are permitted provided that the following conditions
     13   1.1.1.2    jruoho  * are met:
     14   1.1.1.2    jruoho  * 1. Redistributions of source code must retain the above copyright
     15   1.1.1.2    jruoho  *    notice, this list of conditions, and the following disclaimer,
     16   1.1.1.2    jruoho  *    without modification.
     17   1.1.1.2    jruoho  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
     18   1.1.1.2    jruoho  *    substantially similar to the "NO WARRANTY" disclaimer below
     19   1.1.1.2    jruoho  *    ("Disclaimer") and any redistribution must be conditioned upon
     20   1.1.1.2    jruoho  *    including a substantially similar Disclaimer requirement for further
     21   1.1.1.2    jruoho  *    binary redistribution.
     22   1.1.1.2    jruoho  * 3. Neither the names of the above-listed copyright holders nor the names
     23   1.1.1.2    jruoho  *    of any contributors may be used to endorse or promote products derived
     24   1.1.1.2    jruoho  *    from this software without specific prior written permission.
     25   1.1.1.2    jruoho  *
     26   1.1.1.2    jruoho  * Alternatively, this software may be distributed under the terms of the
     27   1.1.1.2    jruoho  * GNU General Public License ("GPL") version 2 as published by the Free
     28   1.1.1.2    jruoho  * Software Foundation.
     29   1.1.1.2    jruoho  *
     30   1.1.1.2    jruoho  * NO WARRANTY
     31   1.1.1.2    jruoho  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     32   1.1.1.2    jruoho  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     33   1.1.1.2    jruoho  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
     34   1.1.1.2    jruoho  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
     35   1.1.1.2    jruoho  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     36   1.1.1.2    jruoho  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     37   1.1.1.2    jruoho  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     38   1.1.1.2    jruoho  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     39   1.1.1.2    jruoho  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
     40   1.1.1.2    jruoho  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     41   1.1.1.2    jruoho  * POSSIBILITY OF SUCH DAMAGES.
     42   1.1.1.2    jruoho  */
     43       1.1    jruoho 
     44       1.1    jruoho #include "aslcompiler.h"
     45       1.1    jruoho #include "aslcompiler.y.h"
     46   1.1.1.2    jruoho #include "acdisasm.h"
     47       1.1    jruoho #include "acnamesp.h"
     48       1.1    jruoho #include "amlcode.h"
     49   1.1.1.8  christos #include "acapps.h"
     50   1.1.1.8  christos #include <sys/stat.h>
     51   1.1.1.8  christos 
     52       1.1    jruoho 
     53       1.1    jruoho #define _COMPONENT          ACPI_COMPILER
     54       1.1    jruoho         ACPI_MODULE_NAME    ("aslutils")
     55       1.1    jruoho 
     56       1.1    jruoho 
     57       1.1    jruoho /* Local prototypes */
     58       1.1    jruoho 
     59       1.1    jruoho static void
     60       1.1    jruoho UtPadNameWithUnderscores (
     61       1.1    jruoho     char                    *NameSeg,
     62       1.1    jruoho     char                    *PaddedNameSeg);
     63       1.1    jruoho 
     64       1.1    jruoho static void
     65       1.1    jruoho UtAttachNameseg (
     66       1.1    jruoho     ACPI_PARSE_OBJECT       *Op,
     67       1.1    jruoho     char                    *Name);
     68       1.1    jruoho 
     69       1.1    jruoho 
     70   1.1.1.9  christos /*******************************************************************************
     71   1.1.1.9  christos  *
     72   1.1.1.9  christos  * FUNCTION:    UtIsBigEndianMachine
     73   1.1.1.9  christos  *
     74   1.1.1.9  christos  * PARAMETERS:  None
     75   1.1.1.9  christos  *
     76   1.1.1.9  christos  * RETURN:      TRUE if machine is big endian
     77   1.1.1.9  christos  *              FALSE if machine is little endian
     78   1.1.1.9  christos  *
     79   1.1.1.9  christos  * DESCRIPTION: Detect whether machine is little endian or big endian.
     80   1.1.1.9  christos  *
     81   1.1.1.9  christos  ******************************************************************************/
     82   1.1.1.9  christos 
     83   1.1.1.9  christos UINT8
     84   1.1.1.9  christos UtIsBigEndianMachine (
     85   1.1.1.9  christos     void)
     86   1.1.1.9  christos {
     87   1.1.1.9  christos     union {
     88   1.1.1.9  christos         UINT32              Integer;
     89   1.1.1.9  christos         UINT8               Bytes[4];
     90   1.1.1.9  christos     } Overlay =                 {0xFF000000};
     91   1.1.1.9  christos 
     92   1.1.1.9  christos 
     93   1.1.1.9  christos     return (Overlay.Bytes[0]); /* Returns 0xFF (TRUE) for big endian */
     94   1.1.1.9  christos }
     95   1.1.1.9  christos 
     96   1.1.1.9  christos 
     97   1.1.1.8  christos /******************************************************************************
     98   1.1.1.8  christos  *
     99   1.1.1.8  christos  * FUNCTION:    UtQueryForOverwrite
    100   1.1.1.8  christos  *
    101   1.1.1.8  christos  * PARAMETERS:  Pathname            - Output filename
    102   1.1.1.8  christos  *
    103   1.1.1.8  christos  * RETURN:      TRUE if file does not exist or overwrite is authorized
    104   1.1.1.8  christos  *
    105   1.1.1.8  christos  * DESCRIPTION: Query for file overwrite if it already exists.
    106   1.1.1.8  christos  *
    107   1.1.1.8  christos  ******************************************************************************/
    108   1.1.1.8  christos 
    109   1.1.1.8  christos BOOLEAN
    110   1.1.1.8  christos UtQueryForOverwrite (
    111   1.1.1.8  christos     char                    *Pathname)
    112   1.1.1.8  christos {
    113   1.1.1.8  christos     struct stat             StatInfo;
    114   1.1.1.8  christos 
    115   1.1.1.8  christos 
    116   1.1.1.8  christos     if (!stat (Pathname, &StatInfo))
    117   1.1.1.8  christos     {
    118   1.1.1.8  christos         fprintf (stderr, "Target file \"%s\" already exists, overwrite? [y|n] ",
    119   1.1.1.8  christos             Pathname);
    120   1.1.1.8  christos 
    121   1.1.1.8  christos         if (getchar () != 'y')
    122   1.1.1.8  christos         {
    123   1.1.1.8  christos             return (FALSE);
    124   1.1.1.8  christos         }
    125   1.1.1.8  christos     }
    126   1.1.1.8  christos 
    127   1.1.1.8  christos     return (TRUE);
    128   1.1.1.8  christos }
    129   1.1.1.8  christos 
    130   1.1.1.8  christos 
    131       1.1    jruoho /*******************************************************************************
    132       1.1    jruoho  *
    133   1.1.1.2    jruoho  * FUNCTION:    UtDisplaySupportedTables
    134   1.1.1.2    jruoho  *
    135   1.1.1.2    jruoho  * PARAMETERS:  None
    136   1.1.1.2    jruoho  *
    137   1.1.1.2    jruoho  * RETURN:      None
    138   1.1.1.2    jruoho  *
    139   1.1.1.2    jruoho  * DESCRIPTION: Print all supported ACPI table names.
    140   1.1.1.2    jruoho  *
    141   1.1.1.2    jruoho  ******************************************************************************/
    142   1.1.1.2    jruoho 
    143   1.1.1.2    jruoho void
    144   1.1.1.2    jruoho UtDisplaySupportedTables (
    145   1.1.1.2    jruoho     void)
    146   1.1.1.2    jruoho {
    147   1.1.1.7  christos     const AH_TABLE          *TableData;
    148   1.1.1.4  christos     UINT32                  i;
    149   1.1.1.2    jruoho 
    150   1.1.1.2    jruoho 
    151   1.1.1.4  christos     printf ("\nACPI tables supported by iASL version %8.8X:\n"
    152   1.1.1.4  christos         "  (Compiler, Disassembler, Template Generator)\n\n",
    153   1.1.1.4  christos         ACPI_CA_VERSION);
    154   1.1.1.2    jruoho 
    155   1.1.1.7  christos     /* All ACPI tables with the common table header */
    156   1.1.1.2    jruoho 
    157   1.1.1.7  christos     printf ("\n  Supported ACPI tables:\n");
    158  1.1.1.11  christos     for (TableData = Gbl_AcpiSupportedTables, i = 1;
    159   1.1.1.7  christos          TableData->Signature; TableData++, i++)
    160   1.1.1.2    jruoho     {
    161   1.1.1.7  christos         printf ("%8u) %s    %s\n", i,
    162   1.1.1.7  christos             TableData->Signature, TableData->Description);
    163   1.1.1.2    jruoho     }
    164   1.1.1.2    jruoho }
    165   1.1.1.2    jruoho 
    166   1.1.1.2    jruoho 
    167   1.1.1.2    jruoho /*******************************************************************************
    168   1.1.1.2    jruoho  *
    169   1.1.1.4  christos  * FUNCTION:    UtDisplayConstantOpcodes
    170       1.1    jruoho  *
    171       1.1    jruoho  * PARAMETERS:  None
    172       1.1    jruoho  *
    173       1.1    jruoho  * RETURN:      None
    174       1.1    jruoho  *
    175       1.1    jruoho  * DESCRIPTION: Print AML opcodes that can be used in constant expressions.
    176       1.1    jruoho  *
    177       1.1    jruoho  ******************************************************************************/
    178       1.1    jruoho 
    179       1.1    jruoho void
    180       1.1    jruoho UtDisplayConstantOpcodes (
    181       1.1    jruoho     void)
    182       1.1    jruoho {
    183       1.1    jruoho     UINT32                  i;
    184       1.1    jruoho 
    185       1.1    jruoho 
    186       1.1    jruoho     printf ("Constant expression opcode information\n\n");
    187       1.1    jruoho 
    188       1.1    jruoho     for (i = 0; i < sizeof (AcpiGbl_AmlOpInfo) / sizeof (ACPI_OPCODE_INFO); i++)
    189       1.1    jruoho     {
    190       1.1    jruoho         if (AcpiGbl_AmlOpInfo[i].Flags & AML_CONSTANT)
    191       1.1    jruoho         {
    192       1.1    jruoho             printf ("%s\n", AcpiGbl_AmlOpInfo[i].Name);
    193       1.1    jruoho         }
    194       1.1    jruoho     }
    195       1.1    jruoho }
    196       1.1    jruoho 
    197       1.1    jruoho 
    198       1.1    jruoho /*******************************************************************************
    199       1.1    jruoho  *
    200       1.1    jruoho  * FUNCTION:    UtBeginEvent
    201       1.1    jruoho  *
    202   1.1.1.4  christos  * PARAMETERS:  Name                - Ascii name of this event
    203       1.1    jruoho  *
    204   1.1.1.4  christos  * RETURN:      Event number (integer index)
    205       1.1    jruoho  *
    206       1.1    jruoho  * DESCRIPTION: Saves the current time with this event
    207       1.1    jruoho  *
    208       1.1    jruoho  ******************************************************************************/
    209       1.1    jruoho 
    210       1.1    jruoho UINT8
    211       1.1    jruoho UtBeginEvent (
    212       1.1    jruoho     char                    *Name)
    213       1.1    jruoho {
    214       1.1    jruoho 
    215       1.1    jruoho     if (AslGbl_NextEvent >= ASL_NUM_EVENTS)
    216       1.1    jruoho     {
    217       1.1    jruoho         AcpiOsPrintf ("Ran out of compiler event structs!\n");
    218       1.1    jruoho         return (AslGbl_NextEvent);
    219       1.1    jruoho     }
    220       1.1    jruoho 
    221       1.1    jruoho     /* Init event with current (start) time */
    222       1.1    jruoho 
    223       1.1    jruoho     AslGbl_Events[AslGbl_NextEvent].StartTime = AcpiOsGetTimer ();
    224       1.1    jruoho     AslGbl_Events[AslGbl_NextEvent].EventName = Name;
    225       1.1    jruoho     AslGbl_Events[AslGbl_NextEvent].Valid = TRUE;
    226       1.1    jruoho     return (AslGbl_NextEvent++);
    227       1.1    jruoho }
    228       1.1    jruoho 
    229       1.1    jruoho 
    230       1.1    jruoho /*******************************************************************************
    231       1.1    jruoho  *
    232       1.1    jruoho  * FUNCTION:    UtEndEvent
    233       1.1    jruoho  *
    234   1.1.1.4  christos  * PARAMETERS:  Event               - Event number (integer index)
    235       1.1    jruoho  *
    236       1.1    jruoho  * RETURN:      None
    237       1.1    jruoho  *
    238       1.1    jruoho  * DESCRIPTION: Saves the current time (end time) with this event
    239       1.1    jruoho  *
    240       1.1    jruoho  ******************************************************************************/
    241       1.1    jruoho 
    242       1.1    jruoho void
    243       1.1    jruoho UtEndEvent (
    244   1.1.1.4  christos     UINT8                   Event)
    245       1.1    jruoho {
    246       1.1    jruoho 
    247       1.1    jruoho     if (Event >= ASL_NUM_EVENTS)
    248       1.1    jruoho     {
    249       1.1    jruoho         return;
    250       1.1    jruoho     }
    251       1.1    jruoho 
    252       1.1    jruoho     /* Insert end time for event */
    253       1.1    jruoho 
    254       1.1    jruoho     AslGbl_Events[Event].EndTime = AcpiOsGetTimer ();
    255       1.1    jruoho }
    256       1.1    jruoho 
    257       1.1    jruoho 
    258       1.1    jruoho /*******************************************************************************
    259       1.1    jruoho  *
    260       1.1    jruoho  * FUNCTION:    DbgPrint
    261       1.1    jruoho  *
    262   1.1.1.4  christos  * PARAMETERS:  Type                - Type of output
    263   1.1.1.4  christos  *              Fmt                 - Printf format string
    264   1.1.1.4  christos  *              ...                 - variable printf list
    265       1.1    jruoho  *
    266       1.1    jruoho  * RETURN:      None
    267       1.1    jruoho  *
    268   1.1.1.4  christos  * DESCRIPTION: Conditional print statement. Prints to stderr only if the
    269       1.1    jruoho  *              debug flag is set.
    270       1.1    jruoho  *
    271       1.1    jruoho  ******************************************************************************/
    272       1.1    jruoho 
    273       1.1    jruoho void
    274       1.1    jruoho DbgPrint (
    275       1.1    jruoho     UINT32                  Type,
    276       1.1    jruoho     char                    *Fmt,
    277       1.1    jruoho     ...)
    278       1.1    jruoho {
    279       1.1    jruoho     va_list                 Args;
    280       1.1    jruoho 
    281       1.1    jruoho 
    282       1.1    jruoho     if (!Gbl_DebugFlag)
    283       1.1    jruoho     {
    284       1.1    jruoho         return;
    285       1.1    jruoho     }
    286       1.1    jruoho 
    287       1.1    jruoho     if ((Type == ASL_PARSE_OUTPUT) &&
    288       1.1    jruoho         (!(AslCompilerdebug)))
    289       1.1    jruoho     {
    290       1.1    jruoho         return;
    291       1.1    jruoho     }
    292       1.1    jruoho 
    293   1.1.1.4  christos     va_start (Args, Fmt);
    294       1.1    jruoho     (void) vfprintf (stderr, Fmt, Args);
    295       1.1    jruoho     va_end (Args);
    296       1.1    jruoho     return;
    297       1.1    jruoho }
    298       1.1    jruoho 
    299       1.1    jruoho 
    300       1.1    jruoho /*******************************************************************************
    301       1.1    jruoho  *
    302       1.1    jruoho  * FUNCTION:    UtSetParseOpName
    303       1.1    jruoho  *
    304   1.1.1.4  christos  * PARAMETERS:  Op                  - Parse op to be named.
    305       1.1    jruoho  *
    306       1.1    jruoho  * RETURN:      None
    307       1.1    jruoho  *
    308       1.1    jruoho  * DESCRIPTION: Insert the ascii name of the parse opcode
    309       1.1    jruoho  *
    310       1.1    jruoho  ******************************************************************************/
    311       1.1    jruoho 
    312       1.1    jruoho void
    313       1.1    jruoho UtSetParseOpName (
    314       1.1    jruoho     ACPI_PARSE_OBJECT       *Op)
    315       1.1    jruoho {
    316       1.1    jruoho 
    317  1.1.1.14  christos     AcpiUtSafeStrncpy (Op->Asl.ParseOpName, UtGetOpName (Op->Asl.ParseOpcode),
    318       1.1    jruoho         ACPI_MAX_PARSEOP_NAME);
    319       1.1    jruoho }
    320       1.1    jruoho 
    321       1.1    jruoho 
    322       1.1    jruoho /*******************************************************************************
    323       1.1    jruoho  *
    324       1.1    jruoho  * FUNCTION:    UtDisplaySummary
    325       1.1    jruoho  *
    326   1.1.1.4  christos  * PARAMETERS:  FileID              - ID of outpout file
    327       1.1    jruoho  *
    328       1.1    jruoho  * RETURN:      None
    329       1.1    jruoho  *
    330       1.1    jruoho  * DESCRIPTION: Display compilation statistics
    331       1.1    jruoho  *
    332       1.1    jruoho  ******************************************************************************/
    333       1.1    jruoho 
    334       1.1    jruoho void
    335       1.1    jruoho UtDisplaySummary (
    336       1.1    jruoho     UINT32                  FileId)
    337       1.1    jruoho {
    338   1.1.1.4  christos     UINT32                  i;
    339   1.1.1.4  christos 
    340       1.1    jruoho 
    341       1.1    jruoho     if (FileId != ASL_FILE_STDOUT)
    342       1.1    jruoho     {
    343       1.1    jruoho         /* Compiler name and version number */
    344       1.1    jruoho 
    345  1.1.1.11  christos         FlPrintFile (FileId, "%s version %X [%s]\n\n",
    346  1.1.1.11  christos             ASL_COMPILER_NAME, (UINT32) ACPI_CA_VERSION, __DATE__);
    347       1.1    jruoho     }
    348       1.1    jruoho 
    349   1.1.1.4  christos     /* Summary of main input and output files */
    350   1.1.1.4  christos 
    351       1.1    jruoho     if (Gbl_FileType == ASL_INPUT_TYPE_ASCII_DATA)
    352       1.1    jruoho     {
    353       1.1    jruoho         FlPrintFile (FileId,
    354   1.1.1.4  christos             "%-14s %s - %u lines, %u bytes, %u fields\n",
    355   1.1.1.4  christos             "Table Input:",
    356       1.1    jruoho             Gbl_Files[ASL_FILE_INPUT].Filename, Gbl_CurrentLineNumber,
    357       1.1    jruoho             Gbl_InputByteCount, Gbl_InputFieldCount);
    358       1.1    jruoho 
    359       1.1    jruoho         if ((Gbl_ExceptionCount[ASL_ERROR] == 0) || (Gbl_IgnoreErrors))
    360       1.1    jruoho         {
    361       1.1    jruoho             FlPrintFile (FileId,
    362   1.1.1.4  christos                 "%-14s %s - %u bytes\n",
    363   1.1.1.4  christos                 "Binary Output:",
    364       1.1    jruoho                 Gbl_Files[ASL_FILE_AML_OUTPUT].Filename, Gbl_TableLength);
    365       1.1    jruoho         }
    366       1.1    jruoho     }
    367       1.1    jruoho     else
    368       1.1    jruoho     {
    369       1.1    jruoho         FlPrintFile (FileId,
    370   1.1.1.4  christos             "%-14s %s - %u lines, %u bytes, %u keywords\n",
    371   1.1.1.4  christos             "ASL Input:",
    372       1.1    jruoho             Gbl_Files[ASL_FILE_INPUT].Filename, Gbl_CurrentLineNumber,
    373   1.1.1.7  christos             Gbl_OriginalInputFileSize, TotalKeywords);
    374       1.1    jruoho 
    375       1.1    jruoho         /* AML summary */
    376       1.1    jruoho 
    377       1.1    jruoho         if ((Gbl_ExceptionCount[ASL_ERROR] == 0) || (Gbl_IgnoreErrors))
    378       1.1    jruoho         {
    379   1.1.1.7  christos             if (Gbl_Files[ASL_FILE_AML_OUTPUT].Handle)
    380   1.1.1.7  christos             {
    381   1.1.1.7  christos                 FlPrintFile (FileId,
    382   1.1.1.8  christos                     "%-14s %s - %u bytes, %u named objects, "
    383   1.1.1.8  christos                     "%u executable opcodes\n",
    384   1.1.1.7  christos                     "AML Output:",
    385   1.1.1.8  christos                     Gbl_Files[ASL_FILE_AML_OUTPUT].Filename,
    386   1.1.1.8  christos                     FlGetFileSize (ASL_FILE_AML_OUTPUT),
    387   1.1.1.7  christos                     TotalNamedObjects, TotalExecutableOpcodes);
    388   1.1.1.7  christos             }
    389       1.1    jruoho         }
    390       1.1    jruoho     }
    391       1.1    jruoho 
    392   1.1.1.4  christos     /* Display summary of any optional files */
    393   1.1.1.4  christos 
    394   1.1.1.4  christos     for (i = ASL_FILE_SOURCE_OUTPUT; i <= ASL_MAX_FILE_TYPE; i++)
    395   1.1.1.4  christos     {
    396   1.1.1.4  christos         if (!Gbl_Files[i].Filename || !Gbl_Files[i].Handle)
    397   1.1.1.4  christos         {
    398   1.1.1.4  christos             continue;
    399   1.1.1.4  christos         }
    400   1.1.1.4  christos 
    401   1.1.1.4  christos         /* .SRC is a temp file unless specifically requested */
    402   1.1.1.4  christos 
    403   1.1.1.4  christos         if ((i == ASL_FILE_SOURCE_OUTPUT) && (!Gbl_SourceOutputFlag))
    404   1.1.1.4  christos         {
    405   1.1.1.4  christos             continue;
    406   1.1.1.4  christos         }
    407   1.1.1.4  christos 
    408   1.1.1.7  christos         /* .PRE is the preprocessor intermediate file */
    409   1.1.1.4  christos 
    410   1.1.1.7  christos         if ((i == ASL_FILE_PREPROCESSOR)  && (!Gbl_KeepPreprocessorTempFile))
    411   1.1.1.4  christos         {
    412   1.1.1.4  christos             continue;
    413   1.1.1.4  christos         }
    414   1.1.1.4  christos 
    415   1.1.1.4  christos         FlPrintFile (FileId, "%14s %s - %u bytes\n",
    416   1.1.1.4  christos             Gbl_Files[i].ShortDescription,
    417   1.1.1.4  christos             Gbl_Files[i].Filename, FlGetFileSize (i));
    418   1.1.1.4  christos     }
    419   1.1.1.4  christos 
    420       1.1    jruoho     /* Error summary */
    421       1.1    jruoho 
    422       1.1    jruoho     FlPrintFile (FileId,
    423   1.1.1.4  christos         "\nCompilation complete. %u Errors, %u Warnings, %u Remarks",
    424       1.1    jruoho         Gbl_ExceptionCount[ASL_ERROR],
    425       1.1    jruoho         Gbl_ExceptionCount[ASL_WARNING] +
    426       1.1    jruoho             Gbl_ExceptionCount[ASL_WARNING2] +
    427       1.1    jruoho             Gbl_ExceptionCount[ASL_WARNING3],
    428       1.1    jruoho         Gbl_ExceptionCount[ASL_REMARK]);
    429       1.1    jruoho 
    430       1.1    jruoho     if (Gbl_FileType != ASL_INPUT_TYPE_ASCII_DATA)
    431       1.1    jruoho     {
    432   1.1.1.6  christos         FlPrintFile (FileId, ", %u Optimizations",
    433   1.1.1.6  christos             Gbl_ExceptionCount[ASL_OPTIMIZATION]);
    434   1.1.1.6  christos 
    435   1.1.1.6  christos         if (TotalFolds)
    436   1.1.1.6  christos         {
    437   1.1.1.6  christos             FlPrintFile (FileId, ", %u Constants Folded", TotalFolds);
    438   1.1.1.6  christos         }
    439       1.1    jruoho     }
    440       1.1    jruoho 
    441       1.1    jruoho     FlPrintFile (FileId, "\n");
    442       1.1    jruoho }
    443       1.1    jruoho 
    444       1.1    jruoho 
    445       1.1    jruoho /*******************************************************************************
    446       1.1    jruoho  *
    447   1.1.1.4  christos  * FUNCTION:    UtCheckIntegerRange
    448       1.1    jruoho  *
    449   1.1.1.4  christos  * PARAMETERS:  Op                  - Integer parse node
    450   1.1.1.4  christos  *              LowValue            - Smallest allowed value
    451   1.1.1.4  christos  *              HighValue           - Largest allowed value
    452       1.1    jruoho  *
    453       1.1    jruoho  * RETURN:      Op if OK, otherwise NULL
    454       1.1    jruoho  *
    455       1.1    jruoho  * DESCRIPTION: Check integer for an allowable range
    456       1.1    jruoho  *
    457       1.1    jruoho  ******************************************************************************/
    458       1.1    jruoho 
    459       1.1    jruoho ACPI_PARSE_OBJECT *
    460       1.1    jruoho UtCheckIntegerRange (
    461       1.1    jruoho     ACPI_PARSE_OBJECT       *Op,
    462       1.1    jruoho     UINT32                  LowValue,
    463       1.1    jruoho     UINT32                  HighValue)
    464       1.1    jruoho {
    465       1.1    jruoho 
    466       1.1    jruoho     if (!Op)
    467       1.1    jruoho     {
    468   1.1.1.4  christos         return (NULL);
    469       1.1    jruoho     }
    470       1.1    jruoho 
    471   1.1.1.4  christos     if ((Op->Asl.Value.Integer < LowValue) ||
    472   1.1.1.4  christos         (Op->Asl.Value.Integer > HighValue))
    473       1.1    jruoho     {
    474   1.1.1.4  christos         sprintf (MsgBuffer, "0x%X, allowable: 0x%X-0x%X",
    475   1.1.1.4  christos             (UINT32) Op->Asl.Value.Integer, LowValue, HighValue);
    476       1.1    jruoho 
    477   1.1.1.4  christos         AslError (ASL_ERROR, ASL_MSG_RANGE, Op, MsgBuffer);
    478   1.1.1.4  christos         return (NULL);
    479       1.1    jruoho     }
    480       1.1    jruoho 
    481   1.1.1.4  christos     return (Op);
    482       1.1    jruoho }
    483       1.1    jruoho 
    484       1.1    jruoho 
    485       1.1    jruoho /*******************************************************************************
    486       1.1    jruoho  *
    487       1.1    jruoho  * FUNCTION:    UtInternalizeName
    488       1.1    jruoho  *
    489   1.1.1.4  christos  * PARAMETERS:  ExternalName        - Name to convert
    490   1.1.1.4  christos  *              ConvertedName       - Where the converted name is returned
    491       1.1    jruoho  *
    492       1.1    jruoho  * RETURN:      Status
    493       1.1    jruoho  *
    494       1.1    jruoho  * DESCRIPTION: Convert an external (ASL) name to an internal (AML) name
    495       1.1    jruoho  *
    496       1.1    jruoho  ******************************************************************************/
    497       1.1    jruoho 
    498       1.1    jruoho ACPI_STATUS
    499       1.1    jruoho UtInternalizeName (
    500       1.1    jruoho     char                    *ExternalName,
    501       1.1    jruoho     char                    **ConvertedName)
    502       1.1    jruoho {
    503       1.1    jruoho     ACPI_NAMESTRING_INFO    Info;
    504       1.1    jruoho     ACPI_STATUS             Status;
    505       1.1    jruoho 
    506       1.1    jruoho 
    507       1.1    jruoho     if (!ExternalName)
    508       1.1    jruoho     {
    509       1.1    jruoho         return (AE_OK);
    510       1.1    jruoho     }
    511       1.1    jruoho 
    512       1.1    jruoho     /* Get the length of the new internal name */
    513       1.1    jruoho 
    514       1.1    jruoho     Info.ExternalName = ExternalName;
    515       1.1    jruoho     AcpiNsGetInternalNameLength (&Info);
    516       1.1    jruoho 
    517   1.1.1.5  christos     /* We need a segment to store the internal name */
    518       1.1    jruoho 
    519  1.1.1.13  christos     Info.InternalName = UtLocalCacheCalloc (Info.Length);
    520       1.1    jruoho 
    521       1.1    jruoho     /* Build the name */
    522       1.1    jruoho 
    523       1.1    jruoho     Status = AcpiNsBuildInternalName (&Info);
    524       1.1    jruoho     if (ACPI_FAILURE (Status))
    525       1.1    jruoho     {
    526       1.1    jruoho         return (Status);
    527       1.1    jruoho     }
    528       1.1    jruoho 
    529       1.1    jruoho     *ConvertedName = Info.InternalName;
    530       1.1    jruoho     return (AE_OK);
    531       1.1    jruoho }
    532       1.1    jruoho 
    533       1.1    jruoho 
    534       1.1    jruoho /*******************************************************************************
    535       1.1    jruoho  *
    536       1.1    jruoho  * FUNCTION:    UtPadNameWithUnderscores
    537       1.1    jruoho  *
    538   1.1.1.4  christos  * PARAMETERS:  NameSeg             - Input nameseg
    539   1.1.1.4  christos  *              PaddedNameSeg       - Output padded nameseg
    540       1.1    jruoho  *
    541       1.1    jruoho  * RETURN:      Padded nameseg.
    542       1.1    jruoho  *
    543       1.1    jruoho  * DESCRIPTION: Pads a NameSeg with underscores if necessary to form a full
    544       1.1    jruoho  *              ACPI_NAME.
    545       1.1    jruoho  *
    546       1.1    jruoho  ******************************************************************************/
    547       1.1    jruoho 
    548       1.1    jruoho static void
    549       1.1    jruoho UtPadNameWithUnderscores (
    550       1.1    jruoho     char                    *NameSeg,
    551       1.1    jruoho     char                    *PaddedNameSeg)
    552       1.1    jruoho {
    553       1.1    jruoho     UINT32                  i;
    554       1.1    jruoho 
    555       1.1    jruoho 
    556       1.1    jruoho     for (i = 0; (i < ACPI_NAME_SIZE); i++)
    557       1.1    jruoho     {
    558       1.1    jruoho         if (*NameSeg)
    559       1.1    jruoho         {
    560       1.1    jruoho             *PaddedNameSeg = *NameSeg;
    561       1.1    jruoho             NameSeg++;
    562       1.1    jruoho         }
    563       1.1    jruoho         else
    564       1.1    jruoho         {
    565       1.1    jruoho             *PaddedNameSeg = '_';
    566       1.1    jruoho         }
    567   1.1.1.8  christos 
    568       1.1    jruoho         PaddedNameSeg++;
    569       1.1    jruoho     }
    570       1.1    jruoho }
    571       1.1    jruoho 
    572       1.1    jruoho 
    573       1.1    jruoho /*******************************************************************************
    574       1.1    jruoho  *
    575       1.1    jruoho  * FUNCTION:    UtAttachNameseg
    576       1.1    jruoho  *
    577   1.1.1.4  christos  * PARAMETERS:  Op                  - Parent parse node
    578   1.1.1.4  christos  *              Name                - Full ExternalName
    579       1.1    jruoho  *
    580       1.1    jruoho  * RETURN:      None; Sets the NameSeg field in parent node
    581       1.1    jruoho  *
    582       1.1    jruoho  * DESCRIPTION: Extract the last nameseg of the ExternalName and store it
    583       1.1    jruoho  *              in the NameSeg field of the Op.
    584       1.1    jruoho  *
    585       1.1    jruoho  ******************************************************************************/
    586       1.1    jruoho 
    587       1.1    jruoho static void
    588       1.1    jruoho UtAttachNameseg (
    589       1.1    jruoho     ACPI_PARSE_OBJECT       *Op,
    590       1.1    jruoho     char                    *Name)
    591       1.1    jruoho {
    592       1.1    jruoho     char                    *NameSeg;
    593       1.1    jruoho     char                    PaddedNameSeg[4];
    594       1.1    jruoho 
    595       1.1    jruoho 
    596       1.1    jruoho     if (!Name)
    597       1.1    jruoho     {
    598       1.1    jruoho         return;
    599       1.1    jruoho     }
    600       1.1    jruoho 
    601       1.1    jruoho     /* Look for the last dot in the namepath */
    602       1.1    jruoho 
    603       1.1    jruoho     NameSeg = strrchr (Name, '.');
    604       1.1    jruoho     if (NameSeg)
    605       1.1    jruoho     {
    606       1.1    jruoho         /* Found last dot, we have also found the final nameseg */
    607       1.1    jruoho 
    608       1.1    jruoho         NameSeg++;
    609       1.1    jruoho         UtPadNameWithUnderscores (NameSeg, PaddedNameSeg);
    610       1.1    jruoho     }
    611       1.1    jruoho     else
    612       1.1    jruoho     {
    613       1.1    jruoho         /* No dots in the namepath, there is only a single nameseg. */
    614       1.1    jruoho         /* Handle prefixes */
    615       1.1    jruoho 
    616   1.1.1.4  christos         while (ACPI_IS_ROOT_PREFIX (*Name) ||
    617   1.1.1.4  christos                ACPI_IS_PARENT_PREFIX (*Name))
    618       1.1    jruoho         {
    619       1.1    jruoho             Name++;
    620       1.1    jruoho         }
    621       1.1    jruoho 
    622   1.1.1.4  christos         /* Remaining string should be one single nameseg */
    623       1.1    jruoho 
    624       1.1    jruoho         UtPadNameWithUnderscores (Name, PaddedNameSeg);
    625       1.1    jruoho     }
    626       1.1    jruoho 
    627   1.1.1.4  christos     ACPI_MOVE_NAME (Op->Asl.NameSeg, PaddedNameSeg);
    628       1.1    jruoho }
    629       1.1    jruoho 
    630       1.1    jruoho 
    631       1.1    jruoho /*******************************************************************************
    632       1.1    jruoho  *
    633       1.1    jruoho  * FUNCTION:    UtAttachNamepathToOwner
    634       1.1    jruoho  *
    635   1.1.1.4  christos  * PARAMETERS:  Op                  - Parent parse node
    636   1.1.1.4  christos  *              NameOp              - Node that contains the name
    637       1.1    jruoho  *
    638       1.1    jruoho  * RETURN:      Sets the ExternalName and Namepath in the parent node
    639       1.1    jruoho  *
    640   1.1.1.4  christos  * DESCRIPTION: Store the name in two forms in the parent node: The original
    641       1.1    jruoho  *              (external) name, and the internalized name that is used within
    642       1.1    jruoho  *              the ACPI namespace manager.
    643       1.1    jruoho  *
    644       1.1    jruoho  ******************************************************************************/
    645       1.1    jruoho 
    646       1.1    jruoho void
    647       1.1    jruoho UtAttachNamepathToOwner (
    648       1.1    jruoho     ACPI_PARSE_OBJECT       *Op,
    649       1.1    jruoho     ACPI_PARSE_OBJECT       *NameOp)
    650       1.1    jruoho {
    651       1.1    jruoho     ACPI_STATUS             Status;
    652       1.1    jruoho 
    653       1.1    jruoho 
    654       1.1    jruoho     /* Full external path */
    655       1.1    jruoho 
    656       1.1    jruoho     Op->Asl.ExternalName = NameOp->Asl.Value.String;
    657       1.1    jruoho 
    658       1.1    jruoho     /* Save the NameOp for possible error reporting later */
    659       1.1    jruoho 
    660       1.1    jruoho     Op->Asl.ParentMethod = (void *) NameOp;
    661       1.1    jruoho 
    662       1.1    jruoho     /* Last nameseg of the path */
    663       1.1    jruoho 
    664       1.1    jruoho     UtAttachNameseg (Op, Op->Asl.ExternalName);
    665       1.1    jruoho 
    666       1.1    jruoho     /* Create internalized path */
    667       1.1    jruoho 
    668       1.1    jruoho     Status = UtInternalizeName (NameOp->Asl.Value.String, &Op->Asl.Namepath);
    669       1.1    jruoho     if (ACPI_FAILURE (Status))
    670       1.1    jruoho     {
    671       1.1    jruoho         /* TBD: abort on no memory */
    672       1.1    jruoho     }
    673       1.1    jruoho }
    674       1.1    jruoho 
    675       1.1    jruoho 
    676       1.1    jruoho /*******************************************************************************
    677       1.1    jruoho  *
    678       1.1    jruoho  * FUNCTION:    UtDoConstant
    679       1.1    jruoho  *
    680  1.1.1.12  christos  * PARAMETERS:  String              - Hex/Decimal/Octal
    681       1.1    jruoho  *
    682       1.1    jruoho  * RETURN:      Converted Integer
    683       1.1    jruoho  *
    684  1.1.1.12  christos  * DESCRIPTION: Convert a string to an integer, with overflow/error checking.
    685       1.1    jruoho  *
    686       1.1    jruoho  ******************************************************************************/
    687       1.1    jruoho 
    688       1.1    jruoho UINT64
    689       1.1    jruoho UtDoConstant (
    690       1.1    jruoho     char                    *String)
    691       1.1    jruoho {
    692       1.1    jruoho     ACPI_STATUS             Status;
    693  1.1.1.12  christos     UINT64                  ConvertedInteger;
    694       1.1    jruoho     char                    ErrBuf[64];
    695       1.1    jruoho 
    696       1.1    jruoho 
    697  1.1.1.12  christos     Status = AcpiUtStrtoul64 (String, &ConvertedInteger);
    698       1.1    jruoho     if (ACPI_FAILURE (Status))
    699       1.1    jruoho     {
    700  1.1.1.12  christos         sprintf (ErrBuf, "While creating 64-bit constant: %s\n",
    701       1.1    jruoho             AcpiFormatException (Status));
    702  1.1.1.12  christos 
    703  1.1.1.12  christos         AslCommonError (ASL_ERROR, ASL_MSG_SYNTAX, Gbl_CurrentLineNumber,
    704  1.1.1.12  christos             Gbl_LogicalLineNumber, Gbl_CurrentLineOffset,
    705  1.1.1.12  christos             Gbl_CurrentColumn, Gbl_Files[ASL_FILE_INPUT].Filename, ErrBuf);
    706       1.1    jruoho     }
    707       1.1    jruoho 
    708  1.1.1.12  christos     return (ConvertedInteger);
    709       1.1    jruoho }
    710