diff options
-rw-r--r-- | usr.sbin/acpidump/acpi.c | 6 | ||||
-rw-r--r-- | usr.sbin/acpidump/aml_dump.c | 20 |
2 files changed, 17 insertions, 9 deletions
diff --git a/usr.sbin/acpidump/acpi.c b/usr.sbin/acpidump/acpi.c index d350444372a..390c649c21f 100644 --- a/usr.sbin/acpidump/acpi.c +++ b/usr.sbin/acpidump/acpi.c @@ -1,4 +1,4 @@ -/* $OpenBSD: acpi.c,v 1.3 2005/07/21 16:38:55 fgsch Exp $ */ +/* $OpenBSD: acpi.c,v 1.4 2007/02/22 19:09:26 jordan Exp $ */ /*- * Copyright (c) 1998 Doug Rabson * Copyright (c) 2000 Mitsuru IWASAKI <iwasaki@FreeBSD.org> @@ -25,7 +25,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: acpi.c,v 1.3 2005/07/21 16:38:55 fgsch Exp $ + * $Id: acpi.c,v 1.4 2007/02/22 19:09:26 jordan Exp $ * $FreeBSD: src/usr.sbin/acpi/acpidump/acpi.c,v 1.3 2000/11/08 02:37:00 iwasaki Exp $ */ #include <sys/types.h> @@ -343,12 +343,14 @@ acpi_handle_rsdt(struct ACPIsdt *rsdp) int entries; struct ACPIsdt *sdp; + aml_dump(rsdp); entries = (rsdp->len - SIZEOF_SDT_HDR) / sizeof(u_int32_t); acpi_print_rsdt(rsdp); for (i = 0; i < entries; i++) { sdp = (struct ACPIsdt *) acpi_map_sdt(rsdp->body[i]); if (acpi_checksum(sdp, sdp->len)) errx(1, "RSDT entry %d is corrupt", i); + aml_dump(sdp); if (!memcmp(sdp->signature, "FACP", 4)) { acpi_handle_facp((struct FACPbody *) sdp->body); } else { diff --git a/usr.sbin/acpidump/aml_dump.c b/usr.sbin/acpidump/aml_dump.c index 11acc4858e1..b18e957261d 100644 --- a/usr.sbin/acpidump/aml_dump.c +++ b/usr.sbin/acpidump/aml_dump.c @@ -1,4 +1,4 @@ -/* $OpenBSD: aml_dump.c,v 1.1 2005/06/02 20:09:39 tholo Exp $ */ +/* $OpenBSD: aml_dump.c,v 1.2 2007/02/22 19:09:26 jordan Exp $ */ /*- * Copyright (c) 2000 Mitsuru IWASAKI <iwasaki@FreeBSD.org> * All rights reserved. @@ -24,7 +24,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: aml_dump.c,v 1.1 2005/06/02 20:09:39 tholo Exp $ + * $Id: aml_dump.c,v 1.2 2007/02/22 19:09:26 jordan Exp $ * $FreeBSD: src/usr.sbin/acpi/acpidump/aml_dump.c,v 1.3 2000/11/08 02:37:00 iwasaki Exp $ */ @@ -40,8 +40,10 @@ char *aml_dumpfile = NULL; void -aml_dump(struct ACPIsdt *dsdp) +aml_dump(struct ACPIsdt *hdr) { + static int hdr_index; + char name[128]; int fd; mode_t mode; @@ -49,13 +51,17 @@ aml_dump(struct ACPIsdt *dsdp) return; } + snprintf(name, sizeof(name), "%s.%c%c%c%c.%d", + aml_dumpfile, hdr->signature[0], hdr->signature[1], + hdr->signature[2], hdr->signature[3], + hdr_index++); + mode = (S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH); - fd = open(aml_dumpfile, O_WRONLY | O_CREAT | O_TRUNC, mode); + fd = open(name, O_WRONLY | O_CREAT | O_TRUNC, mode); if (fd == -1) { return; } - write(fd, dsdp, SIZEOF_SDT_HDR); - write(fd, dsdp->body, dsdp->len - SIZEOF_SDT_HDR); + write(fd, hdr, SIZEOF_SDT_HDR); + write(fd, hdr->body, hdr->len - SIZEOF_SDT_HDR); close(fd); } - |