1 /****************************************************************************** 2 * 3 * Module Name: dbhistry - debugger HISTORY command 4 * 5 *****************************************************************************/ 6 7 /* 8 * Copyright (C) 2000 - 2017, 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 #include <contrib/dev/acpica/include/acpi.h> 45 #include <contrib/dev/acpica/include/accommon.h> 46 #include <contrib/dev/acpica/include/acdebug.h> 47 48 49 #define _COMPONENT ACPI_CA_DEBUGGER 50 ACPI_MODULE_NAME ("dbhistry") 51 52 53 #define HI_NO_HISTORY 0 54 #define HI_RECORD_HISTORY 1 55 #define HISTORY_SIZE 40 56 57 58 typedef struct HistoryInfo 59 { 60 char *Command; 61 UINT32 CmdNum; 62 63 } HISTORY_INFO; 64 65 66 static HISTORY_INFO AcpiGbl_HistoryBuffer[HISTORY_SIZE]; 67 static UINT16 AcpiGbl_LoHistory = 0; 68 static UINT16 AcpiGbl_NumHistory = 0; 69 static UINT16 AcpiGbl_NextHistoryIndex = 0; 70 UINT32 AcpiGbl_NextCmdNum = 1; 71 72 73 /******************************************************************************* 74 * 75 * FUNCTION: AcpiDbAddToHistory 76 * 77 * PARAMETERS: CommandLine - Command to add 78 * 79 * RETURN: None 80 * 81 * DESCRIPTION: Add a command line to the history buffer. 82 * 83 ******************************************************************************/ 84 85 void 86 AcpiDbAddToHistory ( 87 char *CommandLine) 88 { 89 UINT16 CmdLen; 90 UINT16 BufferLen; 91 92 /* Put command into the next available slot */ 93 94 CmdLen = (UINT16) strlen (CommandLine); 95 if (!CmdLen) 96 { 97 return; 98 } 99 100 if (AcpiGbl_HistoryBuffer[AcpiGbl_NextHistoryIndex].Command != NULL) 101 { 102 BufferLen = (UINT16) strlen ( 103 AcpiGbl_HistoryBuffer[AcpiGbl_NextHistoryIndex].Command); 104 105 if (CmdLen > BufferLen) 106 { 107 AcpiOsFree (AcpiGbl_HistoryBuffer[AcpiGbl_NextHistoryIndex]. 108 Command); 109 AcpiGbl_HistoryBuffer[AcpiGbl_NextHistoryIndex].Command = 110 AcpiOsAllocate (CmdLen + 1); 111 } 112 } 113 else 114 { 115 AcpiGbl_HistoryBuffer[AcpiGbl_NextHistoryIndex].Command = 116 AcpiOsAllocate (CmdLen + 1); 117 } 118 119 strcpy (AcpiGbl_HistoryBuffer[AcpiGbl_NextHistoryIndex].Command, 120 CommandLine); 121 122 AcpiGbl_HistoryBuffer[AcpiGbl_NextHistoryIndex].CmdNum = 123 AcpiGbl_NextCmdNum; 124 125 /* Adjust indexes */ 126 127 if ((AcpiGbl_NumHistory == HISTORY_SIZE) && 128 (AcpiGbl_NextHistoryIndex == AcpiGbl_LoHistory)) 129 { 130 AcpiGbl_LoHistory++; 131 if (AcpiGbl_LoHistory >= HISTORY_SIZE) 132 { 133 AcpiGbl_LoHistory = 0; 134 } 135 } 136 137 AcpiGbl_NextHistoryIndex++; 138 if (AcpiGbl_NextHistoryIndex >= HISTORY_SIZE) 139 { 140 AcpiGbl_NextHistoryIndex = 0; 141 } 142 143 AcpiGbl_NextCmdNum++; 144 if (AcpiGbl_NumHistory < HISTORY_SIZE) 145 { 146 AcpiGbl_NumHistory++; 147 } 148 } 149 150 151 /******************************************************************************* 152 * 153 * FUNCTION: AcpiDbDisplayHistory 154 * 155 * PARAMETERS: None 156 * 157 * RETURN: None 158 * 159 * DESCRIPTION: Display the contents of the history buffer 160 * 161 ******************************************************************************/ 162 163 void 164 AcpiDbDisplayHistory ( 165 void) 166 { 167 UINT32 i; 168 UINT16 HistoryIndex; 169 170 171 HistoryIndex = AcpiGbl_LoHistory; 172 173 /* Dump entire history buffer */ 174 175 for (i = 0; i < AcpiGbl_NumHistory; i++) 176 { 177 if (AcpiGbl_HistoryBuffer[HistoryIndex].Command) 178 { 179 AcpiOsPrintf ("%3ld %s\n", 180 AcpiGbl_HistoryBuffer[HistoryIndex].CmdNum, 181 AcpiGbl_HistoryBuffer[HistoryIndex].Command); 182 } 183 184 HistoryIndex++; 185 if (HistoryIndex >= HISTORY_SIZE) 186 { 187 HistoryIndex = 0; 188 } 189 } 190 } 191 192 193 /******************************************************************************* 194 * 195 * FUNCTION: AcpiDbGetFromHistory 196 * 197 * PARAMETERS: CommandNumArg - String containing the number of the 198 * command to be retrieved 199 * 200 * RETURN: Pointer to the retrieved command. Null on error. 201 * 202 * DESCRIPTION: Get a command from the history buffer 203 * 204 ******************************************************************************/ 205 206 char * 207 AcpiDbGetFromHistory ( 208 char *CommandNumArg) 209 { 210 UINT32 CmdNum; 211 212 213 if (CommandNumArg == NULL) 214 { 215 CmdNum = AcpiGbl_NextCmdNum - 1; 216 } 217 218 else 219 { 220 CmdNum = strtoul (CommandNumArg, NULL, 0); 221 } 222 223 return (AcpiDbGetHistoryByIndex (CmdNum)); 224 } 225 226 227 /******************************************************************************* 228 * 229 * FUNCTION: AcpiDbGetHistoryByIndex 230 * 231 * PARAMETERS: CmdNum - Index of the desired history entry. 232 * Values are 0...(AcpiGbl_NextCmdNum - 1) 233 * 234 * RETURN: Pointer to the retrieved command. Null on error. 235 * 236 * DESCRIPTION: Get a command from the history buffer 237 * 238 ******************************************************************************/ 239 240 char * 241 AcpiDbGetHistoryByIndex ( 242 UINT32 CmdNum) 243 { 244 UINT32 i; 245 UINT16 HistoryIndex; 246 247 248 /* Search history buffer */ 249 250 HistoryIndex = AcpiGbl_LoHistory; 251 for (i = 0; i < AcpiGbl_NumHistory; i++) 252 { 253 if (AcpiGbl_HistoryBuffer[HistoryIndex].CmdNum == CmdNum) 254 { 255 /* Found the command, return it */ 256 257 return (AcpiGbl_HistoryBuffer[HistoryIndex].Command); 258 } 259 260 /* History buffer is circular */ 261 262 HistoryIndex++; 263 if (HistoryIndex >= HISTORY_SIZE) 264 { 265 HistoryIndex = 0; 266 } 267 } 268 269 AcpiOsPrintf ("Invalid history number: %u\n", HistoryIndex); 270 return (NULL); 271 } 272