xref: /dflybsd-src/sys/contrib/dev/acpica/source/tools/acpidump/apmain.c (revision 9e1c08804a46f1c1a9cd11e190ddba7d2bc4abed)
10d02842fSSascha Wildner /******************************************************************************
20d02842fSSascha Wildner  *
30d02842fSSascha Wildner  * Module Name: apmain - Main module for the acpidump utility
40d02842fSSascha Wildner  *
50d02842fSSascha Wildner  *****************************************************************************/
60d02842fSSascha Wildner 
70d02842fSSascha Wildner /*
820294b7eSSascha Wildner  * Copyright (C) 2000 - 2014, Intel Corp.
90d02842fSSascha Wildner  * All rights reserved.
100d02842fSSascha Wildner  *
110d02842fSSascha Wildner  * Redistribution and use in source and binary forms, with or without
120d02842fSSascha Wildner  * modification, are permitted provided that the following conditions
130d02842fSSascha Wildner  * are met:
140d02842fSSascha Wildner  * 1. Redistributions of source code must retain the above copyright
150d02842fSSascha Wildner  *    notice, this list of conditions, and the following disclaimer,
160d02842fSSascha Wildner  *    without modification.
170d02842fSSascha Wildner  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
180d02842fSSascha Wildner  *    substantially similar to the "NO WARRANTY" disclaimer below
190d02842fSSascha Wildner  *    ("Disclaimer") and any redistribution must be conditioned upon
200d02842fSSascha Wildner  *    including a substantially similar Disclaimer requirement for further
210d02842fSSascha Wildner  *    binary redistribution.
220d02842fSSascha Wildner  * 3. Neither the names of the above-listed copyright holders nor the names
230d02842fSSascha Wildner  *    of any contributors may be used to endorse or promote products derived
240d02842fSSascha Wildner  *    from this software without specific prior written permission.
250d02842fSSascha Wildner  *
260d02842fSSascha Wildner  * Alternatively, this software may be distributed under the terms of the
270d02842fSSascha Wildner  * GNU General Public License ("GPL") version 2 as published by the Free
280d02842fSSascha Wildner  * Software Foundation.
290d02842fSSascha Wildner  *
300d02842fSSascha Wildner  * NO WARRANTY
310d02842fSSascha Wildner  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
320d02842fSSascha Wildner  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
330d02842fSSascha Wildner  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
340d02842fSSascha Wildner  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
350d02842fSSascha Wildner  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
360d02842fSSascha Wildner  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
370d02842fSSascha Wildner  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
380d02842fSSascha Wildner  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
390d02842fSSascha Wildner  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
400d02842fSSascha Wildner  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
410d02842fSSascha Wildner  * POSSIBILITY OF SUCH DAMAGES.
420d02842fSSascha Wildner  */
430d02842fSSascha Wildner 
440d02842fSSascha Wildner #define _DECLARE_GLOBALS
450d02842fSSascha Wildner #include "acpidump.h"
460d02842fSSascha Wildner #include "acapps.h"
470d02842fSSascha Wildner 
480d02842fSSascha Wildner 
490d02842fSSascha Wildner /*
500d02842fSSascha Wildner  * acpidump - A portable utility for obtaining system ACPI tables and dumping
510d02842fSSascha Wildner  * them in an ASCII hex format suitable for binary extraction via acpixtract.
520d02842fSSascha Wildner  *
530d02842fSSascha Wildner  * Obtaining the system ACPI tables is an OS-specific operation.
540d02842fSSascha Wildner  *
550d02842fSSascha Wildner  * This utility can be ported to any host operating system by providing a
560d02842fSSascha Wildner  * module containing system-specific versions of these interfaces:
570d02842fSSascha Wildner  *
580d02842fSSascha Wildner  *      AcpiOsGetTableByAddress
590d02842fSSascha Wildner  *      AcpiOsGetTableByIndex
600d02842fSSascha Wildner  *      AcpiOsGetTableByName
610d02842fSSascha Wildner  *
620d02842fSSascha Wildner  * See the ACPICA Reference Guide for the exact definitions of these
630d02842fSSascha Wildner  * interfaces. Also, see these ACPICA source code modules for example
640d02842fSSascha Wildner  * implementations:
650d02842fSSascha Wildner  *
660d02842fSSascha Wildner  *      source/os_specific/service_layers/oswintbl.c
670d02842fSSascha Wildner  *      source/os_specific/service_layers/oslinuxtbl.c
680d02842fSSascha Wildner  */
690d02842fSSascha Wildner 
700d02842fSSascha Wildner 
710d02842fSSascha Wildner /* Local prototypes */
720d02842fSSascha Wildner 
730d02842fSSascha Wildner static void
740d02842fSSascha Wildner ApDisplayUsage (
750d02842fSSascha Wildner     void);
760d02842fSSascha Wildner 
770d02842fSSascha Wildner static int
780d02842fSSascha Wildner ApDoOptions (
790d02842fSSascha Wildner     int                     argc,
800d02842fSSascha Wildner     char                    **argv);
810d02842fSSascha Wildner 
820d02842fSSascha Wildner static void
830d02842fSSascha Wildner ApInsertAction (
840d02842fSSascha Wildner     char                    *Argument,
850d02842fSSascha Wildner     UINT32                  ToBeDone);
860d02842fSSascha Wildner 
870d02842fSSascha Wildner 
880d02842fSSascha Wildner /* Table for deferred actions from command line options */
890d02842fSSascha Wildner 
900d02842fSSascha Wildner AP_DUMP_ACTION              ActionTable [AP_MAX_ACTIONS];
910d02842fSSascha Wildner UINT32                      CurrentAction = 0;
920d02842fSSascha Wildner 
930d02842fSSascha Wildner 
940d02842fSSascha Wildner #define AP_UTILITY_NAME             "ACPI Binary Table Dump Utility"
95*9e1c0880SSascha Wildner #define AP_SUPPORTED_OPTIONS        "?a:bcf:hn:o:r:svxz"
960d02842fSSascha Wildner 
970d02842fSSascha Wildner 
980d02842fSSascha Wildner /******************************************************************************
990d02842fSSascha Wildner  *
1000d02842fSSascha Wildner  * FUNCTION:    ApDisplayUsage
1010d02842fSSascha Wildner  *
1020d02842fSSascha Wildner  * DESCRIPTION: Usage message for the AcpiDump utility
1030d02842fSSascha Wildner  *
1040d02842fSSascha Wildner  ******************************************************************************/
1050d02842fSSascha Wildner 
1060d02842fSSascha Wildner static void
1070d02842fSSascha Wildner ApDisplayUsage (
1080d02842fSSascha Wildner     void)
1090d02842fSSascha Wildner {
1100d02842fSSascha Wildner 
1110d02842fSSascha Wildner     ACPI_USAGE_HEADER ("acpidump [options]");
1120d02842fSSascha Wildner 
1130d02842fSSascha Wildner     ACPI_OPTION ("-b",                      "Dump tables to binary files");
1140d02842fSSascha Wildner     ACPI_OPTION ("-c",                      "Dump customized tables");
1150d02842fSSascha Wildner     ACPI_OPTION ("-h -?",                   "This help message");
1160d02842fSSascha Wildner     ACPI_OPTION ("-o <File>",               "Redirect output to file");
1170d02842fSSascha Wildner     ACPI_OPTION ("-r <Address>",            "Dump tables from specified RSDP");
1180d02842fSSascha Wildner     ACPI_OPTION ("-s",                      "Print table summaries only");
1190d02842fSSascha Wildner     ACPI_OPTION ("-v",                      "Display version information");
1200d02842fSSascha Wildner     ACPI_OPTION ("-z",                      "Verbose mode");
1210d02842fSSascha Wildner 
1220d02842fSSascha Wildner     printf ("\nTable Options:\n");
1230d02842fSSascha Wildner 
1240d02842fSSascha Wildner     ACPI_OPTION ("-a <Address>",            "Get table via a physical address");
1250d02842fSSascha Wildner     ACPI_OPTION ("-f <BinaryFile>",         "Get table via a binary file");
1260d02842fSSascha Wildner     ACPI_OPTION ("-n <Signature>",          "Get table via a name/signature");
127*9e1c0880SSascha Wildner     ACPI_OPTION ("-x",                      "Do not use but dump XSDT");
128*9e1c0880SSascha Wildner     ACPI_OPTION ("-x -x",                   "Do not use or dump XSDT");
1290d02842fSSascha Wildner 
1300d02842fSSascha Wildner     printf (
1310d02842fSSascha Wildner         "\n"
1320d02842fSSascha Wildner         "Invocation without parameters dumps all available tables\n"
1330d02842fSSascha Wildner         "Multiple mixed instances of -a, -f, and -n are supported\n\n");
1340d02842fSSascha Wildner }
1350d02842fSSascha Wildner 
1360d02842fSSascha Wildner 
1370d02842fSSascha Wildner /******************************************************************************
1380d02842fSSascha Wildner  *
1390d02842fSSascha Wildner  * FUNCTION:    ApInsertAction
1400d02842fSSascha Wildner  *
1410d02842fSSascha Wildner  * PARAMETERS:  Argument            - Pointer to the argument for this action
1420d02842fSSascha Wildner  *              ToBeDone            - What to do to process this action
1430d02842fSSascha Wildner  *
1440d02842fSSascha Wildner  * RETURN:      None. Exits program if action table becomes full.
1450d02842fSSascha Wildner  *
1460d02842fSSascha Wildner  * DESCRIPTION: Add an action item to the action table
1470d02842fSSascha Wildner  *
1480d02842fSSascha Wildner  ******************************************************************************/
1490d02842fSSascha Wildner 
1500d02842fSSascha Wildner static void
1510d02842fSSascha Wildner ApInsertAction (
1520d02842fSSascha Wildner     char                    *Argument,
1530d02842fSSascha Wildner     UINT32                  ToBeDone)
1540d02842fSSascha Wildner {
1550d02842fSSascha Wildner 
1560d02842fSSascha Wildner     /* Insert action and check for table overflow */
1570d02842fSSascha Wildner 
1580d02842fSSascha Wildner     ActionTable [CurrentAction].Argument = Argument;
1590d02842fSSascha Wildner     ActionTable [CurrentAction].ToBeDone = ToBeDone;
1600d02842fSSascha Wildner 
1610d02842fSSascha Wildner     CurrentAction++;
1620d02842fSSascha Wildner     if (CurrentAction > AP_MAX_ACTIONS)
1630d02842fSSascha Wildner     {
1640d02842fSSascha Wildner         fprintf (stderr, "Too many table options (max %u)\n", AP_MAX_ACTIONS);
1650d02842fSSascha Wildner         exit (-1);
1660d02842fSSascha Wildner     }
1670d02842fSSascha Wildner }
1680d02842fSSascha Wildner 
1690d02842fSSascha Wildner 
1700d02842fSSascha Wildner /******************************************************************************
1710d02842fSSascha Wildner  *
1720d02842fSSascha Wildner  * FUNCTION:    ApDoOptions
1730d02842fSSascha Wildner  *
1740d02842fSSascha Wildner  * PARAMETERS:  argc/argv           - Standard argc/argv
1750d02842fSSascha Wildner  *
1760d02842fSSascha Wildner  * RETURN:      Status
1770d02842fSSascha Wildner  *
1780d02842fSSascha Wildner  * DESCRIPTION: Command line option processing. The main actions for getting
1790d02842fSSascha Wildner  *              and dumping tables are deferred via the action table.
1800d02842fSSascha Wildner  *
1810d02842fSSascha Wildner  *****************************************************************************/
1820d02842fSSascha Wildner 
1830d02842fSSascha Wildner static int
1840d02842fSSascha Wildner ApDoOptions (
1850d02842fSSascha Wildner     int                     argc,
1860d02842fSSascha Wildner     char                    **argv)
1870d02842fSSascha Wildner {
1880d02842fSSascha Wildner     int                     j;
1890d02842fSSascha Wildner     ACPI_STATUS             Status;
1900d02842fSSascha Wildner 
1910d02842fSSascha Wildner 
1920d02842fSSascha Wildner     /* Command line options */
1930d02842fSSascha Wildner 
1940d02842fSSascha Wildner     while ((j = AcpiGetopt (argc, argv, AP_SUPPORTED_OPTIONS)) != EOF) switch (j)
1950d02842fSSascha Wildner     {
1960d02842fSSascha Wildner     /*
1970d02842fSSascha Wildner      * Global options
1980d02842fSSascha Wildner      */
1990d02842fSSascha Wildner     case 'b':   /* Dump all input tables to binary files */
2000d02842fSSascha Wildner 
2010d02842fSSascha Wildner         Gbl_BinaryMode = TRUE;
2020d02842fSSascha Wildner         continue;
2030d02842fSSascha Wildner 
2040d02842fSSascha Wildner     case 'c':   /* Dump customized tables */
2050d02842fSSascha Wildner 
2060d02842fSSascha Wildner         Gbl_DumpCustomizedTables = TRUE;
2070d02842fSSascha Wildner         continue;
2080d02842fSSascha Wildner 
2090d02842fSSascha Wildner     case 'h':
2100d02842fSSascha Wildner     case '?':
2110d02842fSSascha Wildner 
2120d02842fSSascha Wildner         ApDisplayUsage ();
2130d02842fSSascha Wildner         exit (0);
2140d02842fSSascha Wildner 
2150d02842fSSascha Wildner     case 'o':   /* Redirect output to a single file */
2160d02842fSSascha Wildner 
2170d02842fSSascha Wildner         if (ApOpenOutputFile (AcpiGbl_Optarg))
2180d02842fSSascha Wildner         {
2190d02842fSSascha Wildner             exit (-1);
2200d02842fSSascha Wildner         }
2210d02842fSSascha Wildner         continue;
2220d02842fSSascha Wildner 
2230d02842fSSascha Wildner     case 'r':   /* Dump tables from specified RSDP */
2240d02842fSSascha Wildner 
2250d02842fSSascha Wildner         Status = AcpiUtStrtoul64 (AcpiGbl_Optarg, 0, &Gbl_RsdpBase);
2260d02842fSSascha Wildner         if (ACPI_FAILURE (Status))
2270d02842fSSascha Wildner         {
2280d02842fSSascha Wildner             fprintf (stderr, "%s: Could not convert to a physical address\n",
2290d02842fSSascha Wildner                 AcpiGbl_Optarg);
2300d02842fSSascha Wildner             exit (-1);
2310d02842fSSascha Wildner         }
2320d02842fSSascha Wildner         continue;
2330d02842fSSascha Wildner 
2340d02842fSSascha Wildner     case 's':   /* Print table summaries only */
2350d02842fSSascha Wildner 
2360d02842fSSascha Wildner         Gbl_SummaryMode = TRUE;
2370d02842fSSascha Wildner         continue;
2380d02842fSSascha Wildner 
239*9e1c0880SSascha Wildner     case 'x':   /* Do not use XSDT */
240*9e1c0880SSascha Wildner 
241*9e1c0880SSascha Wildner         if (!AcpiGbl_DoNotUseXsdt)
242*9e1c0880SSascha Wildner         {
243*9e1c0880SSascha Wildner             AcpiGbl_DoNotUseXsdt = TRUE;
244*9e1c0880SSascha Wildner         }
245*9e1c0880SSascha Wildner         else
246*9e1c0880SSascha Wildner         {
247*9e1c0880SSascha Wildner             Gbl_DoNotDumpXsdt = TRUE;
248*9e1c0880SSascha Wildner         }
249*9e1c0880SSascha Wildner         continue;
250*9e1c0880SSascha Wildner 
2510d02842fSSascha Wildner     case 'v':   /* Revision/version */
2520d02842fSSascha Wildner 
2530d02842fSSascha Wildner         printf (ACPI_COMMON_SIGNON (AP_UTILITY_NAME));
2540d02842fSSascha Wildner         exit (0);
2550d02842fSSascha Wildner 
2560d02842fSSascha Wildner     case 'z':   /* Verbose mode */
2570d02842fSSascha Wildner 
2580d02842fSSascha Wildner         Gbl_VerboseMode = TRUE;
2590d02842fSSascha Wildner         fprintf (stderr, ACPI_COMMON_SIGNON (AP_UTILITY_NAME));
2600d02842fSSascha Wildner         continue;
2610d02842fSSascha Wildner 
2620d02842fSSascha Wildner     /*
2630d02842fSSascha Wildner      * Table options
2640d02842fSSascha Wildner      */
2650d02842fSSascha Wildner     case 'a':   /* Get table by physical address */
2660d02842fSSascha Wildner 
2670d02842fSSascha Wildner         ApInsertAction (AcpiGbl_Optarg, AP_DUMP_TABLE_BY_ADDRESS);
2680d02842fSSascha Wildner         break;
2690d02842fSSascha Wildner 
2700d02842fSSascha Wildner     case 'f':   /* Get table from a file */
2710d02842fSSascha Wildner 
2720d02842fSSascha Wildner         ApInsertAction (AcpiGbl_Optarg, AP_DUMP_TABLE_BY_FILE);
2730d02842fSSascha Wildner         break;
2740d02842fSSascha Wildner 
2750d02842fSSascha Wildner     case 'n':   /* Get table by input name (signature) */
2760d02842fSSascha Wildner 
2770d02842fSSascha Wildner         ApInsertAction (AcpiGbl_Optarg, AP_DUMP_TABLE_BY_NAME);
2780d02842fSSascha Wildner         break;
2790d02842fSSascha Wildner 
2800d02842fSSascha Wildner     default:
2810d02842fSSascha Wildner 
2820d02842fSSascha Wildner         ApDisplayUsage ();
2830d02842fSSascha Wildner         exit (-1);
2840d02842fSSascha Wildner     }
2850d02842fSSascha Wildner 
2860d02842fSSascha Wildner     /* If there are no actions, this means "get/dump all tables" */
2870d02842fSSascha Wildner 
2880d02842fSSascha Wildner     if (CurrentAction == 0)
2890d02842fSSascha Wildner     {
2900d02842fSSascha Wildner         ApInsertAction (NULL, AP_DUMP_ALL_TABLES);
2910d02842fSSascha Wildner     }
2920d02842fSSascha Wildner 
2930d02842fSSascha Wildner     return (0);
2940d02842fSSascha Wildner }
2950d02842fSSascha Wildner 
2960d02842fSSascha Wildner 
2970d02842fSSascha Wildner /******************************************************************************
2980d02842fSSascha Wildner  *
2990d02842fSSascha Wildner  * FUNCTION:    main
3000d02842fSSascha Wildner  *
3010d02842fSSascha Wildner  * PARAMETERS:  argc/argv           - Standard argc/argv
3020d02842fSSascha Wildner  *
3030d02842fSSascha Wildner  * RETURN:      Status
3040d02842fSSascha Wildner  *
3050d02842fSSascha Wildner  * DESCRIPTION: C main function for acpidump utility
3060d02842fSSascha Wildner  *
3070d02842fSSascha Wildner  ******************************************************************************/
3080d02842fSSascha Wildner 
3090d02842fSSascha Wildner int ACPI_SYSTEM_XFACE
3100d02842fSSascha Wildner main (
3110d02842fSSascha Wildner     int                     argc,
3120d02842fSSascha Wildner     char                    *argv[])
3130d02842fSSascha Wildner {
3140d02842fSSascha Wildner     int                     Status = 0;
3150d02842fSSascha Wildner     AP_DUMP_ACTION          *Action;
3160d02842fSSascha Wildner     UINT32                  FileSize;
3170d02842fSSascha Wildner     UINT32                  i;
3180d02842fSSascha Wildner 
3190d02842fSSascha Wildner 
3200d02842fSSascha Wildner     ACPI_DEBUG_INITIALIZE (); /* For debug version only */
3210d02842fSSascha Wildner 
3220d02842fSSascha Wildner     /* Process command line options */
3230d02842fSSascha Wildner 
3240d02842fSSascha Wildner     if (ApDoOptions (argc, argv))
3250d02842fSSascha Wildner     {
3260d02842fSSascha Wildner         return (-1);
3270d02842fSSascha Wildner     }
3280d02842fSSascha Wildner 
3290d02842fSSascha Wildner     /* Get/dump ACPI table(s) as requested */
3300d02842fSSascha Wildner 
3310d02842fSSascha Wildner     for (i = 0; i < CurrentAction; i++)
3320d02842fSSascha Wildner     {
3330d02842fSSascha Wildner         Action = &ActionTable[i];
3340d02842fSSascha Wildner         switch (Action->ToBeDone)
3350d02842fSSascha Wildner         {
3360d02842fSSascha Wildner         case AP_DUMP_ALL_TABLES:
3370d02842fSSascha Wildner 
3380d02842fSSascha Wildner             Status = ApDumpAllTables ();
3390d02842fSSascha Wildner             break;
3400d02842fSSascha Wildner 
3410d02842fSSascha Wildner         case AP_DUMP_TABLE_BY_ADDRESS:
3420d02842fSSascha Wildner 
3430d02842fSSascha Wildner             Status = ApDumpTableByAddress (Action->Argument);
3440d02842fSSascha Wildner             break;
3450d02842fSSascha Wildner 
3460d02842fSSascha Wildner         case AP_DUMP_TABLE_BY_NAME:
3470d02842fSSascha Wildner 
3480d02842fSSascha Wildner             Status = ApDumpTableByName (Action->Argument);
3490d02842fSSascha Wildner             break;
3500d02842fSSascha Wildner 
3510d02842fSSascha Wildner         case AP_DUMP_TABLE_BY_FILE:
3520d02842fSSascha Wildner 
3530d02842fSSascha Wildner             Status = ApDumpTableFromFile (Action->Argument);
3540d02842fSSascha Wildner             break;
3550d02842fSSascha Wildner 
3560d02842fSSascha Wildner         default:
3570d02842fSSascha Wildner 
3580d02842fSSascha Wildner             fprintf (stderr, "Internal error, invalid action: 0x%X\n",
3590d02842fSSascha Wildner                 Action->ToBeDone);
3600d02842fSSascha Wildner             return (-1);
3610d02842fSSascha Wildner         }
3620d02842fSSascha Wildner 
3630d02842fSSascha Wildner         if (Status)
3640d02842fSSascha Wildner         {
3650d02842fSSascha Wildner             return (Status);
3660d02842fSSascha Wildner         }
3670d02842fSSascha Wildner     }
3680d02842fSSascha Wildner 
3690d02842fSSascha Wildner     if (Gbl_OutputFile)
3700d02842fSSascha Wildner     {
3710d02842fSSascha Wildner         if (Gbl_VerboseMode)
3720d02842fSSascha Wildner         {
3730d02842fSSascha Wildner             /* Summary for the output file */
3740d02842fSSascha Wildner 
375d4972a9cSSascha Wildner             FileSize = CmGetFileSize (Gbl_OutputFile);
3760d02842fSSascha Wildner             fprintf (stderr, "Output file %s contains 0x%X (%u) bytes\n\n",
3770d02842fSSascha Wildner                 Gbl_OutputFilename, FileSize, FileSize);
3780d02842fSSascha Wildner         }
3790d02842fSSascha Wildner 
3800d02842fSSascha Wildner         fclose (Gbl_OutputFile);
3810d02842fSSascha Wildner     }
3820d02842fSSascha Wildner 
3830d02842fSSascha Wildner     return (Status);
3840d02842fSSascha Wildner }
385