From e55eb97f4a6c4ce77d0884aaf1adcb0b29e240bf Mon Sep 17 00:00:00 2001 From: Stefan Reinauer Date: Sat, 4 Dec 2010 20:50:39 +0000 Subject: ACPI table dumping wrapper script Signed-off-by: Stefan Reinauer Acked-by: Stefan Reinauer git-svn-id: svn://svn.coreboot.org/coreboot/trunk@6139 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1 --- util/acpi/acpidump-all | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100755 util/acpi/acpidump-all diff --git a/util/acpi/acpidump-all b/util/acpi/acpidump-all new file mode 100755 index 0000000000..fe10e9d1e6 --- /dev/null +++ b/util/acpi/acpidump-all @@ -0,0 +1,50 @@ +#!/bin/bash +# +# Copyright (C) 2007-2010 by coresystems GmbH +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; version 2 of the License. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA +# + +rm -rf out +mkdir out + +# walk through all ACPI tables with their addresses +# example: +# RSDT @ 0xcf6794ba +# we can not just dump the tables by their names because some +# machines have double ACPI tables + +acpidump | grep "@ 0x" | while read line +do + NAME=$( echo `echo $line|cut -f1 -d@` ) + FNAME=$( echo $NAME | sed s/\ /_/g |sed s/\!/b/g ) + ADDR=$( echo `echo $line|cut -f2 -d@` ) + if [ "${!FNAME}" == "" ]; then + eval $FNAME=0 + else + eval $FNAME=$(( ${!FNAME} + 1 )) + fi + printf "Processing table \"$NAME\" at $ADDR ... " + printf "${!FNAME} tables of that kind found before.\n" + + # acpidump -s ${!FNAME} --table "$NAME" > out/$FNAME-$ADDR-${!FNAME}.txt + acpidump -b -s ${!FNAME} --table "$NAME" > out/$FNAME-$ADDR-${!FNAME}.bin + if [ "`file -b out/$FNAME-$ADDR-${!FNAME}.bin`" != "ASCII text" ]; then + iasl -d out/$FNAME-$ADDR-${!FNAME}.bin &>/dev/null + else + printf "Skipping $NAME because it was not dumped correctly.\n\n" + fi + +done + -- cgit v1.2.3