1 /******************************************************************************* 2 * 3 * Module Name: utnonansi - Non-ansi C library functions 4 * 5 ******************************************************************************/ 6 7 /* 8 * Copyright (C) 2000 - 2019, 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 "acpi.h" 45 #include "accommon.h" 46 47 48 #define _COMPONENT ACPI_UTILITIES 49 ACPI_MODULE_NAME ("utnonansi") 50 51 /* 52 * Non-ANSI C library functions - strlwr, strupr, stricmp, and "safe" 53 * string functions. 54 */ 55 56 /******************************************************************************* 57 * 58 * FUNCTION: AcpiUtStrlwr (strlwr) 59 * 60 * PARAMETERS: SrcString - The source string to convert 61 * 62 * RETURN: None 63 * 64 * DESCRIPTION: Convert a string to lowercase 65 * 66 ******************************************************************************/ 67 68 void 69 AcpiUtStrlwr ( 70 char *SrcString) 71 { 72 char *String; 73 74 75 ACPI_FUNCTION_ENTRY (); 76 77 78 if (!SrcString) 79 { 80 return; 81 } 82 83 /* Walk entire string, lowercasing the letters */ 84 85 for (String = SrcString; *String; String++) 86 { 87 *String = (char) tolower ((int) *String); 88 } 89 } 90 91 92 /******************************************************************************* 93 * 94 * FUNCTION: AcpiUtStrupr (strupr) 95 * 96 * PARAMETERS: SrcString - The source string to convert 97 * 98 * RETURN: None 99 * 100 * DESCRIPTION: Convert a string to uppercase 101 * 102 ******************************************************************************/ 103 104 void 105 AcpiUtStrupr ( 106 char *SrcString) 107 { 108 char *String; 109 110 111 ACPI_FUNCTION_ENTRY (); 112 113 114 if (!SrcString) 115 { 116 return; 117 } 118 119 /* Walk entire string, uppercasing the letters */ 120 121 for (String = SrcString; *String; String++) 122 { 123 *String = (char) toupper ((int) *String); 124 } 125 } 126 127 128 /****************************************************************************** 129 * 130 * FUNCTION: AcpiUtStricmp (stricmp) 131 * 132 * PARAMETERS: String1 - first string to compare 133 * String2 - second string to compare 134 * 135 * RETURN: int that signifies string relationship. Zero means strings 136 * are equal. 137 * 138 * DESCRIPTION: Case-insensitive string compare. Implementation of the 139 * non-ANSI stricmp function. 140 * 141 ******************************************************************************/ 142 143 int 144 AcpiUtStricmp ( 145 char *String1, 146 char *String2) 147 { 148 int c1; 149 int c2; 150 151 152 do 153 { 154 c1 = tolower ((int) *String1); 155 c2 = tolower ((int) *String2); 156 157 String1++; 158 String2++; 159 } 160 while ((c1 == c2) && (c1)); 161 162 return (c1 - c2); 163 } 164 165 166 #if defined (ACPI_DEBUGGER) || defined (ACPI_APPLICATION) || defined (ACPI_DEBUG_OUTPUT) 167 /******************************************************************************* 168 * 169 * FUNCTION: AcpiUtSafeStrcpy, AcpiUtSafeStrcat, AcpiUtSafeStrncat 170 * 171 * PARAMETERS: Adds a "DestSize" parameter to each of the standard string 172 * functions. This is the size of the Destination buffer. 173 * 174 * RETURN: TRUE if the operation would overflow the destination buffer. 175 * 176 * DESCRIPTION: Safe versions of standard Clib string functions. Ensure that 177 * the result of the operation will not overflow the output string 178 * buffer. 179 * 180 * NOTE: These functions are typically only helpful for processing 181 * user input and command lines. For most ACPICA code, the 182 * required buffer length is precisely calculated before buffer 183 * allocation, so the use of these functions is unnecessary. 184 * 185 ******************************************************************************/ 186 187 BOOLEAN 188 AcpiUtSafeStrcpy ( 189 char *Dest, 190 ACPI_SIZE DestSize, 191 char *Source) 192 { 193 194 if (strlen (Source) >= DestSize) 195 { 196 return (TRUE); 197 } 198 199 strcpy (Dest, Source); 200 return (FALSE); 201 } 202 203 BOOLEAN 204 AcpiUtSafeStrcat ( 205 char *Dest, 206 ACPI_SIZE DestSize, 207 char *Source) 208 { 209 210 if ((strlen (Dest) + strlen (Source)) >= DestSize) 211 { 212 return (TRUE); 213 } 214 215 strcat (Dest, Source); 216 return (FALSE); 217 } 218 219 BOOLEAN 220 AcpiUtSafeStrncat ( 221 char *Dest, 222 ACPI_SIZE DestSize, 223 char *Source, 224 ACPI_SIZE MaxTransferLength) 225 { 226 ACPI_SIZE ActualTransferLength; 227 228 229 ActualTransferLength = ACPI_MIN (MaxTransferLength, strlen (Source)); 230 231 if ((strlen (Dest) + ActualTransferLength) >= DestSize) 232 { 233 return (TRUE); 234 } 235 236 strncat (Dest, Source, MaxTransferLength); 237 return (FALSE); 238 } 239 240 void 241 AcpiUtSafeStrncpy ( 242 char *Dest, 243 char *Source, 244 ACPI_SIZE DestSize) 245 { 246 /* Always terminate destination string */ 247 248 strncpy (Dest, Source, DestSize); 249 Dest[DestSize - 1] = 0; 250 } 251 252 #endif 253