1 /******************************************************************************
2  *
3  * Module Name: utdebug - Debug print/trace routines
4  *
5  *****************************************************************************/
6 
7 /*
8  * Copyright (C) 2000 - 2022, 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 MERCHANTABILITY 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 EXPORT_ACPI_INTERFACES
45 
46 #include "acpi.h"
47 #include "accommon.h"
48 #include "acinterp.h"
49 
50 #define _COMPONENT          ACPI_UTILITIES
51         ACPI_MODULE_NAME    ("utdebug")
52 
53 
54 #ifdef ACPI_DEBUG_OUTPUT
55 
56 static ACPI_THREAD_ID       AcpiGbl_PreviousThreadId = (ACPI_THREAD_ID) 0xFFFFFFFF;
57 static const char           *AcpiGbl_FunctionEntryPrefix = "----Entry";
58 static const char           *AcpiGbl_FunctionExitPrefix  = "----Exit-";
59 
60 
61 /*******************************************************************************
62  *
63  * FUNCTION:    AcpiUtInitStackPtrTrace
64  *
65  * PARAMETERS:  None
66  *
67  * RETURN:      None
68  *
69  * DESCRIPTION: Save the current CPU stack pointer at subsystem startup
70  *
71  ******************************************************************************/
72 
73 void
74 AcpiUtInitStackPtrTrace (
75     void)
76 {
77     ACPI_SIZE               CurrentSp;
78 
79 
80     AcpiGbl_EntryStackPointer = &CurrentSp;
81 }
82 
83 
84 /*******************************************************************************
85  *
86  * FUNCTION:    AcpiUtTrackStackPtr
87  *
88  * PARAMETERS:  None
89  *
90  * RETURN:      None
91  *
92  * DESCRIPTION: Save the current CPU stack pointer
93  *
94  ******************************************************************************/
95 
96 void
97 AcpiUtTrackStackPtr (
98     void)
99 {
100     ACPI_SIZE               CurrentSp;
101 
102 
103     if (&CurrentSp < AcpiGbl_LowestStackPointer)
104     {
105         AcpiGbl_LowestStackPointer = &CurrentSp;
106     }
107 
108     if (AcpiGbl_NestingLevel > AcpiGbl_DeepestNesting)
109     {
110         AcpiGbl_DeepestNesting = AcpiGbl_NestingLevel;
111     }
112 }
113 
114 
115 /*******************************************************************************
116  *
117  * FUNCTION:    AcpiUtTrimFunctionName
118  *
119  * PARAMETERS:  FunctionName        - Ascii string containing a procedure name
120  *
121  * RETURN:      Updated pointer to the function name
122  *
123  * DESCRIPTION: Remove the "Acpi" prefix from the function name, if present.
124  *              This allows compiler macros such as __FUNCTION__ to be used
125  *              with no change to the debug output.
126  *
127  ******************************************************************************/
128 
129 static const char *
130 AcpiUtTrimFunctionName (
131     const char              *FunctionName)
132 {
133 
134     /* All Function names are longer than 4 chars, check is safe */
135 
136     if (*(ACPI_CAST_PTR (UINT32, FunctionName)) == ACPI_PREFIX_MIXED)
137     {
138         /* This is the case where the original source has not been modified */
139 
140         return (FunctionName + 4);
141     }
142 
143     if (*(ACPI_CAST_PTR (UINT32, FunctionName)) == ACPI_PREFIX_LOWER)
144     {
145         /* This is the case where the source has been 'linuxized' */
146 
147         return (FunctionName + 5);
148     }
149 
150     return (FunctionName);
151 }
152 
153 
154 /*******************************************************************************
155  *
156  * FUNCTION:    AcpiDebugPrint
157  *
158  * PARAMETERS:  RequestedDebugLevel - Requested debug print level
159  *              LineNumber          - Caller's line number (for error output)
160  *              FunctionName        - Caller's procedure name
161  *              ModuleName          - Caller's module name
162  *              ComponentId         - Caller's component ID
163  *              Format              - Printf format field
164  *              ...                 - Optional printf arguments
165  *
166  * RETURN:      None
167  *
168  * DESCRIPTION: Print error message with prefix consisting of the module name,
169  *              line number, and component ID.
170  *
171  ******************************************************************************/
172 
173 void  ACPI_INTERNAL_VAR_XFACE
174 AcpiDebugPrint (
175     UINT32                  RequestedDebugLevel,
176     UINT32                  LineNumber,
177     const char              *FunctionName,
178     const char              *ModuleName,
179     UINT32                  ComponentId,
180     const char              *Format,
181     ...)
182 {
183     ACPI_THREAD_ID          ThreadId;
184     va_list                 args;
185 #ifdef ACPI_APPLICATION
186     int                     FillCount;
187 #endif
188 
189     /* Check if debug output enabled */
190 
191     if (!ACPI_IS_DEBUG_ENABLED (RequestedDebugLevel, ComponentId))
192     {
193         return;
194     }
195 
196     /*
197      * Thread tracking and context switch notification
198      */
199     ThreadId = AcpiOsGetThreadId ();
200     if (ThreadId != AcpiGbl_PreviousThreadId)
201     {
202         if (ACPI_LV_THREADS & AcpiDbgLevel)
203         {
204             AcpiOsPrintf (
205                 "\n**** Context Switch from TID %u to TID %u ****\n\n",
206                 (UINT32) AcpiGbl_PreviousThreadId, (UINT32) ThreadId);
207         }
208 
209         AcpiGbl_PreviousThreadId = ThreadId;
210         AcpiGbl_NestingLevel = 0;
211     }
212 
213     /*
214      * Display the module name, current line number, thread ID (if requested),
215      * current procedure nesting level, and the current procedure name
216      */
217     AcpiOsPrintf ("%9s-%04d ", ModuleName, LineNumber);
218 
219 #ifdef ACPI_APPLICATION
220     /*
221      * For AcpiExec/iASL only, emit the thread ID and nesting level.
222      * Note: nesting level is really only useful during a single-thread
223      * execution. Otherwise, multiple threads will keep resetting the
224      * level.
225      */
226     if (ACPI_LV_THREADS & AcpiDbgLevel)
227     {
228         AcpiOsPrintf ("[%u] ", (UINT32) ThreadId);
229     }
230 
231     FillCount = 48 - AcpiGbl_NestingLevel -
232         strlen (AcpiUtTrimFunctionName (FunctionName));
233     if (FillCount < 0)
234     {
235         FillCount = 0;
236     }
237 
238     AcpiOsPrintf ("[%02d] %*s",
239         AcpiGbl_NestingLevel, AcpiGbl_NestingLevel + 1, " ");
240     AcpiOsPrintf ("%s%*s: ",
241         AcpiUtTrimFunctionName (FunctionName), FillCount, " ");
242 
243 #else
244     AcpiOsPrintf ("%-22.22s: ", AcpiUtTrimFunctionName (FunctionName));
245 #endif
246 
247     va_start (args, Format);
248     AcpiOsVprintf (Format, args);
249     va_end (args);
250 }
251 
252 ACPI_EXPORT_SYMBOL (AcpiDebugPrint)
253 
254 
255 /*******************************************************************************
256  *
257  * FUNCTION:    AcpiDebugPrintRaw
258  *
259  * PARAMETERS:  RequestedDebugLevel - Requested debug print level
260  *              LineNumber          - Caller's line number
261  *              FunctionName        - Caller's procedure name
262  *              ModuleName          - Caller's module name
263  *              ComponentId         - Caller's component ID
264  *              Format              - Printf format field
265  *              ...                 - Optional printf arguments
266  *
267  * RETURN:      None
268  *
269  * DESCRIPTION: Print message with no headers. Has same interface as
270  *              DebugPrint so that the same macros can be used.
271  *
272  ******************************************************************************/
273 
274 void  ACPI_INTERNAL_VAR_XFACE
275 AcpiDebugPrintRaw (
276     UINT32                  RequestedDebugLevel,
277     UINT32                  LineNumber,
278     const char              *FunctionName,
279     const char              *ModuleName,
280     UINT32                  ComponentId,
281     const char              *Format,
282     ...)
283 {
284     va_list                 args;
285 
286 
287     /* Check if debug output enabled */
288 
289     if (!ACPI_IS_DEBUG_ENABLED (RequestedDebugLevel, ComponentId))
290     {
291         return;
292     }
293 
294     va_start (args, Format);
295     AcpiOsVprintf (Format, args);
296     va_end (args);
297 }
298 
299 ACPI_EXPORT_SYMBOL (AcpiDebugPrintRaw)
300 
301 
302 /*******************************************************************************
303  *
304  * FUNCTION:    AcpiUtTrace
305  *
306  * PARAMETERS:  LineNumber          - Caller's line number
307  *              FunctionName        - Caller's procedure name
308  *              ModuleName          - Caller's module name
309  *              ComponentId         - Caller's component ID
310  *
311  * RETURN:      None
312  *
313  * DESCRIPTION: Function entry trace. Prints only if TRACE_FUNCTIONS bit is
314  *              set in DebugLevel
315  *
316  ******************************************************************************/
317 
318 void
319 AcpiUtTrace (
320     UINT32                  LineNumber,
321     const char              *FunctionName,
322     const char              *ModuleName,
323     UINT32                  ComponentId)
324 {
325 
326     AcpiGbl_NestingLevel++;
327     AcpiUtTrackStackPtr ();
328 
329     /* Check if enabled up-front for performance */
330 
331     if (ACPI_IS_DEBUG_ENABLED (ACPI_LV_FUNCTIONS, ComponentId))
332     {
333         AcpiDebugPrint (ACPI_LV_FUNCTIONS,
334             LineNumber, FunctionName, ModuleName, ComponentId,
335             "%s\n", AcpiGbl_FunctionEntryPrefix);
336     }
337 }
338 
339 ACPI_EXPORT_SYMBOL (AcpiUtTrace)
340 
341 
342 /*******************************************************************************
343  *
344  * FUNCTION:    AcpiUtTracePtr
345  *
346  * PARAMETERS:  LineNumber          - Caller's line number
347  *              FunctionName        - Caller's procedure name
348  *              ModuleName          - Caller's module name
349  *              ComponentId         - Caller's component ID
350  *              Pointer             - Pointer to display
351  *
352  * RETURN:      None
353  *
354  * DESCRIPTION: Function entry trace. Prints only if TRACE_FUNCTIONS bit is
355  *              set in DebugLevel
356  *
357  ******************************************************************************/
358 
359 void
360 AcpiUtTracePtr (
361     UINT32                  LineNumber,
362     const char              *FunctionName,
363     const char              *ModuleName,
364     UINT32                  ComponentId,
365     const void              *Pointer)
366 {
367 
368     AcpiGbl_NestingLevel++;
369     AcpiUtTrackStackPtr ();
370 
371     /* Check if enabled up-front for performance */
372 
373     if (ACPI_IS_DEBUG_ENABLED (ACPI_LV_FUNCTIONS, ComponentId))
374     {
375         AcpiDebugPrint (ACPI_LV_FUNCTIONS,
376             LineNumber, FunctionName, ModuleName, ComponentId,
377             "%s %p\n", AcpiGbl_FunctionEntryPrefix, Pointer);
378     }
379 }
380 
381 
382 /*******************************************************************************
383  *
384  * FUNCTION:    AcpiUtTraceStr
385  *
386  * PARAMETERS:  LineNumber          - Caller's line number
387  *              FunctionName        - Caller's procedure name
388  *              ModuleName          - Caller's module name
389  *              ComponentId         - Caller's component ID
390  *              String              - Additional string to display
391  *
392  * RETURN:      None
393  *
394  * DESCRIPTION: Function entry trace. Prints only if TRACE_FUNCTIONS bit is
395  *              set in DebugLevel
396  *
397  ******************************************************************************/
398 
399 void
400 AcpiUtTraceStr (
401     UINT32                  LineNumber,
402     const char              *FunctionName,
403     const char              *ModuleName,
404     UINT32                  ComponentId,
405     const char              *String)
406 {
407 
408     AcpiGbl_NestingLevel++;
409     AcpiUtTrackStackPtr ();
410 
411     /* Check if enabled up-front for performance */
412 
413     if (ACPI_IS_DEBUG_ENABLED (ACPI_LV_FUNCTIONS, ComponentId))
414     {
415         AcpiDebugPrint (ACPI_LV_FUNCTIONS,
416             LineNumber, FunctionName, ModuleName, ComponentId,
417             "%s %s\n", AcpiGbl_FunctionEntryPrefix, String);
418     }
419 }
420 
421 
422 /*******************************************************************************
423  *
424  * FUNCTION:    AcpiUtTraceU32
425  *
426  * PARAMETERS:  LineNumber          - Caller's line number
427  *              FunctionName        - Caller's procedure name
428  *              ModuleName          - Caller's module name
429  *              ComponentId         - Caller's component ID
430  *              Integer             - Integer to display
431  *
432  * RETURN:      None
433  *
434  * DESCRIPTION: Function entry trace. Prints only if TRACE_FUNCTIONS bit is
435  *              set in DebugLevel
436  *
437  ******************************************************************************/
438 
439 void
440 AcpiUtTraceU32 (
441     UINT32                  LineNumber,
442     const char              *FunctionName,
443     const char              *ModuleName,
444     UINT32                  ComponentId,
445     UINT32                  Integer)
446 {
447 
448     AcpiGbl_NestingLevel++;
449     AcpiUtTrackStackPtr ();
450 
451     /* Check if enabled up-front for performance */
452 
453     if (ACPI_IS_DEBUG_ENABLED (ACPI_LV_FUNCTIONS, ComponentId))
454     {
455         AcpiDebugPrint (ACPI_LV_FUNCTIONS,
456             LineNumber, FunctionName, ModuleName, ComponentId,
457             "%s %08X\n", AcpiGbl_FunctionEntryPrefix, Integer);
458     }
459 }
460 
461 
462 /*******************************************************************************
463  *
464  * FUNCTION:    AcpiUtExit
465  *
466  * PARAMETERS:  LineNumber          - Caller's line number
467  *              FunctionName        - Caller's procedure name
468  *              ModuleName          - Caller's module name
469  *              ComponentId         - Caller's component ID
470  *
471  * RETURN:      None
472  *
473  * DESCRIPTION: Function exit trace. Prints only if TRACE_FUNCTIONS bit is
474  *              set in DebugLevel
475  *
476  ******************************************************************************/
477 
478 void
479 AcpiUtExit (
480     UINT32                  LineNumber,
481     const char              *FunctionName,
482     const char              *ModuleName,
483     UINT32                  ComponentId)
484 {
485 
486     /* Check if enabled up-front for performance */
487 
488     if (ACPI_IS_DEBUG_ENABLED (ACPI_LV_FUNCTIONS, ComponentId))
489     {
490         AcpiDebugPrint (ACPI_LV_FUNCTIONS,
491             LineNumber, FunctionName, ModuleName, ComponentId,
492             "%s\n", AcpiGbl_FunctionExitPrefix);
493     }
494 
495     if (AcpiGbl_NestingLevel)
496     {
497         AcpiGbl_NestingLevel--;
498     }
499 }
500 
501 ACPI_EXPORT_SYMBOL (AcpiUtExit)
502 
503 
504 /*******************************************************************************
505  *
506  * FUNCTION:    AcpiUtStatusExit
507  *
508  * PARAMETERS:  LineNumber          - Caller's line number
509  *              FunctionName        - Caller's procedure name
510  *              ModuleName          - Caller's module name
511  *              ComponentId         - Caller's component ID
512  *              Status              - Exit status code
513  *
514  * RETURN:      None
515  *
516  * DESCRIPTION: Function exit trace. Prints only if TRACE_FUNCTIONS bit is
517  *              set in DebugLevel. Prints exit status also.
518  *
519  ******************************************************************************/
520 
521 void
522 AcpiUtStatusExit (
523     UINT32                  LineNumber,
524     const char              *FunctionName,
525     const char              *ModuleName,
526     UINT32                  ComponentId,
527     ACPI_STATUS             Status)
528 {
529 
530     /* Check if enabled up-front for performance */
531 
532     if (ACPI_IS_DEBUG_ENABLED (ACPI_LV_FUNCTIONS, ComponentId))
533     {
534         if (ACPI_SUCCESS (Status))
535         {
536             AcpiDebugPrint (ACPI_LV_FUNCTIONS,
537                 LineNumber, FunctionName, ModuleName, ComponentId,
538                 "%s %s\n", AcpiGbl_FunctionExitPrefix,
539                 AcpiFormatException (Status));
540         }
541         else
542         {
543             AcpiDebugPrint (ACPI_LV_FUNCTIONS,
544                 LineNumber, FunctionName, ModuleName, ComponentId,
545                 "%s ****Exception****: %s\n", AcpiGbl_FunctionExitPrefix,
546                 AcpiFormatException (Status));
547         }
548     }
549 
550     if (AcpiGbl_NestingLevel)
551     {
552         AcpiGbl_NestingLevel--;
553     }
554 }
555 
556 ACPI_EXPORT_SYMBOL (AcpiUtStatusExit)
557 
558 
559 /*******************************************************************************
560  *
561  * FUNCTION:    AcpiUtValueExit
562  *
563  * PARAMETERS:  LineNumber          - Caller's line number
564  *              FunctionName        - Caller's procedure name
565  *              ModuleName          - Caller's module name
566  *              ComponentId         - Caller's component ID
567  *              Value               - Value to be printed with exit msg
568  *
569  * RETURN:      None
570  *
571  * DESCRIPTION: Function exit trace. Prints only if TRACE_FUNCTIONS bit is
572  *              set in DebugLevel. Prints exit value also.
573  *
574  ******************************************************************************/
575 
576 void
577 AcpiUtValueExit (
578     UINT32                  LineNumber,
579     const char              *FunctionName,
580     const char              *ModuleName,
581     UINT32                  ComponentId,
582     UINT64                  Value)
583 {
584 
585     /* Check if enabled up-front for performance */
586 
587     if (ACPI_IS_DEBUG_ENABLED (ACPI_LV_FUNCTIONS, ComponentId))
588     {
589         AcpiDebugPrint (ACPI_LV_FUNCTIONS,
590             LineNumber, FunctionName, ModuleName, ComponentId,
591             "%s %8.8X%8.8X\n", AcpiGbl_FunctionExitPrefix,
592             ACPI_FORMAT_UINT64 (Value));
593     }
594 
595     if (AcpiGbl_NestingLevel)
596     {
597         AcpiGbl_NestingLevel--;
598     }
599 }
600 
601 ACPI_EXPORT_SYMBOL (AcpiUtValueExit)
602 
603 
604 /*******************************************************************************
605  *
606  * FUNCTION:    AcpiUtPtrExit
607  *
608  * PARAMETERS:  LineNumber          - Caller's line number
609  *              FunctionName        - Caller's procedure name
610  *              ModuleName          - Caller's module name
611  *              ComponentId         - Caller's component ID
612  *              Ptr                 - Pointer to display
613  *
614  * RETURN:      None
615  *
616  * DESCRIPTION: Function exit trace. Prints only if TRACE_FUNCTIONS bit is
617  *              set in DebugLevel. Prints exit value also.
618  *
619  ******************************************************************************/
620 
621 void
622 AcpiUtPtrExit (
623     UINT32                  LineNumber,
624     const char              *FunctionName,
625     const char              *ModuleName,
626     UINT32                  ComponentId,
627     UINT8                   *Ptr)
628 {
629 
630     /* Check if enabled up-front for performance */
631 
632     if (ACPI_IS_DEBUG_ENABLED (ACPI_LV_FUNCTIONS, ComponentId))
633     {
634         AcpiDebugPrint (ACPI_LV_FUNCTIONS,
635             LineNumber, FunctionName, ModuleName, ComponentId,
636             "%s %p\n", AcpiGbl_FunctionExitPrefix, Ptr);
637     }
638 
639     if (AcpiGbl_NestingLevel)
640     {
641         AcpiGbl_NestingLevel--;
642     }
643 }
644 
645 
646 /*******************************************************************************
647  *
648  * FUNCTION:    AcpiUtStrExit
649  *
650  * PARAMETERS:  LineNumber          - Caller's line number
651  *              FunctionName        - Caller's procedure name
652  *              ModuleName          - Caller's module name
653  *              ComponentId         - Caller's component ID
654  *              String              - String to display
655  *
656  * RETURN:      None
657  *
658  * DESCRIPTION: Function exit trace. Prints only if TRACE_FUNCTIONS bit is
659  *              set in DebugLevel. Prints exit value also.
660  *
661  ******************************************************************************/
662 
663 void
664 AcpiUtStrExit (
665     UINT32                  LineNumber,
666     const char              *FunctionName,
667     const char              *ModuleName,
668     UINT32                  ComponentId,
669     const char              *String)
670 {
671 
672     /* Check if enabled up-front for performance */
673 
674     if (ACPI_IS_DEBUG_ENABLED (ACPI_LV_FUNCTIONS, ComponentId))
675     {
676         AcpiDebugPrint (ACPI_LV_FUNCTIONS,
677             LineNumber, FunctionName, ModuleName, ComponentId,
678             "%s %s\n", AcpiGbl_FunctionExitPrefix, String);
679     }
680 
681     if (AcpiGbl_NestingLevel)
682     {
683         AcpiGbl_NestingLevel--;
684     }
685 }
686 
687 
688 /*******************************************************************************
689  *
690  * FUNCTION:    AcpiTracePoint
691  *
692  * PARAMETERS:  Type                - Trace event type
693  *              Begin               - TRUE if before execution
694  *              Aml                 - Executed AML address
695  *              Pathname            - Object path
696  *              Pointer             - Pointer to the related object
697  *
698  * RETURN:      None
699  *
700  * DESCRIPTION: Interpreter execution trace.
701  *
702  ******************************************************************************/
703 
704 void
705 AcpiTracePoint (
706     ACPI_TRACE_EVENT_TYPE   Type,
707     BOOLEAN                 Begin,
708     UINT8                   *Aml,
709     char                    *Pathname)
710 {
711 
712     ACPI_FUNCTION_ENTRY ();
713 
714     AcpiExTracePoint (Type, Begin, Aml, Pathname);
715 
716 #ifdef ACPI_USE_SYSTEM_TRACER
717     AcpiOsTracePoint (Type, Begin, Aml, Pathname);
718 #endif
719 }
720 
721 ACPI_EXPORT_SYMBOL (AcpiTracePoint)
722 
723 
724 #endif
725