xref: /minix3/minix/drivers/power/acpi/utilities/utbuffer.c (revision 29492bb71c7148a089a5afafa0c99409161218df)
1*29492bb7SDavid van Moolenbroek /******************************************************************************
2*29492bb7SDavid van Moolenbroek  *
3*29492bb7SDavid van Moolenbroek  * Module Name: utbuffer - Buffer dump routines
4*29492bb7SDavid van Moolenbroek  *
5*29492bb7SDavid van Moolenbroek  *****************************************************************************/
6*29492bb7SDavid van Moolenbroek 
7*29492bb7SDavid van Moolenbroek /*
8*29492bb7SDavid van Moolenbroek  * Copyright (C) 2000 - 2014, Intel Corp.
9*29492bb7SDavid van Moolenbroek  * All rights reserved.
10*29492bb7SDavid van Moolenbroek  *
11*29492bb7SDavid van Moolenbroek  * Redistribution and use in source and binary forms, with or without
12*29492bb7SDavid van Moolenbroek  * modification, are permitted provided that the following conditions
13*29492bb7SDavid van Moolenbroek  * are met:
14*29492bb7SDavid van Moolenbroek  * 1. Redistributions of source code must retain the above copyright
15*29492bb7SDavid van Moolenbroek  *    notice, this list of conditions, and the following disclaimer,
16*29492bb7SDavid van Moolenbroek  *    without modification.
17*29492bb7SDavid van Moolenbroek  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18*29492bb7SDavid van Moolenbroek  *    substantially similar to the "NO WARRANTY" disclaimer below
19*29492bb7SDavid van Moolenbroek  *    ("Disclaimer") and any redistribution must be conditioned upon
20*29492bb7SDavid van Moolenbroek  *    including a substantially similar Disclaimer requirement for further
21*29492bb7SDavid van Moolenbroek  *    binary redistribution.
22*29492bb7SDavid van Moolenbroek  * 3. Neither the names of the above-listed copyright holders nor the names
23*29492bb7SDavid van Moolenbroek  *    of any contributors may be used to endorse or promote products derived
24*29492bb7SDavid van Moolenbroek  *    from this software without specific prior written permission.
25*29492bb7SDavid van Moolenbroek  *
26*29492bb7SDavid van Moolenbroek  * Alternatively, this software may be distributed under the terms of the
27*29492bb7SDavid van Moolenbroek  * GNU General Public License ("GPL") version 2 as published by the Free
28*29492bb7SDavid van Moolenbroek  * Software Foundation.
29*29492bb7SDavid van Moolenbroek  *
30*29492bb7SDavid van Moolenbroek  * NO WARRANTY
31*29492bb7SDavid van Moolenbroek  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32*29492bb7SDavid van Moolenbroek  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33*29492bb7SDavid van Moolenbroek  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34*29492bb7SDavid van Moolenbroek  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35*29492bb7SDavid van Moolenbroek  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36*29492bb7SDavid van Moolenbroek  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37*29492bb7SDavid van Moolenbroek  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38*29492bb7SDavid van Moolenbroek  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39*29492bb7SDavid van Moolenbroek  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40*29492bb7SDavid van Moolenbroek  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41*29492bb7SDavid van Moolenbroek  * POSSIBILITY OF SUCH DAMAGES.
42*29492bb7SDavid van Moolenbroek  */
43*29492bb7SDavid van Moolenbroek 
44*29492bb7SDavid van Moolenbroek #include "acpi.h"
45*29492bb7SDavid van Moolenbroek #include "accommon.h"
46*29492bb7SDavid van Moolenbroek 
47*29492bb7SDavid van Moolenbroek #define _COMPONENT          ACPI_UTILITIES
48*29492bb7SDavid van Moolenbroek         ACPI_MODULE_NAME    ("utbuffer")
49*29492bb7SDavid van Moolenbroek 
50*29492bb7SDavid van Moolenbroek 
51*29492bb7SDavid van Moolenbroek /*******************************************************************************
52*29492bb7SDavid van Moolenbroek  *
53*29492bb7SDavid van Moolenbroek  * FUNCTION:    AcpiUtDumpBuffer
54*29492bb7SDavid van Moolenbroek  *
55*29492bb7SDavid van Moolenbroek  * PARAMETERS:  Buffer              - Buffer to dump
56*29492bb7SDavid van Moolenbroek  *              Count               - Amount to dump, in bytes
57*29492bb7SDavid van Moolenbroek  *              Display             - BYTE, WORD, DWORD, or QWORD display:
58*29492bb7SDavid van Moolenbroek  *                                      DB_BYTE_DISPLAY
59*29492bb7SDavid van Moolenbroek  *                                      DB_WORD_DISPLAY
60*29492bb7SDavid van Moolenbroek  *                                      DB_DWORD_DISPLAY
61*29492bb7SDavid van Moolenbroek  *                                      DB_QWORD_DISPLAY
62*29492bb7SDavid van Moolenbroek  *              BaseOffset          - Beginning buffer offset (display only)
63*29492bb7SDavid van Moolenbroek  *
64*29492bb7SDavid van Moolenbroek  * RETURN:      None
65*29492bb7SDavid van Moolenbroek  *
66*29492bb7SDavid van Moolenbroek  * DESCRIPTION: Generic dump buffer in both hex and ascii.
67*29492bb7SDavid van Moolenbroek  *
68*29492bb7SDavid van Moolenbroek  ******************************************************************************/
69*29492bb7SDavid van Moolenbroek 
70*29492bb7SDavid van Moolenbroek void
AcpiUtDumpBuffer(UINT8 * Buffer,UINT32 Count,UINT32 Display,UINT32 BaseOffset)71*29492bb7SDavid van Moolenbroek AcpiUtDumpBuffer (
72*29492bb7SDavid van Moolenbroek     UINT8                   *Buffer,
73*29492bb7SDavid van Moolenbroek     UINT32                  Count,
74*29492bb7SDavid van Moolenbroek     UINT32                  Display,
75*29492bb7SDavid van Moolenbroek     UINT32                  BaseOffset)
76*29492bb7SDavid van Moolenbroek {
77*29492bb7SDavid van Moolenbroek     UINT32                  i = 0;
78*29492bb7SDavid van Moolenbroek     UINT32                  j;
79*29492bb7SDavid van Moolenbroek     UINT32                  Temp32;
80*29492bb7SDavid van Moolenbroek     UINT8                   BufChar;
81*29492bb7SDavid van Moolenbroek 
82*29492bb7SDavid van Moolenbroek 
83*29492bb7SDavid van Moolenbroek     if (!Buffer)
84*29492bb7SDavid van Moolenbroek     {
85*29492bb7SDavid van Moolenbroek         AcpiOsPrintf ("Null Buffer Pointer in DumpBuffer!\n");
86*29492bb7SDavid van Moolenbroek         return;
87*29492bb7SDavid van Moolenbroek     }
88*29492bb7SDavid van Moolenbroek 
89*29492bb7SDavid van Moolenbroek     if ((Count < 4) || (Count & 0x01))
90*29492bb7SDavid van Moolenbroek     {
91*29492bb7SDavid van Moolenbroek         Display = DB_BYTE_DISPLAY;
92*29492bb7SDavid van Moolenbroek     }
93*29492bb7SDavid van Moolenbroek 
94*29492bb7SDavid van Moolenbroek     /* Nasty little dump buffer routine! */
95*29492bb7SDavid van Moolenbroek 
96*29492bb7SDavid van Moolenbroek     while (i < Count)
97*29492bb7SDavid van Moolenbroek     {
98*29492bb7SDavid van Moolenbroek         /* Print current offset */
99*29492bb7SDavid van Moolenbroek 
100*29492bb7SDavid van Moolenbroek         AcpiOsPrintf ("%6.4X: ", (BaseOffset + i));
101*29492bb7SDavid van Moolenbroek 
102*29492bb7SDavid van Moolenbroek         /* Print 16 hex chars */
103*29492bb7SDavid van Moolenbroek 
104*29492bb7SDavid van Moolenbroek         for (j = 0; j < 16;)
105*29492bb7SDavid van Moolenbroek         {
106*29492bb7SDavid van Moolenbroek             if (i + j >= Count)
107*29492bb7SDavid van Moolenbroek             {
108*29492bb7SDavid van Moolenbroek                 /* Dump fill spaces */
109*29492bb7SDavid van Moolenbroek 
110*29492bb7SDavid van Moolenbroek                 AcpiOsPrintf ("%*s", ((Display * 2) + 1), " ");
111*29492bb7SDavid van Moolenbroek                 j += Display;
112*29492bb7SDavid van Moolenbroek                 continue;
113*29492bb7SDavid van Moolenbroek             }
114*29492bb7SDavid van Moolenbroek 
115*29492bb7SDavid van Moolenbroek             switch (Display)
116*29492bb7SDavid van Moolenbroek             {
117*29492bb7SDavid van Moolenbroek             case DB_BYTE_DISPLAY:
118*29492bb7SDavid van Moolenbroek             default:    /* Default is BYTE display */
119*29492bb7SDavid van Moolenbroek 
120*29492bb7SDavid van Moolenbroek                 AcpiOsPrintf ("%02X ", Buffer[(ACPI_SIZE) i + j]);
121*29492bb7SDavid van Moolenbroek                 break;
122*29492bb7SDavid van Moolenbroek 
123*29492bb7SDavid van Moolenbroek             case DB_WORD_DISPLAY:
124*29492bb7SDavid van Moolenbroek 
125*29492bb7SDavid van Moolenbroek                 ACPI_MOVE_16_TO_32 (&Temp32, &Buffer[(ACPI_SIZE) i + j]);
126*29492bb7SDavid van Moolenbroek                 AcpiOsPrintf ("%04X ", Temp32);
127*29492bb7SDavid van Moolenbroek                 break;
128*29492bb7SDavid van Moolenbroek 
129*29492bb7SDavid van Moolenbroek             case DB_DWORD_DISPLAY:
130*29492bb7SDavid van Moolenbroek 
131*29492bb7SDavid van Moolenbroek                 ACPI_MOVE_32_TO_32 (&Temp32, &Buffer[(ACPI_SIZE) i + j]);
132*29492bb7SDavid van Moolenbroek                 AcpiOsPrintf ("%08X ", Temp32);
133*29492bb7SDavid van Moolenbroek                 break;
134*29492bb7SDavid van Moolenbroek 
135*29492bb7SDavid van Moolenbroek             case DB_QWORD_DISPLAY:
136*29492bb7SDavid van Moolenbroek 
137*29492bb7SDavid van Moolenbroek                 ACPI_MOVE_32_TO_32 (&Temp32, &Buffer[(ACPI_SIZE) i + j]);
138*29492bb7SDavid van Moolenbroek                 AcpiOsPrintf ("%08X", Temp32);
139*29492bb7SDavid van Moolenbroek 
140*29492bb7SDavid van Moolenbroek                 ACPI_MOVE_32_TO_32 (&Temp32, &Buffer[(ACPI_SIZE) i + j + 4]);
141*29492bb7SDavid van Moolenbroek                 AcpiOsPrintf ("%08X ", Temp32);
142*29492bb7SDavid van Moolenbroek                 break;
143*29492bb7SDavid van Moolenbroek             }
144*29492bb7SDavid van Moolenbroek 
145*29492bb7SDavid van Moolenbroek             j += Display;
146*29492bb7SDavid van Moolenbroek         }
147*29492bb7SDavid van Moolenbroek 
148*29492bb7SDavid van Moolenbroek         /*
149*29492bb7SDavid van Moolenbroek          * Print the ASCII equivalent characters but watch out for the bad
150*29492bb7SDavid van Moolenbroek          * unprintable ones (printable chars are 0x20 through 0x7E)
151*29492bb7SDavid van Moolenbroek          */
152*29492bb7SDavid van Moolenbroek         AcpiOsPrintf (" ");
153*29492bb7SDavid van Moolenbroek         for (j = 0; j < 16; j++)
154*29492bb7SDavid van Moolenbroek         {
155*29492bb7SDavid van Moolenbroek             if (i + j >= Count)
156*29492bb7SDavid van Moolenbroek             {
157*29492bb7SDavid van Moolenbroek                 AcpiOsPrintf ("\n");
158*29492bb7SDavid van Moolenbroek                 return;
159*29492bb7SDavid van Moolenbroek             }
160*29492bb7SDavid van Moolenbroek 
161*29492bb7SDavid van Moolenbroek             BufChar = Buffer[(ACPI_SIZE) i + j];
162*29492bb7SDavid van Moolenbroek             if (ACPI_IS_PRINT (BufChar))
163*29492bb7SDavid van Moolenbroek             {
164*29492bb7SDavid van Moolenbroek                 AcpiOsPrintf ("%c", BufChar);
165*29492bb7SDavid van Moolenbroek             }
166*29492bb7SDavid van Moolenbroek             else
167*29492bb7SDavid van Moolenbroek             {
168*29492bb7SDavid van Moolenbroek                 AcpiOsPrintf (".");
169*29492bb7SDavid van Moolenbroek             }
170*29492bb7SDavid van Moolenbroek         }
171*29492bb7SDavid van Moolenbroek 
172*29492bb7SDavid van Moolenbroek         /* Done with that line. */
173*29492bb7SDavid van Moolenbroek 
174*29492bb7SDavid van Moolenbroek         AcpiOsPrintf ("\n");
175*29492bb7SDavid van Moolenbroek         i += 16;
176*29492bb7SDavid van Moolenbroek     }
177*29492bb7SDavid van Moolenbroek 
178*29492bb7SDavid van Moolenbroek     return;
179*29492bb7SDavid van Moolenbroek }
180*29492bb7SDavid van Moolenbroek 
181*29492bb7SDavid van Moolenbroek 
182*29492bb7SDavid van Moolenbroek /*******************************************************************************
183*29492bb7SDavid van Moolenbroek  *
184*29492bb7SDavid van Moolenbroek  * FUNCTION:    AcpiUtDebugDumpBuffer
185*29492bb7SDavid van Moolenbroek  *
186*29492bb7SDavid van Moolenbroek  * PARAMETERS:  Buffer              - Buffer to dump
187*29492bb7SDavid van Moolenbroek  *              Count               - Amount to dump, in bytes
188*29492bb7SDavid van Moolenbroek  *              Display             - BYTE, WORD, DWORD, or QWORD display:
189*29492bb7SDavid van Moolenbroek  *                                      DB_BYTE_DISPLAY
190*29492bb7SDavid van Moolenbroek  *                                      DB_WORD_DISPLAY
191*29492bb7SDavid van Moolenbroek  *                                      DB_DWORD_DISPLAY
192*29492bb7SDavid van Moolenbroek  *                                      DB_QWORD_DISPLAY
193*29492bb7SDavid van Moolenbroek  *              ComponentID         - Caller's component ID
194*29492bb7SDavid van Moolenbroek  *
195*29492bb7SDavid van Moolenbroek  * RETURN:      None
196*29492bb7SDavid van Moolenbroek  *
197*29492bb7SDavid van Moolenbroek  * DESCRIPTION: Generic dump buffer in both hex and ascii.
198*29492bb7SDavid van Moolenbroek  *
199*29492bb7SDavid van Moolenbroek  ******************************************************************************/
200*29492bb7SDavid van Moolenbroek 
201*29492bb7SDavid van Moolenbroek void
AcpiUtDebugDumpBuffer(UINT8 * Buffer,UINT32 Count,UINT32 Display,UINT32 ComponentId)202*29492bb7SDavid van Moolenbroek AcpiUtDebugDumpBuffer (
203*29492bb7SDavid van Moolenbroek     UINT8                   *Buffer,
204*29492bb7SDavid van Moolenbroek     UINT32                  Count,
205*29492bb7SDavid van Moolenbroek     UINT32                  Display,
206*29492bb7SDavid van Moolenbroek     UINT32                  ComponentId)
207*29492bb7SDavid van Moolenbroek {
208*29492bb7SDavid van Moolenbroek 
209*29492bb7SDavid van Moolenbroek     /* Only dump the buffer if tracing is enabled */
210*29492bb7SDavid van Moolenbroek 
211*29492bb7SDavid van Moolenbroek     if (!((ACPI_LV_TABLES & AcpiDbgLevel) &&
212*29492bb7SDavid van Moolenbroek         (ComponentId & AcpiDbgLayer)))
213*29492bb7SDavid van Moolenbroek     {
214*29492bb7SDavid van Moolenbroek         return;
215*29492bb7SDavid van Moolenbroek     }
216*29492bb7SDavid van Moolenbroek 
217*29492bb7SDavid van Moolenbroek     AcpiUtDumpBuffer (Buffer, Count, Display, 0);
218*29492bb7SDavid van Moolenbroek }
219*29492bb7SDavid van Moolenbroek 
220*29492bb7SDavid van Moolenbroek 
221*29492bb7SDavid van Moolenbroek #ifdef ACPI_APPLICATION
222*29492bb7SDavid van Moolenbroek /*******************************************************************************
223*29492bb7SDavid van Moolenbroek  *
224*29492bb7SDavid van Moolenbroek  * FUNCTION:    AcpiUtDumpBufferToFile
225*29492bb7SDavid van Moolenbroek  *
226*29492bb7SDavid van Moolenbroek  * PARAMETERS:  File                - File descriptor
227*29492bb7SDavid van Moolenbroek  *              Buffer              - Buffer to dump
228*29492bb7SDavid van Moolenbroek  *              Count               - Amount to dump, in bytes
229*29492bb7SDavid van Moolenbroek  *              Display             - BYTE, WORD, DWORD, or QWORD display:
230*29492bb7SDavid van Moolenbroek  *                                      DB_BYTE_DISPLAY
231*29492bb7SDavid van Moolenbroek  *                                      DB_WORD_DISPLAY
232*29492bb7SDavid van Moolenbroek  *                                      DB_DWORD_DISPLAY
233*29492bb7SDavid van Moolenbroek  *                                      DB_QWORD_DISPLAY
234*29492bb7SDavid van Moolenbroek  *              BaseOffset          - Beginning buffer offset (display only)
235*29492bb7SDavid van Moolenbroek  *
236*29492bb7SDavid van Moolenbroek  * RETURN:      None
237*29492bb7SDavid van Moolenbroek  *
238*29492bb7SDavid van Moolenbroek  * DESCRIPTION: Generic dump buffer in both hex and ascii to a file.
239*29492bb7SDavid van Moolenbroek  *
240*29492bb7SDavid van Moolenbroek  ******************************************************************************/
241*29492bb7SDavid van Moolenbroek 
242*29492bb7SDavid van Moolenbroek void
AcpiUtDumpBufferToFile(ACPI_FILE File,UINT8 * Buffer,UINT32 Count,UINT32 Display,UINT32 BaseOffset)243*29492bb7SDavid van Moolenbroek AcpiUtDumpBufferToFile (
244*29492bb7SDavid van Moolenbroek     ACPI_FILE               File,
245*29492bb7SDavid van Moolenbroek     UINT8                   *Buffer,
246*29492bb7SDavid van Moolenbroek     UINT32                  Count,
247*29492bb7SDavid van Moolenbroek     UINT32                  Display,
248*29492bb7SDavid van Moolenbroek     UINT32                  BaseOffset)
249*29492bb7SDavid van Moolenbroek {
250*29492bb7SDavid van Moolenbroek     UINT32                  i = 0;
251*29492bb7SDavid van Moolenbroek     UINT32                  j;
252*29492bb7SDavid van Moolenbroek     UINT32                  Temp32;
253*29492bb7SDavid van Moolenbroek     UINT8                   BufChar;
254*29492bb7SDavid van Moolenbroek 
255*29492bb7SDavid van Moolenbroek 
256*29492bb7SDavid van Moolenbroek     if (!Buffer)
257*29492bb7SDavid van Moolenbroek     {
258*29492bb7SDavid van Moolenbroek         AcpiUtFilePrintf (File, "Null Buffer Pointer in DumpBuffer!\n");
259*29492bb7SDavid van Moolenbroek         return;
260*29492bb7SDavid van Moolenbroek     }
261*29492bb7SDavid van Moolenbroek 
262*29492bb7SDavid van Moolenbroek     if ((Count < 4) || (Count & 0x01))
263*29492bb7SDavid van Moolenbroek     {
264*29492bb7SDavid van Moolenbroek         Display = DB_BYTE_DISPLAY;
265*29492bb7SDavid van Moolenbroek     }
266*29492bb7SDavid van Moolenbroek 
267*29492bb7SDavid van Moolenbroek     /* Nasty little dump buffer routine! */
268*29492bb7SDavid van Moolenbroek 
269*29492bb7SDavid van Moolenbroek     while (i < Count)
270*29492bb7SDavid van Moolenbroek     {
271*29492bb7SDavid van Moolenbroek         /* Print current offset */
272*29492bb7SDavid van Moolenbroek 
273*29492bb7SDavid van Moolenbroek         AcpiUtFilePrintf (File, "%6.4X: ", (BaseOffset + i));
274*29492bb7SDavid van Moolenbroek 
275*29492bb7SDavid van Moolenbroek         /* Print 16 hex chars */
276*29492bb7SDavid van Moolenbroek 
277*29492bb7SDavid van Moolenbroek         for (j = 0; j < 16;)
278*29492bb7SDavid van Moolenbroek         {
279*29492bb7SDavid van Moolenbroek             if (i + j >= Count)
280*29492bb7SDavid van Moolenbroek             {
281*29492bb7SDavid van Moolenbroek                 /* Dump fill spaces */
282*29492bb7SDavid van Moolenbroek 
283*29492bb7SDavid van Moolenbroek                 AcpiUtFilePrintf (File, "%*s", ((Display * 2) + 1), " ");
284*29492bb7SDavid van Moolenbroek                 j += Display;
285*29492bb7SDavid van Moolenbroek                 continue;
286*29492bb7SDavid van Moolenbroek             }
287*29492bb7SDavid van Moolenbroek 
288*29492bb7SDavid van Moolenbroek             switch (Display)
289*29492bb7SDavid van Moolenbroek             {
290*29492bb7SDavid van Moolenbroek             case DB_BYTE_DISPLAY:
291*29492bb7SDavid van Moolenbroek             default:    /* Default is BYTE display */
292*29492bb7SDavid van Moolenbroek 
293*29492bb7SDavid van Moolenbroek                 AcpiUtFilePrintf (File, "%02X ", Buffer[(ACPI_SIZE) i + j]);
294*29492bb7SDavid van Moolenbroek                 break;
295*29492bb7SDavid van Moolenbroek 
296*29492bb7SDavid van Moolenbroek             case DB_WORD_DISPLAY:
297*29492bb7SDavid van Moolenbroek 
298*29492bb7SDavid van Moolenbroek                 ACPI_MOVE_16_TO_32 (&Temp32, &Buffer[(ACPI_SIZE) i + j]);
299*29492bb7SDavid van Moolenbroek                 AcpiUtFilePrintf (File, "%04X ", Temp32);
300*29492bb7SDavid van Moolenbroek                 break;
301*29492bb7SDavid van Moolenbroek 
302*29492bb7SDavid van Moolenbroek             case DB_DWORD_DISPLAY:
303*29492bb7SDavid van Moolenbroek 
304*29492bb7SDavid van Moolenbroek                 ACPI_MOVE_32_TO_32 (&Temp32, &Buffer[(ACPI_SIZE) i + j]);
305*29492bb7SDavid van Moolenbroek                 AcpiUtFilePrintf (File, "%08X ", Temp32);
306*29492bb7SDavid van Moolenbroek                 break;
307*29492bb7SDavid van Moolenbroek 
308*29492bb7SDavid van Moolenbroek             case DB_QWORD_DISPLAY:
309*29492bb7SDavid van Moolenbroek 
310*29492bb7SDavid van Moolenbroek                 ACPI_MOVE_32_TO_32 (&Temp32, &Buffer[(ACPI_SIZE) i + j]);
311*29492bb7SDavid van Moolenbroek                 AcpiUtFilePrintf (File, "%08X", Temp32);
312*29492bb7SDavid van Moolenbroek 
313*29492bb7SDavid van Moolenbroek                 ACPI_MOVE_32_TO_32 (&Temp32, &Buffer[(ACPI_SIZE) i + j + 4]);
314*29492bb7SDavid van Moolenbroek                 AcpiUtFilePrintf (File, "%08X ", Temp32);
315*29492bb7SDavid van Moolenbroek                 break;
316*29492bb7SDavid van Moolenbroek             }
317*29492bb7SDavid van Moolenbroek 
318*29492bb7SDavid van Moolenbroek             j += Display;
319*29492bb7SDavid van Moolenbroek         }
320*29492bb7SDavid van Moolenbroek 
321*29492bb7SDavid van Moolenbroek         /*
322*29492bb7SDavid van Moolenbroek          * Print the ASCII equivalent characters but watch out for the bad
323*29492bb7SDavid van Moolenbroek          * unprintable ones (printable chars are 0x20 through 0x7E)
324*29492bb7SDavid van Moolenbroek          */
325*29492bb7SDavid van Moolenbroek         AcpiUtFilePrintf (File, " ");
326*29492bb7SDavid van Moolenbroek         for (j = 0; j < 16; j++)
327*29492bb7SDavid van Moolenbroek         {
328*29492bb7SDavid van Moolenbroek             if (i + j >= Count)
329*29492bb7SDavid van Moolenbroek             {
330*29492bb7SDavid van Moolenbroek                 AcpiUtFilePrintf (File, "\n");
331*29492bb7SDavid van Moolenbroek                 return;
332*29492bb7SDavid van Moolenbroek             }
333*29492bb7SDavid van Moolenbroek 
334*29492bb7SDavid van Moolenbroek             BufChar = Buffer[(ACPI_SIZE) i + j];
335*29492bb7SDavid van Moolenbroek             if (ACPI_IS_PRINT (BufChar))
336*29492bb7SDavid van Moolenbroek             {
337*29492bb7SDavid van Moolenbroek                 AcpiUtFilePrintf (File, "%c", BufChar);
338*29492bb7SDavid van Moolenbroek             }
339*29492bb7SDavid van Moolenbroek             else
340*29492bb7SDavid van Moolenbroek             {
341*29492bb7SDavid van Moolenbroek                 AcpiUtFilePrintf (File, ".");
342*29492bb7SDavid van Moolenbroek             }
343*29492bb7SDavid van Moolenbroek         }
344*29492bb7SDavid van Moolenbroek 
345*29492bb7SDavid van Moolenbroek         /* Done with that line. */
346*29492bb7SDavid van Moolenbroek 
347*29492bb7SDavid van Moolenbroek         AcpiUtFilePrintf (File, "\n");
348*29492bb7SDavid van Moolenbroek         i += 16;
349*29492bb7SDavid van Moolenbroek     }
350*29492bb7SDavid van Moolenbroek 
351*29492bb7SDavid van Moolenbroek     return;
352*29492bb7SDavid van Moolenbroek }
353*29492bb7SDavid van Moolenbroek #endif
354