10d02842fSSascha Wildner /****************************************************************************** 20d02842fSSascha Wildner * 30d02842fSSascha Wildner * Module Name: apmain - Main module for the acpidump utility 40d02842fSSascha Wildner * 50d02842fSSascha Wildner *****************************************************************************/ 60d02842fSSascha Wildner 70d02842fSSascha Wildner /* 8fe7b5cb4SSascha Wildner * Copyright (C) 2000 - 2015, 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 825f39c7e7SSascha 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" 95*25ca8c79SSascha Wildner #define AP_SUPPORTED_OPTIONS "?a:bc:f: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 ("-h -?", "This help message"); 1150d02842fSSascha Wildner ACPI_OPTION ("-o <File>", "Redirect output to file"); 1160d02842fSSascha Wildner ACPI_OPTION ("-r <Address>", "Dump tables from specified RSDP"); 1170d02842fSSascha Wildner ACPI_OPTION ("-s", "Print table summaries only"); 1180d02842fSSascha Wildner ACPI_OPTION ("-v", "Display version information"); 1190d02842fSSascha Wildner ACPI_OPTION ("-z", "Verbose mode"); 1200d02842fSSascha Wildner 1215f39c7e7SSascha Wildner ACPI_USAGE_TEXT ("\nTable Options:\n"); 1220d02842fSSascha Wildner 1230d02842fSSascha Wildner ACPI_OPTION ("-a <Address>", "Get table via a physical address"); 124*25ca8c79SSascha Wildner ACPI_OPTION ("-c <on|off>", "Turning on/off customized table dumping"); 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 1305f39c7e7SSascha 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 * 1445f39c7e7SSascha Wildner * RETURN: Status 1450d02842fSSascha Wildner * 1460d02842fSSascha Wildner * DESCRIPTION: Add an action item to the action table 1470d02842fSSascha Wildner * 1480d02842fSSascha Wildner ******************************************************************************/ 1490d02842fSSascha Wildner 1505f39c7e7SSascha 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 { 1645f39c7e7SSascha Wildner AcpiLogError ("Too many table options (max %u)\n", AP_MAX_ACTIONS); 1655f39c7e7SSascha Wildner return (-1); 1660d02842fSSascha Wildner } 1675f39c7e7SSascha Wildner 1685f39c7e7SSascha 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 1965f39c7e7SSascha 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 208*25ca8c79SSascha Wildner if (!strcmp (AcpiGbl_Optarg, "on")) 209*25ca8c79SSascha Wildner { 2100d02842fSSascha Wildner Gbl_DumpCustomizedTables = TRUE; 211*25ca8c79SSascha Wildner } 212*25ca8c79SSascha Wildner else if (!strcmp (AcpiGbl_Optarg, "off")) 213*25ca8c79SSascha Wildner { 214*25ca8c79SSascha Wildner Gbl_DumpCustomizedTables = FALSE; 215*25ca8c79SSascha Wildner } 216*25ca8c79SSascha Wildner else 217*25ca8c79SSascha Wildner { 218*25ca8c79SSascha Wildner AcpiLogError ("%s: Cannot handle this switch, please use on|off\n", 219*25ca8c79SSascha Wildner AcpiGbl_Optarg); 220*25ca8c79SSascha Wildner return (-1); 221*25ca8c79SSascha Wildner } 2220d02842fSSascha Wildner continue; 2230d02842fSSascha Wildner 2240d02842fSSascha Wildner case 'h': 2250d02842fSSascha Wildner case '?': 2260d02842fSSascha Wildner 2270d02842fSSascha Wildner ApDisplayUsage (); 2285f39c7e7SSascha Wildner return (1); 2290d02842fSSascha Wildner 2300d02842fSSascha Wildner case 'o': /* Redirect output to a single file */ 2310d02842fSSascha Wildner 2320d02842fSSascha Wildner if (ApOpenOutputFile (AcpiGbl_Optarg)) 2330d02842fSSascha Wildner { 2345f39c7e7SSascha Wildner return (-1); 2350d02842fSSascha Wildner } 2360d02842fSSascha Wildner continue; 2370d02842fSSascha Wildner 2380d02842fSSascha Wildner case 'r': /* Dump tables from specified RSDP */ 2390d02842fSSascha Wildner 2400d02842fSSascha Wildner Status = AcpiUtStrtoul64 (AcpiGbl_Optarg, 0, &Gbl_RsdpBase); 2410d02842fSSascha Wildner if (ACPI_FAILURE (Status)) 2420d02842fSSascha Wildner { 2435f39c7e7SSascha Wildner AcpiLogError ("%s: Could not convert to a physical address\n", 2440d02842fSSascha Wildner AcpiGbl_Optarg); 2455f39c7e7SSascha Wildner return (-1); 2460d02842fSSascha Wildner } 2470d02842fSSascha Wildner continue; 2480d02842fSSascha Wildner 2490d02842fSSascha Wildner case 's': /* Print table summaries only */ 2500d02842fSSascha Wildner 2510d02842fSSascha Wildner Gbl_SummaryMode = TRUE; 2520d02842fSSascha Wildner continue; 2530d02842fSSascha Wildner 2549e1c0880SSascha Wildner case 'x': /* Do not use XSDT */ 2559e1c0880SSascha Wildner 2569e1c0880SSascha Wildner if (!AcpiGbl_DoNotUseXsdt) 2579e1c0880SSascha Wildner { 2589e1c0880SSascha Wildner AcpiGbl_DoNotUseXsdt = TRUE; 2599e1c0880SSascha Wildner } 2609e1c0880SSascha Wildner else 2619e1c0880SSascha Wildner { 2629e1c0880SSascha Wildner Gbl_DoNotDumpXsdt = TRUE; 2639e1c0880SSascha Wildner } 2649e1c0880SSascha Wildner continue; 2659e1c0880SSascha Wildner 2660d02842fSSascha Wildner case 'v': /* Revision/version */ 2670d02842fSSascha Wildner 2685f39c7e7SSascha Wildner AcpiOsPrintf (ACPI_COMMON_SIGNON (AP_UTILITY_NAME)); 2695f39c7e7SSascha Wildner return (1); 2700d02842fSSascha Wildner 2710d02842fSSascha Wildner case 'z': /* Verbose mode */ 2720d02842fSSascha Wildner 2730d02842fSSascha Wildner Gbl_VerboseMode = TRUE; 2745f39c7e7SSascha Wildner AcpiLogError (ACPI_COMMON_SIGNON (AP_UTILITY_NAME)); 2750d02842fSSascha Wildner continue; 2760d02842fSSascha Wildner 2770d02842fSSascha Wildner /* 2780d02842fSSascha Wildner * Table options 2790d02842fSSascha Wildner */ 2800d02842fSSascha Wildner case 'a': /* Get table by physical address */ 2810d02842fSSascha Wildner 2825f39c7e7SSascha Wildner if (ApInsertAction (AcpiGbl_Optarg, AP_DUMP_TABLE_BY_ADDRESS)) 2835f39c7e7SSascha Wildner { 2845f39c7e7SSascha Wildner return (-1); 2855f39c7e7SSascha Wildner } 2860d02842fSSascha Wildner break; 2870d02842fSSascha Wildner 2880d02842fSSascha Wildner case 'f': /* Get table from a file */ 2890d02842fSSascha Wildner 2905f39c7e7SSascha Wildner if (ApInsertAction (AcpiGbl_Optarg, AP_DUMP_TABLE_BY_FILE)) 2915f39c7e7SSascha Wildner { 2925f39c7e7SSascha Wildner return (-1); 2935f39c7e7SSascha Wildner } 2940d02842fSSascha Wildner break; 2950d02842fSSascha Wildner 2960d02842fSSascha Wildner case 'n': /* Get table by input name (signature) */ 2970d02842fSSascha Wildner 2985f39c7e7SSascha Wildner if (ApInsertAction (AcpiGbl_Optarg, AP_DUMP_TABLE_BY_NAME)) 2995f39c7e7SSascha Wildner { 3005f39c7e7SSascha Wildner return (-1); 3015f39c7e7SSascha Wildner } 3020d02842fSSascha Wildner break; 3030d02842fSSascha Wildner 3040d02842fSSascha Wildner default: 3050d02842fSSascha Wildner 3060d02842fSSascha Wildner ApDisplayUsage (); 3075f39c7e7SSascha Wildner return (-1); 3080d02842fSSascha Wildner } 3090d02842fSSascha Wildner 3100d02842fSSascha Wildner /* If there are no actions, this means "get/dump all tables" */ 3110d02842fSSascha Wildner 3120d02842fSSascha Wildner if (CurrentAction == 0) 3130d02842fSSascha Wildner { 3145f39c7e7SSascha Wildner if (ApInsertAction (NULL, AP_DUMP_ALL_TABLES)) 3155f39c7e7SSascha Wildner { 3165f39c7e7SSascha Wildner return (-1); 3175f39c7e7SSascha Wildner } 3180d02842fSSascha Wildner } 3190d02842fSSascha Wildner 3200d02842fSSascha Wildner return (0); 3210d02842fSSascha Wildner } 3220d02842fSSascha Wildner 3230d02842fSSascha Wildner 3240d02842fSSascha Wildner /****************************************************************************** 3250d02842fSSascha Wildner * 3260d02842fSSascha Wildner * FUNCTION: main 3270d02842fSSascha Wildner * 3280d02842fSSascha Wildner * PARAMETERS: argc/argv - Standard argc/argv 3290d02842fSSascha Wildner * 3300d02842fSSascha Wildner * RETURN: Status 3310d02842fSSascha Wildner * 3320d02842fSSascha Wildner * DESCRIPTION: C main function for acpidump utility 3330d02842fSSascha Wildner * 3340d02842fSSascha Wildner ******************************************************************************/ 3350d02842fSSascha Wildner 3365f39c7e7SSascha Wildner #ifndef _GNU_EFI 3370d02842fSSascha Wildner int ACPI_SYSTEM_XFACE 3380d02842fSSascha Wildner main ( 3390d02842fSSascha Wildner int argc, 3400d02842fSSascha Wildner char *argv[]) 3415f39c7e7SSascha Wildner #else 3425f39c7e7SSascha Wildner int ACPI_SYSTEM_XFACE 3435f39c7e7SSascha Wildner acpi_main ( 3445f39c7e7SSascha Wildner int argc, 3455f39c7e7SSascha Wildner char *argv[]) 3465f39c7e7SSascha Wildner #endif 3470d02842fSSascha Wildner { 3480d02842fSSascha Wildner int Status = 0; 3490d02842fSSascha Wildner AP_DUMP_ACTION *Action; 3500d02842fSSascha Wildner UINT32 FileSize; 3510d02842fSSascha Wildner UINT32 i; 3520d02842fSSascha Wildner 3530d02842fSSascha Wildner 3540d02842fSSascha Wildner ACPI_DEBUG_INITIALIZE (); /* For debug version only */ 3555f39c7e7SSascha Wildner AcpiOsInitialize (); 3565f39c7e7SSascha Wildner Gbl_OutputFile = ACPI_FILE_OUT; 3570d02842fSSascha Wildner 3580d02842fSSascha Wildner /* Process command line options */ 3590d02842fSSascha Wildner 3605f39c7e7SSascha Wildner Status = ApDoOptions (argc, argv); 3615f39c7e7SSascha Wildner if (Status > 0) 3620d02842fSSascha Wildner { 3635f39c7e7SSascha Wildner return (0); 3645f39c7e7SSascha Wildner } 3655f39c7e7SSascha Wildner if (Status < 0) 3665f39c7e7SSascha Wildner { 3675f39c7e7SSascha Wildner return (Status); 3680d02842fSSascha Wildner } 3690d02842fSSascha Wildner 3700d02842fSSascha Wildner /* Get/dump ACPI table(s) as requested */ 3710d02842fSSascha Wildner 3720d02842fSSascha Wildner for (i = 0; i < CurrentAction; i++) 3730d02842fSSascha Wildner { 3740d02842fSSascha Wildner Action = &ActionTable[i]; 3750d02842fSSascha Wildner switch (Action->ToBeDone) 3760d02842fSSascha Wildner { 3770d02842fSSascha Wildner case AP_DUMP_ALL_TABLES: 3780d02842fSSascha Wildner 3790d02842fSSascha Wildner Status = ApDumpAllTables (); 3800d02842fSSascha Wildner break; 3810d02842fSSascha Wildner 3820d02842fSSascha Wildner case AP_DUMP_TABLE_BY_ADDRESS: 3830d02842fSSascha Wildner 3840d02842fSSascha Wildner Status = ApDumpTableByAddress (Action->Argument); 3850d02842fSSascha Wildner break; 3860d02842fSSascha Wildner 3870d02842fSSascha Wildner case AP_DUMP_TABLE_BY_NAME: 3880d02842fSSascha Wildner 3890d02842fSSascha Wildner Status = ApDumpTableByName (Action->Argument); 3900d02842fSSascha Wildner break; 3910d02842fSSascha Wildner 3920d02842fSSascha Wildner case AP_DUMP_TABLE_BY_FILE: 3930d02842fSSascha Wildner 3940d02842fSSascha Wildner Status = ApDumpTableFromFile (Action->Argument); 3950d02842fSSascha Wildner break; 3960d02842fSSascha Wildner 3970d02842fSSascha Wildner default: 3980d02842fSSascha Wildner 3995f39c7e7SSascha Wildner AcpiLogError ("Internal error, invalid action: 0x%X\n", 4000d02842fSSascha Wildner Action->ToBeDone); 4010d02842fSSascha Wildner return (-1); 4020d02842fSSascha Wildner } 4030d02842fSSascha Wildner 4040d02842fSSascha Wildner if (Status) 4050d02842fSSascha Wildner { 4060d02842fSSascha Wildner return (Status); 4070d02842fSSascha Wildner } 4080d02842fSSascha Wildner } 4090d02842fSSascha Wildner 4105f39c7e7SSascha Wildner if (Gbl_OutputFilename) 4110d02842fSSascha Wildner { 4120d02842fSSascha Wildner if (Gbl_VerboseMode) 4130d02842fSSascha Wildner { 4140d02842fSSascha Wildner /* Summary for the output file */ 4150d02842fSSascha Wildner 416d4972a9cSSascha Wildner FileSize = CmGetFileSize (Gbl_OutputFile); 4175f39c7e7SSascha Wildner AcpiLogError ("Output file %s contains 0x%X (%u) bytes\n\n", 4180d02842fSSascha Wildner Gbl_OutputFilename, FileSize, FileSize); 4190d02842fSSascha Wildner } 4200d02842fSSascha Wildner 4215f39c7e7SSascha Wildner AcpiOsCloseFile (Gbl_OutputFile); 4220d02842fSSascha Wildner } 4230d02842fSSascha Wildner 4240d02842fSSascha Wildner return (Status); 4250d02842fSSascha Wildner } 426