diff options
author | njl <njl@FreeBSD.org> | 2003-12-09 02:45:16 +0000 |
---|---|---|
committer | njl <njl@FreeBSD.org> | 2003-12-09 02:45:16 +0000 |
commit | 2a9caa496cc3521e5c9352c255b827c90efb3839 (patch) | |
tree | 24e5ad5d8b4fb5681ddaa34c6ae30814c80ffe56 /sys/contrib/dev/acpica/common | |
parent | dc49a5b908c59c6ae7c8b069908225dd6c21c041 (diff) | |
download | FreeBSD-src-2a9caa496cc3521e5c9352c255b827c90efb3839.zip FreeBSD-src-2a9caa496cc3521e5c9352c255b827c90efb3839.tar.gz |
Import ACPI-CA 20031203
Diffstat (limited to 'sys/contrib/dev/acpica/common')
-rw-r--r-- | sys/contrib/dev/acpica/common/adisasm.c | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/sys/contrib/dev/acpica/common/adisasm.c b/sys/contrib/dev/acpica/common/adisasm.c index a13baf8..e54480e 100644 --- a/sys/contrib/dev/acpica/common/adisasm.c +++ b/sys/contrib/dev/acpica/common/adisasm.c @@ -1,7 +1,7 @@ /****************************************************************************** * * Module Name: adisasm - Application-level disassembler routines - * $Revision: 58 $ + * $Revision: 63 $ * *****************************************************************************/ @@ -521,12 +521,16 @@ AdAmlDisassemble ( if (!OutFilename) { fprintf (stderr, "Could not generate output filename\n"); + Status = AE_ERROR; + goto Cleanup; } File = fopen (DisasmFilename, "w+"); if (!File) { fprintf (stderr, "Could not open output file\n"); + Status = AE_ERROR; + goto Cleanup; } AcpiOsRedirectOutput (File); @@ -560,7 +564,7 @@ Cleanup: } AcpiPsDeleteParseTree (AcpiGbl_ParsedNamespaceRoot); - return AE_OK; + return Status; } @@ -593,7 +597,7 @@ AdCreateTableHeader ( AcpiOsPrintf (" *\n * Disassembly of %s, %s */\n", Filename, ctime (&Timer)); AcpiOsPrintf ( - "DefinitionBlock (\"%4.4s.aml\", \"%4.4s\", %hd, \"%.6s\", \"%.8s\", %d)\n", + "DefinitionBlock (\"%4.4s.aml\", \"%4.4s\", %hd, \"%.6s\", \"%.8s\", %u)\n", Table->Signature, Table->Signature, Table->Revision, Table->OemId, Table->OemTableId, Table->OemRevision); } @@ -869,12 +873,17 @@ AdGetLocalTables ( if (GetAllTables) { - ACPI_STRNCPY (TableHeader.Signature, "RSDT", 4); + ACPI_STRNCPY (TableHeader.Signature, RSDT_SIG, 4); AcpiOsTableOverride (&TableHeader, &NewTable); + if (!NewTable) + { + fprintf (stderr, "Could not obtain RSDT\n"); + return AE_NO_ACPI_TABLES; + } #if ACPI_MACHINE_WIDTH != 64 - if (!ACPI_STRNCMP (NewTable->Signature, "RSDT", 4)) + if (!ACPI_STRNCMP (NewTable->Signature, RSDT_SIG, 4)) { PointerSize = sizeof (UINT32); } @@ -896,25 +905,25 @@ AdGetLocalTables ( /* Get the FADT */ - ACPI_STRNCPY (TableHeader.Signature, "FADT", 4); + ACPI_STRNCPY (TableHeader.Signature, FADT_SIG, 4); AcpiOsTableOverride (&TableHeader, &NewTable); if (NewTable) { AcpiGbl_FADT = (void *) NewTable; AdWriteTable (NewTable, NewTable->Length, - "FADT", NewTable->OemTableId); + FADT_SIG, NewTable->OemTableId); } AcpiOsPrintf ("\n"); /* Get the FACS */ - ACPI_STRNCPY (TableHeader.Signature, "FACS", 4); + ACPI_STRNCPY (TableHeader.Signature, FACS_SIG, 4); AcpiOsTableOverride (&TableHeader, &NewTable); if (NewTable) { AcpiGbl_FACS = (void *) NewTable; AdWriteTable (NewTable, AcpiGbl_FACS->Length, - "FACS", AcpiGbl_FADT->Header.OemTableId); + FACS_SIG, AcpiGbl_FADT->OemTableId); } AcpiOsPrintf ("\n"); } @@ -933,7 +942,7 @@ AdGetLocalTables ( else { fprintf (stderr, "Could not obtain DSDT\n"); - Status = AE_NO_ACPI_TABLES; + return AE_NO_ACPI_TABLES; } AcpiOsPrintf ("\n"); |