dbhistry.c revision 1.1.1.2 1 /******************************************************************************
2 *
3 * Module Name: dbhistry - debugger HISTORY command
4 *
5 *****************************************************************************/
6
7 /*
8 * Copyright (C) 2000 - 2011, Intel Corp.
9 * All rights reserved.
10 *
11 * Redistribution and use in source and binary forms, with or without
12 * modification, are permitted provided that the following conditions
13 * are met:
14 * 1. Redistributions of source code must retain the above copyright
15 * notice, this list of conditions, and the following disclaimer,
16 * without modification.
17 * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18 * substantially similar to the "NO WARRANTY" disclaimer below
19 * ("Disclaimer") and any redistribution must be conditioned upon
20 * including a substantially similar Disclaimer requirement for further
21 * binary redistribution.
22 * 3. Neither the names of the above-listed copyright holders nor the names
23 * of any contributors may be used to endorse or promote products derived
24 * from this software without specific prior written permission.
25 *
26 * Alternatively, this software may be distributed under the terms of the
27 * GNU General Public License ("GPL") version 2 as published by the Free
28 * Software Foundation.
29 *
30 * NO WARRANTY
31 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41 * POSSIBILITY OF SUCH DAMAGES.
42 */
43
44
45 #include "acpi.h"
46 #include "accommon.h"
47 #include "acdebug.h"
48
49 #ifdef ACPI_DEBUGGER
50
51 #define _COMPONENT ACPI_CA_DEBUGGER
52 ACPI_MODULE_NAME ("dbhistry")
53
54
55 #define HI_NO_HISTORY 0
56 #define HI_RECORD_HISTORY 1
57 #define HISTORY_SIZE 20
58
59
60 typedef struct HistoryInfo
61 {
62 char Command[80];
63 UINT32 CmdNum;
64
65 } HISTORY_INFO;
66
67
68 static HISTORY_INFO AcpiGbl_HistoryBuffer[HISTORY_SIZE];
69 static UINT16 AcpiGbl_LoHistory = 0;
70 static UINT16 AcpiGbl_NumHistory = 0;
71 static UINT16 AcpiGbl_NextHistoryIndex = 0;
72 static UINT32 AcpiGbl_NextCmdNum = 1;
73
74
75 /*******************************************************************************
76 *
77 * FUNCTION: AcpiDbAddToHistory
78 *
79 * PARAMETERS: CommandLine - Command to add
80 *
81 * RETURN: None
82 *
83 * DESCRIPTION: Add a command line to the history buffer.
84 *
85 ******************************************************************************/
86
87 void
88 AcpiDbAddToHistory (
89 char *CommandLine)
90 {
91
92 /* Put command into the next available slot */
93
94 ACPI_STRCPY (AcpiGbl_HistoryBuffer[AcpiGbl_NextHistoryIndex].Command,
95 CommandLine);
96
97 AcpiGbl_HistoryBuffer[AcpiGbl_NextHistoryIndex].CmdNum = AcpiGbl_NextCmdNum;
98
99 /* Adjust indexes */
100
101 if ((AcpiGbl_NumHistory == HISTORY_SIZE) &&
102 (AcpiGbl_NextHistoryIndex == AcpiGbl_LoHistory))
103 {
104 AcpiGbl_LoHistory++;
105 if (AcpiGbl_LoHistory >= HISTORY_SIZE)
106 {
107 AcpiGbl_LoHistory = 0;
108 }
109 }
110
111 AcpiGbl_NextHistoryIndex++;
112 if (AcpiGbl_NextHistoryIndex >= HISTORY_SIZE)
113 {
114 AcpiGbl_NextHistoryIndex = 0;
115 }
116
117 AcpiGbl_NextCmdNum++;
118 if (AcpiGbl_NumHistory < HISTORY_SIZE)
119 {
120 AcpiGbl_NumHistory++;
121 }
122 }
123
124
125 /*******************************************************************************
126 *
127 * FUNCTION: AcpiDbDisplayHistory
128 *
129 * PARAMETERS: None
130 *
131 * RETURN: None
132 *
133 * DESCRIPTION: Display the contents of the history buffer
134 *
135 ******************************************************************************/
136
137 void
138 AcpiDbDisplayHistory (
139 void)
140 {
141 UINT32 i;
142 UINT16 HistoryIndex;
143
144
145 HistoryIndex = AcpiGbl_LoHistory;
146
147 /* Dump entire history buffer */
148
149 for (i = 0; i < AcpiGbl_NumHistory; i++)
150 {
151 AcpiOsPrintf ("%ld %s\n", AcpiGbl_HistoryBuffer[HistoryIndex].CmdNum,
152 AcpiGbl_HistoryBuffer[HistoryIndex].Command);
153
154 HistoryIndex++;
155 if (HistoryIndex >= HISTORY_SIZE)
156 {
157 HistoryIndex = 0;
158 }
159 }
160 }
161
162
163 /*******************************************************************************
164 *
165 * FUNCTION: AcpiDbGetFromHistory
166 *
167 * PARAMETERS: CommandNumArg - String containing the number of the
168 * command to be retrieved
169 *
170 * RETURN: Pointer to the retrieved command. Null on error.
171 *
172 * DESCRIPTION: Get a command from the history buffer
173 *
174 ******************************************************************************/
175
176 char *
177 AcpiDbGetFromHistory (
178 char *CommandNumArg)
179 {
180 UINT32 i;
181 UINT16 HistoryIndex;
182 UINT32 CmdNum;
183
184
185 if (CommandNumArg == NULL)
186 {
187 CmdNum = AcpiGbl_NextCmdNum - 1;
188 }
189
190 else
191 {
192 CmdNum = ACPI_STRTOUL (CommandNumArg, NULL, 0);
193 }
194
195 /* Search history buffer */
196
197 HistoryIndex = AcpiGbl_LoHistory;
198 for (i = 0; i < AcpiGbl_NumHistory; i++)
199 {
200 if (AcpiGbl_HistoryBuffer[HistoryIndex].CmdNum == CmdNum)
201 {
202 /* Found the commnad, return it */
203
204 return (AcpiGbl_HistoryBuffer[HistoryIndex].Command);
205 }
206
207
208 HistoryIndex++;
209 if (HistoryIndex >= HISTORY_SIZE)
210 {
211 HistoryIndex = 0;
212 }
213 }
214
215 AcpiOsPrintf ("Invalid history number: %u\n", HistoryIndex);
216 return (NULL);
217 }
218
219 #endif /* ACPI_DEBUGGER */
220
221