xref: /freebsd/sys/contrib/dev/acpica/compiler/aslerror.c (revision 26a222dc0c048fc071b548eadad7b80405a1b126)
1 /******************************************************************************
2  *
3  * Module Name: aslerror - Error handling and statistics
4  *
5  *****************************************************************************/
6 
7 /*
8  * Copyright (C) 2000 - 2015, 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 #include <contrib/dev/acpica/compiler/aslcompiler.h>
45 
46 #define _COMPONENT          ACPI_COMPILER
47         ACPI_MODULE_NAME    ("aslerror")
48 
49 /* Local prototypes */
50 
51 static void
52 AeAddToErrorLog (
53     ASL_ERROR_MSG           *Enode);
54 
55 
56 /*******************************************************************************
57  *
58  * FUNCTION:    AslAbort
59  *
60  * PARAMETERS:  None
61  *
62  * RETURN:      None
63  *
64  * DESCRIPTION: Dump the error log and abort the compiler. Used for serious
65  *              I/O errors.
66  *
67  ******************************************************************************/
68 
69 void
70 AslAbort (
71     void)
72 {
73 
74     AePrintErrorLog (ASL_FILE_STDERR);
75     if (Gbl_DebugFlag)
76     {
77         /* Print error summary to stdout also */
78 
79         AePrintErrorLog (ASL_FILE_STDOUT);
80     }
81 
82     exit (1);
83 }
84 
85 
86 /*******************************************************************************
87  *
88  * FUNCTION:    AeClearErrorLog
89  *
90  * PARAMETERS:  None
91  *
92  * RETURN:      None
93  *
94  * DESCRIPTION: Empty the error list
95  *
96  ******************************************************************************/
97 
98 void
99 AeClearErrorLog (
100     void)
101 {
102     ASL_ERROR_MSG           *Enode = Gbl_ErrorLog;
103     ASL_ERROR_MSG           *Next;
104 
105     /* Walk the error node list */
106 
107     while (Enode)
108     {
109         Next = Enode->Next;
110         ACPI_FREE (Enode);
111         Enode = Next;
112     }
113 
114     Gbl_ErrorLog = NULL;
115 }
116 
117 
118 /*******************************************************************************
119  *
120  * FUNCTION:    AeAddToErrorLog
121  *
122  * PARAMETERS:  Enode       - An error node to add to the log
123  *
124  * RETURN:      None
125  *
126  * DESCRIPTION: Add a new error node to the error log. The error log is
127  *              ordered by the "logical" line number (cumulative line number
128  *              including all include files.)
129  *
130  ******************************************************************************/
131 
132 static void
133 AeAddToErrorLog (
134     ASL_ERROR_MSG           *Enode)
135 {
136     ASL_ERROR_MSG           *Next;
137     ASL_ERROR_MSG           *Prev;
138 
139 
140     /* If Gbl_ErrorLog is null, this is the first error node */
141 
142     if (!Gbl_ErrorLog)
143     {
144         Gbl_ErrorLog = Enode;
145         return;
146     }
147 
148     /*
149      * Walk error list until we find a line number greater than ours.
150      * List is sorted according to line number.
151      */
152     Prev = NULL;
153     Next = Gbl_ErrorLog;
154 
155     while ((Next) &&
156            (Next->LogicalLineNumber <= Enode->LogicalLineNumber))
157     {
158         Prev = Next;
159         Next = Next->Next;
160     }
161 
162     /* Found our place in the list */
163 
164     Enode->Next = Next;
165 
166     if (Prev)
167     {
168         Prev->Next = Enode;
169     }
170     else
171     {
172         Gbl_ErrorLog = Enode;
173     }
174 }
175 
176 
177 /*******************************************************************************
178  *
179  * FUNCTION:    AePrintException
180  *
181  * PARAMETERS:  FileId          - ID of output file
182  *              Enode           - Error node to print
183  *              Header          - Additional text before each message
184  *
185  * RETURN:      None
186  *
187  * DESCRIPTION: Print the contents of an error node.
188  *
189  * NOTE:        We don't use the FlxxxFile I/O functions here because on error
190  *              they abort the compiler and call this function!  Since we
191  *              are reporting errors here, we ignore most output errors and
192  *              just try to get out as much as we can.
193  *
194  ******************************************************************************/
195 
196 void
197 AePrintException (
198     UINT32                  FileId,
199     ASL_ERROR_MSG           *Enode,
200     char                    *Header)
201 {
202     UINT8                   SourceByte;
203     int                     Actual;
204     size_t                  RActual;
205     UINT32                  MsgLength;
206     const char              *MainMessage;
207     char                    *ExtraMessage;
208     UINT32                  SourceColumn;
209     UINT32                  ErrorColumn;
210     FILE                    *OutputFile;
211     FILE                    *SourceFile = NULL;
212     long                    FileSize;
213     BOOLEAN                 PrematureEOF = FALSE;
214     UINT32                  Total = 0;
215 
216 
217     if (Gbl_NoErrors)
218     {
219         return;
220     }
221 
222     /*
223      * Only listing files have a header, and remarks/optimizations
224      * are always output
225      */
226     if (!Header)
227     {
228         /* Ignore remarks if requested */
229 
230         switch (Enode->Level)
231         {
232         case ASL_WARNING:
233         case ASL_WARNING2:
234         case ASL_WARNING3:
235 
236             if (!Gbl_DisplayWarnings)
237             {
238                 return;
239             }
240             break;
241 
242         case ASL_REMARK:
243 
244             if (!Gbl_DisplayRemarks)
245             {
246                 return;
247             }
248             break;
249 
250         case ASL_OPTIMIZATION:
251 
252             if (!Gbl_DisplayOptimizations)
253             {
254                 return;
255             }
256             break;
257 
258         default:
259 
260             break;
261         }
262     }
263 
264     /* Get the various required file handles */
265 
266     OutputFile = Gbl_Files[FileId].Handle;
267 
268     if (!Enode->SourceLine)
269     {
270         /* Use the merged header/source file if present, otherwise use input file */
271 
272         SourceFile = Gbl_Files[ASL_FILE_SOURCE_OUTPUT].Handle;
273         if (!SourceFile)
274         {
275             SourceFile = Gbl_Files[ASL_FILE_INPUT].Handle;
276         }
277 
278         if (SourceFile)
279         {
280             /* Determine if the error occurred at source file EOF */
281 
282             fseek (SourceFile, 0, SEEK_END);
283             FileSize = ftell (SourceFile);
284 
285             if ((long) Enode->LogicalByteOffset >= FileSize)
286             {
287                 PrematureEOF = TRUE;
288             }
289         }
290     }
291 
292     if (Header)
293     {
294         fprintf (OutputFile, "%s", Header);
295     }
296 
297     /* Print filename and line number if present and valid */
298 
299     if (Enode->Filename)
300     {
301         if (Gbl_VerboseErrors)
302         {
303             fprintf (OutputFile, "%-8s", Enode->Filename);
304 
305             if (Enode->LineNumber)
306             {
307                 if (Enode->SourceLine)
308                 {
309                     fprintf (OutputFile, " %6u: %s",
310                         Enode->LineNumber, Enode->SourceLine);
311                 }
312                 else
313                 {
314                     fprintf (OutputFile, " %6u: ", Enode->LineNumber);
315 
316                     /*
317                      * If not at EOF, get the corresponding source code line and
318                      * display it. Don't attempt this if we have a premature EOF
319                      * condition.
320                      */
321                     if (!PrematureEOF)
322                     {
323                         /*
324                          * Seek to the offset in the combined source file, read
325                          * the source line, and write it to the output.
326                          */
327                         Actual = fseek (SourceFile, (long) Enode->LogicalByteOffset,
328                                     (int) SEEK_SET);
329                         if (Actual)
330                         {
331                             fprintf (OutputFile,
332                                 "[*** iASL: Seek error on source code temp file %s ***]",
333                                 Gbl_Files[ASL_FILE_SOURCE_OUTPUT].Filename);
334                         }
335                         else
336                         {
337                             RActual = fread (&SourceByte, 1, 1, SourceFile);
338                             if (RActual != 1)
339                             {
340                                 fprintf (OutputFile,
341                                     "[*** iASL: Read error on source code temp file %s ***]",
342                                     Gbl_Files[ASL_FILE_SOURCE_OUTPUT].Filename);
343                             }
344                             else
345                             {
346                                 /* Read/write the source line, up to the maximum line length */
347 
348                                 while (RActual && SourceByte && (SourceByte != '\n'))
349                                 {
350                                     if (Total < 256)
351                                     {
352                                         /* After the max line length, we will just read the line, no write */
353 
354                                         if (fwrite (&SourceByte, 1, 1, OutputFile) != 1)
355                                         {
356                                             printf ("[*** iASL: Write error on output file ***]\n");
357                                             return;
358                                         }
359                                     }
360                                     else if (Total == 256)
361                                     {
362                                         fprintf (OutputFile,
363                                             "\n[*** iASL: Very long input line, message below refers to column %u ***]",
364                                             Enode->Column);
365                                     }
366 
367                                     RActual = fread (&SourceByte, 1, 1, SourceFile);
368                                     if (RActual != 1)
369                                     {
370                                         fprintf (OutputFile,
371                                             "[*** iASL: Read error on source code temp file %s ***]",
372                                             Gbl_Files[ASL_FILE_SOURCE_OUTPUT].Filename);
373                                         return;
374                                     }
375                                     Total++;
376                                 }
377                             }
378                         }
379                     }
380 
381                     fprintf (OutputFile, "\n");
382                 }
383             }
384         }
385         else
386         {
387             /*
388              * Less verbose version of the error message, enabled via the
389              * -vi switch. The format is compatible with MS Visual Studio.
390              */
391             fprintf (OutputFile, "%s", Enode->Filename);
392 
393             if (Enode->LineNumber)
394             {
395                 fprintf (OutputFile, "(%u) : ",
396                     Enode->LineNumber);
397             }
398         }
399     }
400 
401     /* If a NULL message ID, just print the raw message */
402 
403     if (Enode->MessageId == 0)
404     {
405         fprintf (OutputFile, "%s\n", Enode->Message);
406         return;
407     }
408 
409     /* Decode the message ID */
410 
411     fprintf (OutputFile, "%s %4.4d -",
412         AeDecodeExceptionLevel (Enode->Level),
413         AeBuildFullExceptionCode (Enode->Level, Enode->MessageId));
414 
415     MainMessage = AeDecodeMessageId (Enode->MessageId);
416     ExtraMessage = Enode->Message;
417 
418     /* If a NULL line number, just print the decoded message */
419 
420     if (!Enode->LineNumber)
421     {
422         fprintf (OutputFile, " %s %s\n\n", MainMessage, ExtraMessage);
423         return;
424     }
425 
426     MsgLength = strlen (MainMessage);
427     if (MsgLength == 0)
428     {
429         /* Use the secondary/extra message as main message */
430 
431         MainMessage = Enode->Message;
432         if (!MainMessage)
433         {
434             MainMessage = "";
435         }
436 
437         MsgLength = strlen (MainMessage);
438         ExtraMessage = NULL;
439     }
440 
441     if (Gbl_VerboseErrors && !PrematureEOF)
442     {
443         if (Total >= 256)
444         {
445             fprintf (OutputFile, "    %s",
446                 MainMessage);
447         }
448         else
449         {
450             SourceColumn = Enode->Column + Enode->FilenameLength + 6 + 2;
451             ErrorColumn = ASL_ERROR_LEVEL_LENGTH + 5 + 2 + 1;
452 
453             if ((MsgLength + ErrorColumn) < (SourceColumn - 1))
454             {
455                 fprintf (OutputFile, "%*s%s",
456                     (int) ((SourceColumn - 1) - ErrorColumn),
457                     MainMessage, " ^ ");
458             }
459             else
460             {
461                 fprintf (OutputFile, "%*s %s",
462                     (int) ((SourceColumn - ErrorColumn) + 1), "^",
463                     MainMessage);
464             }
465         }
466     }
467     else
468     {
469         fprintf (OutputFile, " %s", MainMessage);
470     }
471 
472     /* Print the extra info message if present */
473 
474     if (ExtraMessage)
475     {
476         fprintf (OutputFile, " (%s)", ExtraMessage);
477     }
478 
479     if (PrematureEOF)
480     {
481         fprintf (OutputFile, " and premature End-Of-File");
482     }
483 
484     fprintf (OutputFile, "\n");
485     if (Gbl_VerboseErrors)
486     {
487         fprintf (OutputFile, "\n");
488     }
489 }
490 
491 
492 /*******************************************************************************
493  *
494  * FUNCTION:    AePrintErrorLog
495  *
496  * PARAMETERS:  FileId           - Where to output the error log
497  *
498  * RETURN:      None
499  *
500  * DESCRIPTION: Print the entire contents of the error log
501  *
502  ******************************************************************************/
503 
504 void
505 AePrintErrorLog (
506     UINT32                  FileId)
507 {
508     ASL_ERROR_MSG           *Enode = Gbl_ErrorLog;
509 
510 
511     /* Walk the error node list */
512 
513     while (Enode)
514     {
515         AePrintException (FileId, Enode, NULL);
516         Enode = Enode->Next;
517     }
518 }
519 
520 
521 /*******************************************************************************
522  *
523  * FUNCTION:    AslCommonError2
524  *
525  * PARAMETERS:  Level               - Seriousness (Warning/error, etc.)
526  *              MessageId           - Index into global message buffer
527  *              LineNumber          - Actual file line number
528  *              Column              - Column in current line
529  *              SourceLine          - Actual source code line
530  *              Filename            - source filename
531  *              ExtraMessage        - additional error message
532  *
533  * RETURN:      None
534  *
535  * DESCRIPTION: Create a new error node and add it to the error log
536  *
537  ******************************************************************************/
538 
539 void
540 AslCommonError2 (
541     UINT8                   Level,
542     UINT16                  MessageId,
543     UINT32                  LineNumber,
544     UINT32                  Column,
545     char                    *SourceLine,
546     char                    *Filename,
547     char                    *ExtraMessage)
548 {
549     char                    *MessageBuffer = NULL;
550     char                    *LineBuffer;
551     ASL_ERROR_MSG           *Enode;
552 
553 
554     Enode = UtLocalCalloc (sizeof (ASL_ERROR_MSG));
555 
556     if (ExtraMessage)
557     {
558         /* Allocate a buffer for the message and a new error node */
559 
560         MessageBuffer = UtStringCacheCalloc (strlen (ExtraMessage) + 1);
561 
562         /* Keep a copy of the extra message */
563 
564         ACPI_STRCPY (MessageBuffer, ExtraMessage);
565     }
566 
567     LineBuffer = UtLocalCalloc (strlen (SourceLine) + 1);
568     ACPI_STRCPY (LineBuffer, SourceLine);
569 
570     /* Initialize the error node */
571 
572     if (Filename)
573     {
574         Enode->Filename = Filename;
575         Enode->FilenameLength = strlen (Filename);
576         if (Enode->FilenameLength < 6)
577         {
578             Enode->FilenameLength = 6;
579         }
580     }
581 
582     Enode->MessageId            = MessageId;
583     Enode->Level                = Level;
584     Enode->LineNumber           = LineNumber;
585     Enode->LogicalLineNumber    = LineNumber;
586     Enode->LogicalByteOffset    = 0;
587     Enode->Column               = Column;
588     Enode->Message              = MessageBuffer;
589     Enode->SourceLine           = LineBuffer;
590 
591     /* Add the new node to the error node list */
592 
593     AeAddToErrorLog (Enode);
594 
595     if (Gbl_DebugFlag)
596     {
597         /* stderr is a file, send error to it immediately */
598 
599         AePrintException (ASL_FILE_STDERR, Enode, NULL);
600     }
601 
602     Gbl_ExceptionCount[Level]++;
603 }
604 
605 
606 /*******************************************************************************
607  *
608  * FUNCTION:    AslCommonError
609  *
610  * PARAMETERS:  Level               - Seriousness (Warning/error, etc.)
611  *              MessageId           - Index into global message buffer
612  *              CurrentLineNumber   - Actual file line number
613  *              LogicalLineNumber   - Cumulative line number
614  *              LogicalByteOffset   - Byte offset in source file
615  *              Column              - Column in current line
616  *              Filename            - source filename
617  *              ExtraMessage        - additional error message
618  *
619  * RETURN:      None
620  *
621  * DESCRIPTION: Create a new error node and add it to the error log
622  *
623  ******************************************************************************/
624 
625 void
626 AslCommonError (
627     UINT8                   Level,
628     UINT16                  MessageId,
629     UINT32                  CurrentLineNumber,
630     UINT32                  LogicalLineNumber,
631     UINT32                  LogicalByteOffset,
632     UINT32                  Column,
633     char                    *Filename,
634     char                    *ExtraMessage)
635 {
636     char                    *MessageBuffer = NULL;
637     ASL_ERROR_MSG           *Enode;
638 
639 
640     Enode = UtLocalCalloc (sizeof (ASL_ERROR_MSG));
641 
642     if (ExtraMessage)
643     {
644         /* Allocate a buffer for the message and a new error node */
645 
646         MessageBuffer = UtStringCacheCalloc (strlen (ExtraMessage) + 1);
647 
648         /* Keep a copy of the extra message */
649 
650         ACPI_STRCPY (MessageBuffer, ExtraMessage);
651     }
652 
653     /* Initialize the error node */
654 
655     if (Filename)
656     {
657         Enode->Filename = Filename;
658         Enode->FilenameLength = strlen (Filename);
659         if (Enode->FilenameLength < 6)
660         {
661             Enode->FilenameLength = 6;
662         }
663     }
664 
665     Enode->MessageId            = MessageId;
666     Enode->Level                = Level;
667     Enode->LineNumber           = CurrentLineNumber;
668     Enode->LogicalLineNumber    = LogicalLineNumber;
669     Enode->LogicalByteOffset    = LogicalByteOffset;
670     Enode->Column               = Column;
671     Enode->Message              = MessageBuffer;
672     Enode->SourceLine           = NULL;
673 
674     /* Add the new node to the error node list */
675 
676     AeAddToErrorLog (Enode);
677 
678     if (Gbl_DebugFlag)
679     {
680         /* stderr is a file, send error to it immediately */
681 
682         AePrintException (ASL_FILE_STDERR, Enode, NULL);
683     }
684 
685     Gbl_ExceptionCount[Level]++;
686     if (Gbl_ExceptionCount[ASL_ERROR] > ASL_MAX_ERROR_COUNT)
687     {
688         printf ("\nMaximum error count (%u) exceeded\n", ASL_MAX_ERROR_COUNT);
689 
690         Gbl_SourceLine = 0;
691         Gbl_NextError = Gbl_ErrorLog;
692         CmCleanupAndExit ();
693         exit(1);
694     }
695 
696     return;
697 }
698 
699 
700 /*******************************************************************************
701  *
702  * FUNCTION:    AslDisableException
703  *
704  * PARAMETERS:  MessageIdString     - ID to be disabled
705  *
706  * RETURN:      Status
707  *
708  * DESCRIPTION: Enter a message ID into the global disabled messages table
709  *
710  ******************************************************************************/
711 
712 ACPI_STATUS
713 AslDisableException (
714     char                    *MessageIdString)
715 {
716     UINT32                  MessageId;
717 
718 
719     /* Convert argument to an integer and validate it */
720 
721     MessageId = (UINT32) strtoul (MessageIdString, NULL, 0);
722 
723     if ((MessageId < 2000) || (MessageId > 5999))
724     {
725         printf ("\"%s\" is not a valid warning/remark ID\n",
726             MessageIdString);
727         return (AE_BAD_PARAMETER);
728     }
729 
730     /* Insert value into the global disabled message array */
731 
732     if (Gbl_DisabledMessagesIndex >= ASL_MAX_DISABLED_MESSAGES)
733     {
734         printf ("Too many messages have been disabled (max %u)\n",
735             ASL_MAX_DISABLED_MESSAGES);
736         return (AE_LIMIT);
737     }
738 
739     Gbl_DisabledMessages[Gbl_DisabledMessagesIndex] = MessageId;
740     Gbl_DisabledMessagesIndex++;
741     return (AE_OK);
742 }
743 
744 
745 /*******************************************************************************
746  *
747  * FUNCTION:    AslIsExceptionDisabled
748  *
749  * PARAMETERS:  Level               - Seriousness (Warning/error, etc.)
750  *              MessageId           - Index into global message buffer
751  *
752  * RETURN:      TRUE if exception/message should be ignored
753  *
754  * DESCRIPTION: Check if the user has specified options such that this
755  *              exception should be ignored
756  *
757  ******************************************************************************/
758 
759 BOOLEAN
760 AslIsExceptionDisabled (
761     UINT8                   Level,
762     UINT16                  MessageId)
763 {
764     UINT32                  EncodedMessageId;
765     UINT32                  i;
766 
767 
768     switch (Level)
769     {
770     case ASL_WARNING2:
771     case ASL_WARNING3:
772 
773         /* Check for global disable via -w1/-w2/-w3 options */
774 
775         if (Level > Gbl_WarningLevel)
776         {
777             return (TRUE);
778         }
779         /* Fall through */
780 
781     case ASL_WARNING:
782     case ASL_REMARK:
783         /*
784          * Ignore this warning/remark if it has been disabled by
785          * the user (-vw option)
786          */
787         EncodedMessageId = AeBuildFullExceptionCode (Level, MessageId);
788         for (i = 0; i < Gbl_DisabledMessagesIndex; i++)
789         {
790             /* Simple implementation via fixed array */
791 
792             if (EncodedMessageId == Gbl_DisabledMessages[i])
793             {
794                 return (TRUE);
795             }
796         }
797         break;
798 
799     default:
800         break;
801     }
802 
803     return (FALSE);
804 }
805 
806 
807 /*******************************************************************************
808  *
809  * FUNCTION:    AslError
810  *
811  * PARAMETERS:  Level               - Seriousness (Warning/error, etc.)
812  *              MessageId           - Index into global message buffer
813  *              Op                  - Parse node where error happened
814  *              ExtraMessage        - additional error message
815  *
816  * RETURN:      None
817  *
818  * DESCRIPTION: Main error reporting routine for the ASL compiler (all code
819  *              except the parser.)
820  *
821  ******************************************************************************/
822 
823 void
824 AslError (
825     UINT8                   Level,
826     UINT16                  MessageId,
827     ACPI_PARSE_OBJECT       *Op,
828     char                    *ExtraMessage)
829 {
830 
831     /* Check if user wants to ignore this exception */
832 
833     if (Gbl_AllExceptionsDisabled ||
834         AslIsExceptionDisabled (Level, MessageId))
835     {
836         return;
837     }
838 
839     if (Op)
840     {
841         AslCommonError (Level, MessageId, Op->Asl.LineNumber,
842             Op->Asl.LogicalLineNumber,
843             Op->Asl.LogicalByteOffset,
844             Op->Asl.Column,
845             Op->Asl.Filename, ExtraMessage);
846     }
847     else
848     {
849         AslCommonError (Level, MessageId, 0,
850             0, 0, 0, NULL, ExtraMessage);
851     }
852 }
853 
854 
855 /*******************************************************************************
856  *
857  * FUNCTION:    AslCoreSubsystemError
858  *
859  * PARAMETERS:  Op                  - Parse node where error happened
860  *              Status              - The ACPICA Exception
861  *              ExtraMessage        - additional error message
862  *              Abort               - TRUE -> Abort compilation
863  *
864  * RETURN:      None
865  *
866  * DESCRIPTION: Error reporting routine for exceptions returned by the ACPICA
867  *              core subsystem.
868  *
869  ******************************************************************************/
870 
871 void
872 AslCoreSubsystemError (
873     ACPI_PARSE_OBJECT       *Op,
874     ACPI_STATUS             Status,
875     char                    *ExtraMessage,
876     BOOLEAN                 Abort)
877 {
878 
879     sprintf (MsgBuffer, "%s %s", AcpiFormatException (Status), ExtraMessage);
880 
881     if (Op)
882     {
883         AslCommonError (ASL_ERROR, ASL_MSG_CORE_EXCEPTION, Op->Asl.LineNumber,
884                         Op->Asl.LogicalLineNumber,
885                         Op->Asl.LogicalByteOffset,
886                         Op->Asl.Column,
887                         Op->Asl.Filename, MsgBuffer);
888     }
889     else
890     {
891         AslCommonError (ASL_ERROR, ASL_MSG_CORE_EXCEPTION, 0,
892                         0, 0, 0, NULL, MsgBuffer);
893     }
894 
895     if (Abort)
896     {
897         AslAbort ();
898     }
899 }
900 
901 
902 /*******************************************************************************
903  *
904  * FUNCTION:    AslCompilererror
905  *
906  * PARAMETERS:  CompilerMessage         - Error message from the parser
907  *
908  * RETURN:      Status (0 for now)
909  *
910  * DESCRIPTION: Report an error situation discovered in a production
911  *              NOTE: don't change the name of this function, it is called
912  *              from the auto-generated parser.
913  *
914  ******************************************************************************/
915 
916 int
917 AslCompilererror (
918     const char              *CompilerMessage)
919 {
920 
921     Gbl_SyntaxError++;
922 
923     AslCommonError (ASL_ERROR, ASL_MSG_SYNTAX, Gbl_CurrentLineNumber,
924         Gbl_LogicalLineNumber, Gbl_CurrentLineOffset,
925         Gbl_CurrentColumn, Gbl_Files[ASL_FILE_INPUT].Filename,
926         ACPI_CAST_PTR (char, CompilerMessage));
927 
928     return (0);
929 }
930