xref: /dflybsd-src/sys/contrib/dev/acpica/source/tools/acpidump/apmain.c (revision 5f39c7e70ca0960d1868c75a449064df712dbb10)
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 
82*5f39c7e7SSascha Wildner static int
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"
959e1c0880SSascha 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 
122*5f39c7e7SSascha Wildner     ACPI_USAGE_TEXT ("\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");
1279e1c0880SSascha Wildner     ACPI_OPTION ("-x",                      "Do not use but dump XSDT");
1289e1c0880SSascha Wildner     ACPI_OPTION ("-x -x",                   "Do not use or dump XSDT");
1290d02842fSSascha Wildner 
130*5f39c7e7SSascha Wildner     ACPI_USAGE_TEXT (
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  *
144*5f39c7e7SSascha Wildner  * RETURN:      Status
1450d02842fSSascha Wildner  *
1460d02842fSSascha Wildner  * DESCRIPTION: Add an action item to the action table
1470d02842fSSascha Wildner  *
1480d02842fSSascha Wildner  ******************************************************************************/
1490d02842fSSascha Wildner 
150*5f39c7e7SSascha Wildner static int
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     {
164*5f39c7e7SSascha Wildner         AcpiLogError ("Too many table options (max %u)\n", AP_MAX_ACTIONS);
165*5f39c7e7SSascha Wildner         return (-1);
1660d02842fSSascha Wildner     }
167*5f39c7e7SSascha Wildner 
168*5f39c7e7SSascha Wildner     return (0);
1690d02842fSSascha Wildner }
1700d02842fSSascha Wildner 
1710d02842fSSascha Wildner 
1720d02842fSSascha Wildner /******************************************************************************
1730d02842fSSascha Wildner  *
1740d02842fSSascha Wildner  * FUNCTION:    ApDoOptions
1750d02842fSSascha Wildner  *
1760d02842fSSascha Wildner  * PARAMETERS:  argc/argv           - Standard argc/argv
1770d02842fSSascha Wildner  *
1780d02842fSSascha Wildner  * RETURN:      Status
1790d02842fSSascha Wildner  *
1800d02842fSSascha Wildner  * DESCRIPTION: Command line option processing. The main actions for getting
1810d02842fSSascha Wildner  *              and dumping tables are deferred via the action table.
1820d02842fSSascha Wildner  *
1830d02842fSSascha Wildner  *****************************************************************************/
1840d02842fSSascha Wildner 
1850d02842fSSascha Wildner static int
1860d02842fSSascha Wildner ApDoOptions (
1870d02842fSSascha Wildner     int                     argc,
1880d02842fSSascha Wildner     char                    **argv)
1890d02842fSSascha Wildner {
1900d02842fSSascha Wildner     int                     j;
1910d02842fSSascha Wildner     ACPI_STATUS             Status;
1920d02842fSSascha Wildner 
1930d02842fSSascha Wildner 
1940d02842fSSascha Wildner     /* Command line options */
1950d02842fSSascha Wildner 
196*5f39c7e7SSascha Wildner     while ((j = AcpiGetopt (argc, argv, AP_SUPPORTED_OPTIONS)) != ACPI_OPT_END) switch (j)
1970d02842fSSascha Wildner     {
1980d02842fSSascha Wildner     /*
1990d02842fSSascha Wildner      * Global options
2000d02842fSSascha Wildner      */
2010d02842fSSascha Wildner     case 'b':   /* Dump all input tables to binary files */
2020d02842fSSascha Wildner 
2030d02842fSSascha Wildner         Gbl_BinaryMode = TRUE;
2040d02842fSSascha Wildner         continue;
2050d02842fSSascha Wildner 
2060d02842fSSascha Wildner     case 'c':   /* Dump customized tables */
2070d02842fSSascha Wildner 
2080d02842fSSascha Wildner         Gbl_DumpCustomizedTables = TRUE;
2090d02842fSSascha Wildner         continue;
2100d02842fSSascha Wildner 
2110d02842fSSascha Wildner     case 'h':
2120d02842fSSascha Wildner     case '?':
2130d02842fSSascha Wildner 
2140d02842fSSascha Wildner         ApDisplayUsage ();
215*5f39c7e7SSascha Wildner         return (1);
2160d02842fSSascha Wildner 
2170d02842fSSascha Wildner     case 'o':   /* Redirect output to a single file */
2180d02842fSSascha Wildner 
2190d02842fSSascha Wildner         if (ApOpenOutputFile (AcpiGbl_Optarg))
2200d02842fSSascha Wildner         {
221*5f39c7e7SSascha Wildner             return (-1);
2220d02842fSSascha Wildner         }
2230d02842fSSascha Wildner         continue;
2240d02842fSSascha Wildner 
2250d02842fSSascha Wildner     case 'r':   /* Dump tables from specified RSDP */
2260d02842fSSascha Wildner 
2270d02842fSSascha Wildner         Status = AcpiUtStrtoul64 (AcpiGbl_Optarg, 0, &Gbl_RsdpBase);
2280d02842fSSascha Wildner         if (ACPI_FAILURE (Status))
2290d02842fSSascha Wildner         {
230*5f39c7e7SSascha Wildner             AcpiLogError ("%s: Could not convert to a physical address\n",
2310d02842fSSascha Wildner                 AcpiGbl_Optarg);
232*5f39c7e7SSascha Wildner             return (-1);
2330d02842fSSascha Wildner         }
2340d02842fSSascha Wildner         continue;
2350d02842fSSascha Wildner 
2360d02842fSSascha Wildner     case 's':   /* Print table summaries only */
2370d02842fSSascha Wildner 
2380d02842fSSascha Wildner         Gbl_SummaryMode = TRUE;
2390d02842fSSascha Wildner         continue;
2400d02842fSSascha Wildner 
2419e1c0880SSascha Wildner     case 'x':   /* Do not use XSDT */
2429e1c0880SSascha Wildner 
2439e1c0880SSascha Wildner         if (!AcpiGbl_DoNotUseXsdt)
2449e1c0880SSascha Wildner         {
2459e1c0880SSascha Wildner             AcpiGbl_DoNotUseXsdt = TRUE;
2469e1c0880SSascha Wildner         }
2479e1c0880SSascha Wildner         else
2489e1c0880SSascha Wildner         {
2499e1c0880SSascha Wildner             Gbl_DoNotDumpXsdt = TRUE;
2509e1c0880SSascha Wildner         }
2519e1c0880SSascha Wildner         continue;
2529e1c0880SSascha Wildner 
2530d02842fSSascha Wildner     case 'v':   /* Revision/version */
2540d02842fSSascha Wildner 
255*5f39c7e7SSascha Wildner         AcpiOsPrintf (ACPI_COMMON_SIGNON (AP_UTILITY_NAME));
256*5f39c7e7SSascha Wildner         return (1);
2570d02842fSSascha Wildner 
2580d02842fSSascha Wildner     case 'z':   /* Verbose mode */
2590d02842fSSascha Wildner 
2600d02842fSSascha Wildner         Gbl_VerboseMode = TRUE;
261*5f39c7e7SSascha Wildner         AcpiLogError (ACPI_COMMON_SIGNON (AP_UTILITY_NAME));
2620d02842fSSascha Wildner         continue;
2630d02842fSSascha Wildner 
2640d02842fSSascha Wildner     /*
2650d02842fSSascha Wildner      * Table options
2660d02842fSSascha Wildner      */
2670d02842fSSascha Wildner     case 'a':   /* Get table by physical address */
2680d02842fSSascha Wildner 
269*5f39c7e7SSascha Wildner         if (ApInsertAction (AcpiGbl_Optarg, AP_DUMP_TABLE_BY_ADDRESS))
270*5f39c7e7SSascha Wildner         {
271*5f39c7e7SSascha Wildner             return (-1);
272*5f39c7e7SSascha Wildner         }
2730d02842fSSascha Wildner         break;
2740d02842fSSascha Wildner 
2750d02842fSSascha Wildner     case 'f':   /* Get table from a file */
2760d02842fSSascha Wildner 
277*5f39c7e7SSascha Wildner         if (ApInsertAction (AcpiGbl_Optarg, AP_DUMP_TABLE_BY_FILE))
278*5f39c7e7SSascha Wildner         {
279*5f39c7e7SSascha Wildner             return (-1);
280*5f39c7e7SSascha Wildner         }
2810d02842fSSascha Wildner         break;
2820d02842fSSascha Wildner 
2830d02842fSSascha Wildner     case 'n':   /* Get table by input name (signature) */
2840d02842fSSascha Wildner 
285*5f39c7e7SSascha Wildner         if (ApInsertAction (AcpiGbl_Optarg, AP_DUMP_TABLE_BY_NAME))
286*5f39c7e7SSascha Wildner         {
287*5f39c7e7SSascha Wildner             return (-1);
288*5f39c7e7SSascha Wildner         }
2890d02842fSSascha Wildner         break;
2900d02842fSSascha Wildner 
2910d02842fSSascha Wildner     default:
2920d02842fSSascha Wildner 
2930d02842fSSascha Wildner         ApDisplayUsage ();
294*5f39c7e7SSascha Wildner         return (-1);
2950d02842fSSascha Wildner     }
2960d02842fSSascha Wildner 
2970d02842fSSascha Wildner     /* If there are no actions, this means "get/dump all tables" */
2980d02842fSSascha Wildner 
2990d02842fSSascha Wildner     if (CurrentAction == 0)
3000d02842fSSascha Wildner     {
301*5f39c7e7SSascha Wildner         if (ApInsertAction (NULL, AP_DUMP_ALL_TABLES))
302*5f39c7e7SSascha Wildner         {
303*5f39c7e7SSascha Wildner             return (-1);
304*5f39c7e7SSascha Wildner         }
3050d02842fSSascha Wildner     }
3060d02842fSSascha Wildner 
3070d02842fSSascha Wildner     return (0);
3080d02842fSSascha Wildner }
3090d02842fSSascha Wildner 
3100d02842fSSascha Wildner 
3110d02842fSSascha Wildner /******************************************************************************
3120d02842fSSascha Wildner  *
3130d02842fSSascha Wildner  * FUNCTION:    main
3140d02842fSSascha Wildner  *
3150d02842fSSascha Wildner  * PARAMETERS:  argc/argv           - Standard argc/argv
3160d02842fSSascha Wildner  *
3170d02842fSSascha Wildner  * RETURN:      Status
3180d02842fSSascha Wildner  *
3190d02842fSSascha Wildner  * DESCRIPTION: C main function for acpidump utility
3200d02842fSSascha Wildner  *
3210d02842fSSascha Wildner  ******************************************************************************/
3220d02842fSSascha Wildner 
323*5f39c7e7SSascha Wildner #ifndef _GNU_EFI
3240d02842fSSascha Wildner int ACPI_SYSTEM_XFACE
3250d02842fSSascha Wildner main (
3260d02842fSSascha Wildner     int                     argc,
3270d02842fSSascha Wildner     char                    *argv[])
328*5f39c7e7SSascha Wildner #else
329*5f39c7e7SSascha Wildner int ACPI_SYSTEM_XFACE
330*5f39c7e7SSascha Wildner acpi_main (
331*5f39c7e7SSascha Wildner     int                     argc,
332*5f39c7e7SSascha Wildner     char                    *argv[])
333*5f39c7e7SSascha Wildner #endif
3340d02842fSSascha Wildner {
3350d02842fSSascha Wildner     int                     Status = 0;
3360d02842fSSascha Wildner     AP_DUMP_ACTION          *Action;
3370d02842fSSascha Wildner     UINT32                  FileSize;
3380d02842fSSascha Wildner     UINT32                  i;
3390d02842fSSascha Wildner 
3400d02842fSSascha Wildner 
3410d02842fSSascha Wildner     ACPI_DEBUG_INITIALIZE (); /* For debug version only */
342*5f39c7e7SSascha Wildner     AcpiOsInitialize ();
343*5f39c7e7SSascha Wildner     Gbl_OutputFile = ACPI_FILE_OUT;
3440d02842fSSascha Wildner 
3450d02842fSSascha Wildner     /* Process command line options */
3460d02842fSSascha Wildner 
347*5f39c7e7SSascha Wildner     Status = ApDoOptions (argc, argv);
348*5f39c7e7SSascha Wildner     if (Status > 0)
3490d02842fSSascha Wildner     {
350*5f39c7e7SSascha Wildner         return (0);
351*5f39c7e7SSascha Wildner     }
352*5f39c7e7SSascha Wildner     if (Status < 0)
353*5f39c7e7SSascha Wildner     {
354*5f39c7e7SSascha Wildner         return (Status);
3550d02842fSSascha Wildner     }
3560d02842fSSascha Wildner 
3570d02842fSSascha Wildner     /* Get/dump ACPI table(s) as requested */
3580d02842fSSascha Wildner 
3590d02842fSSascha Wildner     for (i = 0; i < CurrentAction; i++)
3600d02842fSSascha Wildner     {
3610d02842fSSascha Wildner         Action = &ActionTable[i];
3620d02842fSSascha Wildner         switch (Action->ToBeDone)
3630d02842fSSascha Wildner         {
3640d02842fSSascha Wildner         case AP_DUMP_ALL_TABLES:
3650d02842fSSascha Wildner 
3660d02842fSSascha Wildner             Status = ApDumpAllTables ();
3670d02842fSSascha Wildner             break;
3680d02842fSSascha Wildner 
3690d02842fSSascha Wildner         case AP_DUMP_TABLE_BY_ADDRESS:
3700d02842fSSascha Wildner 
3710d02842fSSascha Wildner             Status = ApDumpTableByAddress (Action->Argument);
3720d02842fSSascha Wildner             break;
3730d02842fSSascha Wildner 
3740d02842fSSascha Wildner         case AP_DUMP_TABLE_BY_NAME:
3750d02842fSSascha Wildner 
3760d02842fSSascha Wildner             Status = ApDumpTableByName (Action->Argument);
3770d02842fSSascha Wildner             break;
3780d02842fSSascha Wildner 
3790d02842fSSascha Wildner         case AP_DUMP_TABLE_BY_FILE:
3800d02842fSSascha Wildner 
3810d02842fSSascha Wildner             Status = ApDumpTableFromFile (Action->Argument);
3820d02842fSSascha Wildner             break;
3830d02842fSSascha Wildner 
3840d02842fSSascha Wildner         default:
3850d02842fSSascha Wildner 
386*5f39c7e7SSascha Wildner             AcpiLogError ("Internal error, invalid action: 0x%X\n",
3870d02842fSSascha Wildner                 Action->ToBeDone);
3880d02842fSSascha Wildner             return (-1);
3890d02842fSSascha Wildner         }
3900d02842fSSascha Wildner 
3910d02842fSSascha Wildner         if (Status)
3920d02842fSSascha Wildner         {
3930d02842fSSascha Wildner             return (Status);
3940d02842fSSascha Wildner         }
3950d02842fSSascha Wildner     }
3960d02842fSSascha Wildner 
397*5f39c7e7SSascha Wildner     if (Gbl_OutputFilename)
3980d02842fSSascha Wildner     {
3990d02842fSSascha Wildner         if (Gbl_VerboseMode)
4000d02842fSSascha Wildner         {
4010d02842fSSascha Wildner             /* Summary for the output file */
4020d02842fSSascha Wildner 
403d4972a9cSSascha Wildner             FileSize = CmGetFileSize (Gbl_OutputFile);
404*5f39c7e7SSascha Wildner             AcpiLogError ("Output file %s contains 0x%X (%u) bytes\n\n",
4050d02842fSSascha Wildner                 Gbl_OutputFilename, FileSize, FileSize);
4060d02842fSSascha Wildner         }
4070d02842fSSascha Wildner 
408*5f39c7e7SSascha Wildner         AcpiOsCloseFile (Gbl_OutputFile);
4090d02842fSSascha Wildner     }
4100d02842fSSascha Wildner 
4110d02842fSSascha Wildner     return (Status);
4120d02842fSSascha Wildner }
413