1*cb565728SJerry Jelinek /*******************************************************************************
2*cb565728SJerry Jelinek *
3*cb565728SJerry Jelinek * Module Name: utnonansi - Non-ansi C library functions
4*cb565728SJerry Jelinek *
5*cb565728SJerry Jelinek ******************************************************************************/
6*cb565728SJerry Jelinek
7*cb565728SJerry Jelinek /*
8*cb565728SJerry Jelinek * Copyright (C) 2000 - 2016, Intel Corp.
9*cb565728SJerry Jelinek * All rights reserved.
10*cb565728SJerry Jelinek *
11*cb565728SJerry Jelinek * Redistribution and use in source and binary forms, with or without
12*cb565728SJerry Jelinek * modification, are permitted provided that the following conditions
13*cb565728SJerry Jelinek * are met:
14*cb565728SJerry Jelinek * 1. Redistributions of source code must retain the above copyright
15*cb565728SJerry Jelinek * notice, this list of conditions, and the following disclaimer,
16*cb565728SJerry Jelinek * without modification.
17*cb565728SJerry Jelinek * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18*cb565728SJerry Jelinek * substantially similar to the "NO WARRANTY" disclaimer below
19*cb565728SJerry Jelinek * ("Disclaimer") and any redistribution must be conditioned upon
20*cb565728SJerry Jelinek * including a substantially similar Disclaimer requirement for further
21*cb565728SJerry Jelinek * binary redistribution.
22*cb565728SJerry Jelinek * 3. Neither the names of the above-listed copyright holders nor the names
23*cb565728SJerry Jelinek * of any contributors may be used to endorse or promote products derived
24*cb565728SJerry Jelinek * from this software without specific prior written permission.
25*cb565728SJerry Jelinek *
26*cb565728SJerry Jelinek * Alternatively, this software may be distributed under the terms of the
27*cb565728SJerry Jelinek * GNU General Public License ("GPL") version 2 as published by the Free
28*cb565728SJerry Jelinek * Software Foundation.
29*cb565728SJerry Jelinek *
30*cb565728SJerry Jelinek * NO WARRANTY
31*cb565728SJerry Jelinek * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32*cb565728SJerry Jelinek * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33*cb565728SJerry Jelinek * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34*cb565728SJerry Jelinek * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35*cb565728SJerry Jelinek * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36*cb565728SJerry Jelinek * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37*cb565728SJerry Jelinek * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38*cb565728SJerry Jelinek * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39*cb565728SJerry Jelinek * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40*cb565728SJerry Jelinek * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41*cb565728SJerry Jelinek * POSSIBILITY OF SUCH DAMAGES.
42*cb565728SJerry Jelinek */
43*cb565728SJerry Jelinek
44*cb565728SJerry Jelinek #include "acpi.h"
45*cb565728SJerry Jelinek #include "accommon.h"
46*cb565728SJerry Jelinek
47*cb565728SJerry Jelinek
48*cb565728SJerry Jelinek #define _COMPONENT ACPI_UTILITIES
49*cb565728SJerry Jelinek ACPI_MODULE_NAME ("utnonansi")
50*cb565728SJerry Jelinek
51*cb565728SJerry Jelinek
52*cb565728SJerry Jelinek /*
53*cb565728SJerry Jelinek * Non-ANSI C library functions - strlwr, strupr, stricmp, and a 64-bit
54*cb565728SJerry Jelinek * version of strtoul.
55*cb565728SJerry Jelinek */
56*cb565728SJerry Jelinek
57*cb565728SJerry Jelinek /*******************************************************************************
58*cb565728SJerry Jelinek *
59*cb565728SJerry Jelinek * FUNCTION: AcpiUtStrlwr (strlwr)
60*cb565728SJerry Jelinek *
61*cb565728SJerry Jelinek * PARAMETERS: SrcString - The source string to convert
62*cb565728SJerry Jelinek *
63*cb565728SJerry Jelinek * RETURN: None
64*cb565728SJerry Jelinek *
65*cb565728SJerry Jelinek * DESCRIPTION: Convert a string to lowercase
66*cb565728SJerry Jelinek *
67*cb565728SJerry Jelinek ******************************************************************************/
68*cb565728SJerry Jelinek
69*cb565728SJerry Jelinek void
AcpiUtStrlwr(char * SrcString)70*cb565728SJerry Jelinek AcpiUtStrlwr (
71*cb565728SJerry Jelinek char *SrcString)
72*cb565728SJerry Jelinek {
73*cb565728SJerry Jelinek char *String;
74*cb565728SJerry Jelinek
75*cb565728SJerry Jelinek
76*cb565728SJerry Jelinek ACPI_FUNCTION_ENTRY ();
77*cb565728SJerry Jelinek
78*cb565728SJerry Jelinek
79*cb565728SJerry Jelinek if (!SrcString)
80*cb565728SJerry Jelinek {
81*cb565728SJerry Jelinek return;
82*cb565728SJerry Jelinek }
83*cb565728SJerry Jelinek
84*cb565728SJerry Jelinek /* Walk entire string, lowercasing the letters */
85*cb565728SJerry Jelinek
86*cb565728SJerry Jelinek for (String = SrcString; *String; String++)
87*cb565728SJerry Jelinek {
88*cb565728SJerry Jelinek *String = (char) tolower ((int) *String);
89*cb565728SJerry Jelinek }
90*cb565728SJerry Jelinek }
91*cb565728SJerry Jelinek
92*cb565728SJerry Jelinek
93*cb565728SJerry Jelinek /*******************************************************************************
94*cb565728SJerry Jelinek *
95*cb565728SJerry Jelinek * FUNCTION: AcpiUtStrupr (strupr)
96*cb565728SJerry Jelinek *
97*cb565728SJerry Jelinek * PARAMETERS: SrcString - The source string to convert
98*cb565728SJerry Jelinek *
99*cb565728SJerry Jelinek * RETURN: None
100*cb565728SJerry Jelinek *
101*cb565728SJerry Jelinek * DESCRIPTION: Convert a string to uppercase
102*cb565728SJerry Jelinek *
103*cb565728SJerry Jelinek ******************************************************************************/
104*cb565728SJerry Jelinek
105*cb565728SJerry Jelinek void
AcpiUtStrupr(char * SrcString)106*cb565728SJerry Jelinek AcpiUtStrupr (
107*cb565728SJerry Jelinek char *SrcString)
108*cb565728SJerry Jelinek {
109*cb565728SJerry Jelinek char *String;
110*cb565728SJerry Jelinek
111*cb565728SJerry Jelinek
112*cb565728SJerry Jelinek ACPI_FUNCTION_ENTRY ();
113*cb565728SJerry Jelinek
114*cb565728SJerry Jelinek
115*cb565728SJerry Jelinek if (!SrcString)
116*cb565728SJerry Jelinek {
117*cb565728SJerry Jelinek return;
118*cb565728SJerry Jelinek }
119*cb565728SJerry Jelinek
120*cb565728SJerry Jelinek /* Walk entire string, uppercasing the letters */
121*cb565728SJerry Jelinek
122*cb565728SJerry Jelinek for (String = SrcString; *String; String++)
123*cb565728SJerry Jelinek {
124*cb565728SJerry Jelinek *String = (char) toupper ((int) *String);
125*cb565728SJerry Jelinek }
126*cb565728SJerry Jelinek }
127*cb565728SJerry Jelinek
128*cb565728SJerry Jelinek
129*cb565728SJerry Jelinek /******************************************************************************
130*cb565728SJerry Jelinek *
131*cb565728SJerry Jelinek * FUNCTION: AcpiUtStricmp (stricmp)
132*cb565728SJerry Jelinek *
133*cb565728SJerry Jelinek * PARAMETERS: String1 - first string to compare
134*cb565728SJerry Jelinek * String2 - second string to compare
135*cb565728SJerry Jelinek *
136*cb565728SJerry Jelinek * RETURN: int that signifies string relationship. Zero means strings
137*cb565728SJerry Jelinek * are equal.
138*cb565728SJerry Jelinek *
139*cb565728SJerry Jelinek * DESCRIPTION: Case-insensitive string compare. Implementation of the
140*cb565728SJerry Jelinek * non-ANSI stricmp function.
141*cb565728SJerry Jelinek *
142*cb565728SJerry Jelinek ******************************************************************************/
143*cb565728SJerry Jelinek
144*cb565728SJerry Jelinek int
AcpiUtStricmp(char * String1,char * String2)145*cb565728SJerry Jelinek AcpiUtStricmp (
146*cb565728SJerry Jelinek char *String1,
147*cb565728SJerry Jelinek char *String2)
148*cb565728SJerry Jelinek {
149*cb565728SJerry Jelinek int c1;
150*cb565728SJerry Jelinek int c2;
151*cb565728SJerry Jelinek
152*cb565728SJerry Jelinek
153*cb565728SJerry Jelinek do
154*cb565728SJerry Jelinek {
155*cb565728SJerry Jelinek c1 = tolower ((int) *String1);
156*cb565728SJerry Jelinek c2 = tolower ((int) *String2);
157*cb565728SJerry Jelinek
158*cb565728SJerry Jelinek String1++;
159*cb565728SJerry Jelinek String2++;
160*cb565728SJerry Jelinek }
161*cb565728SJerry Jelinek while ((c1 == c2) && (c1));
162*cb565728SJerry Jelinek
163*cb565728SJerry Jelinek return (c1 - c2);
164*cb565728SJerry Jelinek }
165*cb565728SJerry Jelinek
166*cb565728SJerry Jelinek
167*cb565728SJerry Jelinek #if defined (ACPI_DEBUGGER) || defined (ACPI_APPLICATION)
168*cb565728SJerry Jelinek /*******************************************************************************
169*cb565728SJerry Jelinek *
170*cb565728SJerry Jelinek * FUNCTION: AcpiUtSafeStrcpy, AcpiUtSafeStrcat, AcpiUtSafeStrncat
171*cb565728SJerry Jelinek *
172*cb565728SJerry Jelinek * PARAMETERS: Adds a "DestSize" parameter to each of the standard string
173*cb565728SJerry Jelinek * functions. This is the size of the Destination buffer.
174*cb565728SJerry Jelinek *
175*cb565728SJerry Jelinek * RETURN: TRUE if the operation would overflow the destination buffer.
176*cb565728SJerry Jelinek *
177*cb565728SJerry Jelinek * DESCRIPTION: Safe versions of standard Clib string functions. Ensure that
178*cb565728SJerry Jelinek * the result of the operation will not overflow the output string
179*cb565728SJerry Jelinek * buffer.
180*cb565728SJerry Jelinek *
181*cb565728SJerry Jelinek * NOTE: These functions are typically only helpful for processing
182*cb565728SJerry Jelinek * user input and command lines. For most ACPICA code, the
183*cb565728SJerry Jelinek * required buffer length is precisely calculated before buffer
184*cb565728SJerry Jelinek * allocation, so the use of these functions is unnecessary.
185*cb565728SJerry Jelinek *
186*cb565728SJerry Jelinek ******************************************************************************/
187*cb565728SJerry Jelinek
188*cb565728SJerry Jelinek BOOLEAN
AcpiUtSafeStrcpy(char * Dest,ACPI_SIZE DestSize,char * Source)189*cb565728SJerry Jelinek AcpiUtSafeStrcpy (
190*cb565728SJerry Jelinek char *Dest,
191*cb565728SJerry Jelinek ACPI_SIZE DestSize,
192*cb565728SJerry Jelinek char *Source)
193*cb565728SJerry Jelinek {
194*cb565728SJerry Jelinek
195*cb565728SJerry Jelinek if (strlen (Source) >= DestSize)
196*cb565728SJerry Jelinek {
197*cb565728SJerry Jelinek return (TRUE);
198*cb565728SJerry Jelinek }
199*cb565728SJerry Jelinek
200*cb565728SJerry Jelinek strcpy (Dest, Source);
201*cb565728SJerry Jelinek return (FALSE);
202*cb565728SJerry Jelinek }
203*cb565728SJerry Jelinek
204*cb565728SJerry Jelinek BOOLEAN
AcpiUtSafeStrcat(char * Dest,ACPI_SIZE DestSize,char * Source)205*cb565728SJerry Jelinek AcpiUtSafeStrcat (
206*cb565728SJerry Jelinek char *Dest,
207*cb565728SJerry Jelinek ACPI_SIZE DestSize,
208*cb565728SJerry Jelinek char *Source)
209*cb565728SJerry Jelinek {
210*cb565728SJerry Jelinek
211*cb565728SJerry Jelinek if ((strlen (Dest) + strlen (Source)) >= DestSize)
212*cb565728SJerry Jelinek {
213*cb565728SJerry Jelinek return (TRUE);
214*cb565728SJerry Jelinek }
215*cb565728SJerry Jelinek
216*cb565728SJerry Jelinek strcat (Dest, Source);
217*cb565728SJerry Jelinek return (FALSE);
218*cb565728SJerry Jelinek }
219*cb565728SJerry Jelinek
220*cb565728SJerry Jelinek BOOLEAN
AcpiUtSafeStrncat(char * Dest,ACPI_SIZE DestSize,char * Source,ACPI_SIZE MaxTransferLength)221*cb565728SJerry Jelinek AcpiUtSafeStrncat (
222*cb565728SJerry Jelinek char *Dest,
223*cb565728SJerry Jelinek ACPI_SIZE DestSize,
224*cb565728SJerry Jelinek char *Source,
225*cb565728SJerry Jelinek ACPI_SIZE MaxTransferLength)
226*cb565728SJerry Jelinek {
227*cb565728SJerry Jelinek ACPI_SIZE ActualTransferLength;
228*cb565728SJerry Jelinek
229*cb565728SJerry Jelinek
230*cb565728SJerry Jelinek ActualTransferLength = ACPI_MIN (MaxTransferLength, strlen (Source));
231*cb565728SJerry Jelinek
232*cb565728SJerry Jelinek if ((strlen (Dest) + ActualTransferLength) >= DestSize)
233*cb565728SJerry Jelinek {
234*cb565728SJerry Jelinek return (TRUE);
235*cb565728SJerry Jelinek }
236*cb565728SJerry Jelinek
237*cb565728SJerry Jelinek strncat (Dest, Source, MaxTransferLength);
238*cb565728SJerry Jelinek return (FALSE);
239*cb565728SJerry Jelinek }
240*cb565728SJerry Jelinek #endif
241*cb565728SJerry Jelinek
242*cb565728SJerry Jelinek
243*cb565728SJerry Jelinek /*******************************************************************************
244*cb565728SJerry Jelinek *
245*cb565728SJerry Jelinek * FUNCTION: AcpiUtStrtoul64
246*cb565728SJerry Jelinek *
247*cb565728SJerry Jelinek * PARAMETERS: String - Null terminated string
248*cb565728SJerry Jelinek * Base - Radix of the string: 16 or 10 or
249*cb565728SJerry Jelinek * ACPI_ANY_BASE
250*cb565728SJerry Jelinek * MaxIntegerByteWidth - Maximum allowable integer,in bytes:
251*cb565728SJerry Jelinek * 4 or 8 (32 or 64 bits)
252*cb565728SJerry Jelinek * RetInteger - Where the converted integer is
253*cb565728SJerry Jelinek * returned
254*cb565728SJerry Jelinek *
255*cb565728SJerry Jelinek * RETURN: Status and Converted value
256*cb565728SJerry Jelinek *
257*cb565728SJerry Jelinek * DESCRIPTION: Convert a string into an unsigned value. Performs either a
258*cb565728SJerry Jelinek * 32-bit or 64-bit conversion, depending on the input integer
259*cb565728SJerry Jelinek * size (often the current mode of the interpreter).
260*cb565728SJerry Jelinek *
261*cb565728SJerry Jelinek * NOTES: Negative numbers are not supported, as they are not supported
262*cb565728SJerry Jelinek * by ACPI.
263*cb565728SJerry Jelinek *
264*cb565728SJerry Jelinek * AcpiGbl_IntegerByteWidth should be set to the proper width.
265*cb565728SJerry Jelinek * For the core ACPICA code, this width depends on the DSDT
266*cb565728SJerry Jelinek * version. For iASL, the default byte width is always 8 for the
267*cb565728SJerry Jelinek * parser, but error checking is performed later to flag cases
268*cb565728SJerry Jelinek * where a 64-bit constant is defined in a 32-bit DSDT/SSDT.
269*cb565728SJerry Jelinek *
270*cb565728SJerry Jelinek * Does not support Octal strings, not needed at this time.
271*cb565728SJerry Jelinek *
272*cb565728SJerry Jelinek ******************************************************************************/
273*cb565728SJerry Jelinek
274*cb565728SJerry Jelinek ACPI_STATUS
AcpiUtStrtoul64(char * String,UINT32 Base,UINT32 MaxIntegerByteWidth,UINT64 * RetInteger)275*cb565728SJerry Jelinek AcpiUtStrtoul64 (
276*cb565728SJerry Jelinek char *String,
277*cb565728SJerry Jelinek UINT32 Base,
278*cb565728SJerry Jelinek UINT32 MaxIntegerByteWidth,
279*cb565728SJerry Jelinek UINT64 *RetInteger)
280*cb565728SJerry Jelinek {
281*cb565728SJerry Jelinek UINT32 ThisDigit = 0;
282*cb565728SJerry Jelinek UINT64 ReturnValue = 0;
283*cb565728SJerry Jelinek UINT64 Quotient;
284*cb565728SJerry Jelinek UINT64 Dividend;
285*cb565728SJerry Jelinek UINT8 ValidDigits = 0;
286*cb565728SJerry Jelinek UINT8 SignOf0x = 0;
287*cb565728SJerry Jelinek UINT8 Term = 0;
288*cb565728SJerry Jelinek
289*cb565728SJerry Jelinek
290*cb565728SJerry Jelinek ACPI_FUNCTION_TRACE_STR (UtStrtoul64, String);
291*cb565728SJerry Jelinek
292*cb565728SJerry Jelinek
293*cb565728SJerry Jelinek switch (Base)
294*cb565728SJerry Jelinek {
295*cb565728SJerry Jelinek case ACPI_ANY_BASE:
296*cb565728SJerry Jelinek case 10:
297*cb565728SJerry Jelinek case 16:
298*cb565728SJerry Jelinek
299*cb565728SJerry Jelinek break;
300*cb565728SJerry Jelinek
301*cb565728SJerry Jelinek default:
302*cb565728SJerry Jelinek
303*cb565728SJerry Jelinek /* Invalid Base */
304*cb565728SJerry Jelinek
305*cb565728SJerry Jelinek return_ACPI_STATUS (AE_BAD_PARAMETER);
306*cb565728SJerry Jelinek }
307*cb565728SJerry Jelinek
308*cb565728SJerry Jelinek if (!String)
309*cb565728SJerry Jelinek {
310*cb565728SJerry Jelinek goto ErrorExit;
311*cb565728SJerry Jelinek }
312*cb565728SJerry Jelinek
313*cb565728SJerry Jelinek /* Skip over any white space in the buffer */
314*cb565728SJerry Jelinek
315*cb565728SJerry Jelinek while ((*String) && (isspace ((int) *String) || *String == '\t'))
316*cb565728SJerry Jelinek {
317*cb565728SJerry Jelinek String++;
318*cb565728SJerry Jelinek }
319*cb565728SJerry Jelinek
320*cb565728SJerry Jelinek if (Base == ACPI_ANY_BASE)
321*cb565728SJerry Jelinek {
322*cb565728SJerry Jelinek /*
323*cb565728SJerry Jelinek * Base equal to ACPI_ANY_BASE means 'Either decimal or hex'.
324*cb565728SJerry Jelinek * We need to determine if it is decimal or hexadecimal.
325*cb565728SJerry Jelinek */
326*cb565728SJerry Jelinek if ((*String == '0') && (tolower ((int) *(String + 1)) == 'x'))
327*cb565728SJerry Jelinek {
328*cb565728SJerry Jelinek SignOf0x = 1;
329*cb565728SJerry Jelinek Base = 16;
330*cb565728SJerry Jelinek
331*cb565728SJerry Jelinek /* Skip over the leading '0x' */
332*cb565728SJerry Jelinek String += 2;
333*cb565728SJerry Jelinek }
334*cb565728SJerry Jelinek else
335*cb565728SJerry Jelinek {
336*cb565728SJerry Jelinek Base = 10;
337*cb565728SJerry Jelinek }
338*cb565728SJerry Jelinek }
339*cb565728SJerry Jelinek
340*cb565728SJerry Jelinek /* Any string left? Check that '0x' is not followed by white space. */
341*cb565728SJerry Jelinek
342*cb565728SJerry Jelinek if (!(*String) || isspace ((int) *String) || *String == '\t')
343*cb565728SJerry Jelinek {
344*cb565728SJerry Jelinek if (Base == ACPI_ANY_BASE)
345*cb565728SJerry Jelinek {
346*cb565728SJerry Jelinek goto ErrorExit;
347*cb565728SJerry Jelinek }
348*cb565728SJerry Jelinek else
349*cb565728SJerry Jelinek {
350*cb565728SJerry Jelinek goto AllDone;
351*cb565728SJerry Jelinek }
352*cb565728SJerry Jelinek }
353*cb565728SJerry Jelinek
354*cb565728SJerry Jelinek /*
355*cb565728SJerry Jelinek * Perform a 32-bit or 64-bit conversion, depending upon the input
356*cb565728SJerry Jelinek * byte width
357*cb565728SJerry Jelinek */
358*cb565728SJerry Jelinek Dividend = (MaxIntegerByteWidth <= ACPI_MAX32_BYTE_WIDTH) ?
359*cb565728SJerry Jelinek ACPI_UINT32_MAX : ACPI_UINT64_MAX;
360*cb565728SJerry Jelinek
361*cb565728SJerry Jelinek /* Main loop: convert the string to a 32- or 64-bit integer */
362*cb565728SJerry Jelinek
363*cb565728SJerry Jelinek while (*String)
364*cb565728SJerry Jelinek {
365*cb565728SJerry Jelinek if (isdigit ((int) *String))
366*cb565728SJerry Jelinek {
367*cb565728SJerry Jelinek /* Convert ASCII 0-9 to Decimal value */
368*cb565728SJerry Jelinek
369*cb565728SJerry Jelinek ThisDigit = ((UINT8) *String) - '0';
370*cb565728SJerry Jelinek }
371*cb565728SJerry Jelinek else if (Base == 10)
372*cb565728SJerry Jelinek {
373*cb565728SJerry Jelinek /* Digit is out of range; possible in ToInteger case only */
374*cb565728SJerry Jelinek
375*cb565728SJerry Jelinek Term = 1;
376*cb565728SJerry Jelinek }
377*cb565728SJerry Jelinek else
378*cb565728SJerry Jelinek {
379*cb565728SJerry Jelinek ThisDigit = (UINT8) toupper ((int) *String);
380*cb565728SJerry Jelinek if (isxdigit ((int) ThisDigit))
381*cb565728SJerry Jelinek {
382*cb565728SJerry Jelinek /* Convert ASCII Hex char to value */
383*cb565728SJerry Jelinek
384*cb565728SJerry Jelinek ThisDigit = ThisDigit - 'A' + 10;
385*cb565728SJerry Jelinek }
386*cb565728SJerry Jelinek else
387*cb565728SJerry Jelinek {
388*cb565728SJerry Jelinek Term = 1;
389*cb565728SJerry Jelinek }
390*cb565728SJerry Jelinek }
391*cb565728SJerry Jelinek
392*cb565728SJerry Jelinek if (Term)
393*cb565728SJerry Jelinek {
394*cb565728SJerry Jelinek if (Base == ACPI_ANY_BASE)
395*cb565728SJerry Jelinek {
396*cb565728SJerry Jelinek goto ErrorExit;
397*cb565728SJerry Jelinek }
398*cb565728SJerry Jelinek else
399*cb565728SJerry Jelinek {
400*cb565728SJerry Jelinek break;
401*cb565728SJerry Jelinek }
402*cb565728SJerry Jelinek }
403*cb565728SJerry Jelinek else if ((ValidDigits == 0) && (ThisDigit == 0) && !SignOf0x)
404*cb565728SJerry Jelinek {
405*cb565728SJerry Jelinek /* Skip zeros */
406*cb565728SJerry Jelinek String++;
407*cb565728SJerry Jelinek continue;
408*cb565728SJerry Jelinek }
409*cb565728SJerry Jelinek
410*cb565728SJerry Jelinek ValidDigits++;
411*cb565728SJerry Jelinek
412*cb565728SJerry Jelinek if (SignOf0x && ((ValidDigits > 16) ||
413*cb565728SJerry Jelinek ((ValidDigits > 8) && (MaxIntegerByteWidth <= ACPI_MAX32_BYTE_WIDTH))))
414*cb565728SJerry Jelinek {
415*cb565728SJerry Jelinek /*
416*cb565728SJerry Jelinek * This is ToInteger operation case.
417*cb565728SJerry Jelinek * No restrictions for string-to-integer conversion,
418*cb565728SJerry Jelinek * see ACPI spec.
419*cb565728SJerry Jelinek */
420*cb565728SJerry Jelinek goto ErrorExit;
421*cb565728SJerry Jelinek }
422*cb565728SJerry Jelinek
423*cb565728SJerry Jelinek /* Divide the digit into the correct position */
424*cb565728SJerry Jelinek
425*cb565728SJerry Jelinek (void) AcpiUtShortDivide (
426*cb565728SJerry Jelinek (Dividend - (UINT64) ThisDigit), Base, &Quotient, NULL);
427*cb565728SJerry Jelinek
428*cb565728SJerry Jelinek if (ReturnValue > Quotient)
429*cb565728SJerry Jelinek {
430*cb565728SJerry Jelinek if (Base == ACPI_ANY_BASE)
431*cb565728SJerry Jelinek {
432*cb565728SJerry Jelinek goto ErrorExit;
433*cb565728SJerry Jelinek }
434*cb565728SJerry Jelinek else
435*cb565728SJerry Jelinek {
436*cb565728SJerry Jelinek break;
437*cb565728SJerry Jelinek }
438*cb565728SJerry Jelinek }
439*cb565728SJerry Jelinek
440*cb565728SJerry Jelinek ReturnValue *= Base;
441*cb565728SJerry Jelinek ReturnValue += ThisDigit;
442*cb565728SJerry Jelinek String++;
443*cb565728SJerry Jelinek }
444*cb565728SJerry Jelinek
445*cb565728SJerry Jelinek /* All done, normal exit */
446*cb565728SJerry Jelinek
447*cb565728SJerry Jelinek AllDone:
448*cb565728SJerry Jelinek
449*cb565728SJerry Jelinek ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Converted value: %8.8X%8.8X\n",
450*cb565728SJerry Jelinek ACPI_FORMAT_UINT64 (ReturnValue)));
451*cb565728SJerry Jelinek
452*cb565728SJerry Jelinek *RetInteger = ReturnValue;
453*cb565728SJerry Jelinek return_ACPI_STATUS (AE_OK);
454*cb565728SJerry Jelinek
455*cb565728SJerry Jelinek
456*cb565728SJerry Jelinek ErrorExit:
457*cb565728SJerry Jelinek
458*cb565728SJerry Jelinek /* Base was set/validated above (10 or 16) */
459*cb565728SJerry Jelinek
460*cb565728SJerry Jelinek if (Base == 10)
461*cb565728SJerry Jelinek {
462*cb565728SJerry Jelinek return_ACPI_STATUS (AE_BAD_DECIMAL_CONSTANT);
463*cb565728SJerry Jelinek }
464*cb565728SJerry Jelinek else
465*cb565728SJerry Jelinek {
466*cb565728SJerry Jelinek return_ACPI_STATUS (AE_BAD_HEX_CONSTANT);
467*cb565728SJerry Jelinek }
468*cb565728SJerry Jelinek }
469*cb565728SJerry Jelinek
470*cb565728SJerry Jelinek
471*cb565728SJerry Jelinek #ifdef _OBSOLETE_FUNCTIONS
472*cb565728SJerry Jelinek /* Removed: 01/2016 */
473*cb565728SJerry Jelinek
474*cb565728SJerry Jelinek /*******************************************************************************
475*cb565728SJerry Jelinek *
476*cb565728SJerry Jelinek * FUNCTION: strtoul64
477*cb565728SJerry Jelinek *
478*cb565728SJerry Jelinek * PARAMETERS: String - Null terminated string
479*cb565728SJerry Jelinek * Terminater - Where a pointer to the terminating byte
480*cb565728SJerry Jelinek * is returned
481*cb565728SJerry Jelinek * Base - Radix of the string
482*cb565728SJerry Jelinek *
483*cb565728SJerry Jelinek * RETURN: Converted value
484*cb565728SJerry Jelinek *
485*cb565728SJerry Jelinek * DESCRIPTION: Convert a string into an unsigned value.
486*cb565728SJerry Jelinek *
487*cb565728SJerry Jelinek ******************************************************************************/
488*cb565728SJerry Jelinek
489*cb565728SJerry Jelinek ACPI_STATUS
strtoul64(char * String,UINT32 Base,UINT64 * RetInteger)490*cb565728SJerry Jelinek strtoul64 (
491*cb565728SJerry Jelinek char *String,
492*cb565728SJerry Jelinek UINT32 Base,
493*cb565728SJerry Jelinek UINT64 *RetInteger)
494*cb565728SJerry Jelinek {
495*cb565728SJerry Jelinek UINT32 Index;
496*cb565728SJerry Jelinek UINT32 Sign;
497*cb565728SJerry Jelinek UINT64 ReturnValue = 0;
498*cb565728SJerry Jelinek ACPI_STATUS Status = AE_OK;
499*cb565728SJerry Jelinek
500*cb565728SJerry Jelinek
501*cb565728SJerry Jelinek *RetInteger = 0;
502*cb565728SJerry Jelinek
503*cb565728SJerry Jelinek switch (Base)
504*cb565728SJerry Jelinek {
505*cb565728SJerry Jelinek case 0:
506*cb565728SJerry Jelinek case 8:
507*cb565728SJerry Jelinek case 10:
508*cb565728SJerry Jelinek case 16:
509*cb565728SJerry Jelinek
510*cb565728SJerry Jelinek break;
511*cb565728SJerry Jelinek
512*cb565728SJerry Jelinek default:
513*cb565728SJerry Jelinek /*
514*cb565728SJerry Jelinek * The specified Base parameter is not in the domain of
515*cb565728SJerry Jelinek * this function:
516*cb565728SJerry Jelinek */
517*cb565728SJerry Jelinek return (AE_BAD_PARAMETER);
518*cb565728SJerry Jelinek }
519*cb565728SJerry Jelinek
520*cb565728SJerry Jelinek /* Skip over any white space in the buffer: */
521*cb565728SJerry Jelinek
522*cb565728SJerry Jelinek while (isspace ((int) *String) || *String == '\t')
523*cb565728SJerry Jelinek {
524*cb565728SJerry Jelinek ++String;
525*cb565728SJerry Jelinek }
526*cb565728SJerry Jelinek
527*cb565728SJerry Jelinek /*
528*cb565728SJerry Jelinek * The buffer may contain an optional plus or minus sign.
529*cb565728SJerry Jelinek * If it does, then skip over it but remember what is was:
530*cb565728SJerry Jelinek */
531*cb565728SJerry Jelinek if (*String == '-')
532*cb565728SJerry Jelinek {
533*cb565728SJerry Jelinek Sign = ACPI_SIGN_NEGATIVE;
534*cb565728SJerry Jelinek ++String;
535*cb565728SJerry Jelinek }
536*cb565728SJerry Jelinek else if (*String == '+')
537*cb565728SJerry Jelinek {
538*cb565728SJerry Jelinek ++String;
539*cb565728SJerry Jelinek Sign = ACPI_SIGN_POSITIVE;
540*cb565728SJerry Jelinek }
541*cb565728SJerry Jelinek else
542*cb565728SJerry Jelinek {
543*cb565728SJerry Jelinek Sign = ACPI_SIGN_POSITIVE;
544*cb565728SJerry Jelinek }
545*cb565728SJerry Jelinek
546*cb565728SJerry Jelinek /*
547*cb565728SJerry Jelinek * If the input parameter Base is zero, then we need to
548*cb565728SJerry Jelinek * determine if it is octal, decimal, or hexadecimal:
549*cb565728SJerry Jelinek */
550*cb565728SJerry Jelinek if (Base == 0)
551*cb565728SJerry Jelinek {
552*cb565728SJerry Jelinek if (*String == '0')
553*cb565728SJerry Jelinek {
554*cb565728SJerry Jelinek if (tolower ((int) *(++String)) == 'x')
555*cb565728SJerry Jelinek {
556*cb565728SJerry Jelinek Base = 16;
557*cb565728SJerry Jelinek ++String;
558*cb565728SJerry Jelinek }
559*cb565728SJerry Jelinek else
560*cb565728SJerry Jelinek {
561*cb565728SJerry Jelinek Base = 8;
562*cb565728SJerry Jelinek }
563*cb565728SJerry Jelinek }
564*cb565728SJerry Jelinek else
565*cb565728SJerry Jelinek {
566*cb565728SJerry Jelinek Base = 10;
567*cb565728SJerry Jelinek }
568*cb565728SJerry Jelinek }
569*cb565728SJerry Jelinek
570*cb565728SJerry Jelinek /*
571*cb565728SJerry Jelinek * For octal and hexadecimal bases, skip over the leading
572*cb565728SJerry Jelinek * 0 or 0x, if they are present.
573*cb565728SJerry Jelinek */
574*cb565728SJerry Jelinek if (Base == 8 && *String == '0')
575*cb565728SJerry Jelinek {
576*cb565728SJerry Jelinek String++;
577*cb565728SJerry Jelinek }
578*cb565728SJerry Jelinek
579*cb565728SJerry Jelinek if (Base == 16 &&
580*cb565728SJerry Jelinek *String == '0' &&
581*cb565728SJerry Jelinek tolower ((int) *(++String)) == 'x')
582*cb565728SJerry Jelinek {
583*cb565728SJerry Jelinek String++;
584*cb565728SJerry Jelinek }
585*cb565728SJerry Jelinek
586*cb565728SJerry Jelinek /* Main loop: convert the string to an unsigned long */
587*cb565728SJerry Jelinek
588*cb565728SJerry Jelinek while (*String)
589*cb565728SJerry Jelinek {
590*cb565728SJerry Jelinek if (isdigit ((int) *String))
591*cb565728SJerry Jelinek {
592*cb565728SJerry Jelinek Index = ((UINT8) *String) - '0';
593*cb565728SJerry Jelinek }
594*cb565728SJerry Jelinek else
595*cb565728SJerry Jelinek {
596*cb565728SJerry Jelinek Index = (UINT8) toupper ((int) *String);
597*cb565728SJerry Jelinek if (isupper ((int) Index))
598*cb565728SJerry Jelinek {
599*cb565728SJerry Jelinek Index = Index - 'A' + 10;
600*cb565728SJerry Jelinek }
601*cb565728SJerry Jelinek else
602*cb565728SJerry Jelinek {
603*cb565728SJerry Jelinek goto ErrorExit;
604*cb565728SJerry Jelinek }
605*cb565728SJerry Jelinek }
606*cb565728SJerry Jelinek
607*cb565728SJerry Jelinek if (Index >= Base)
608*cb565728SJerry Jelinek {
609*cb565728SJerry Jelinek goto ErrorExit;
610*cb565728SJerry Jelinek }
611*cb565728SJerry Jelinek
612*cb565728SJerry Jelinek /* Check to see if value is out of range: */
613*cb565728SJerry Jelinek
614*cb565728SJerry Jelinek if (ReturnValue > ((ACPI_UINT64_MAX - (UINT64) Index) /
615*cb565728SJerry Jelinek (UINT64) Base))
616*cb565728SJerry Jelinek {
617*cb565728SJerry Jelinek goto ErrorExit;
618*cb565728SJerry Jelinek }
619*cb565728SJerry Jelinek else
620*cb565728SJerry Jelinek {
621*cb565728SJerry Jelinek ReturnValue *= Base;
622*cb565728SJerry Jelinek ReturnValue += Index;
623*cb565728SJerry Jelinek }
624*cb565728SJerry Jelinek
625*cb565728SJerry Jelinek ++String;
626*cb565728SJerry Jelinek }
627*cb565728SJerry Jelinek
628*cb565728SJerry Jelinek
629*cb565728SJerry Jelinek /* If a minus sign was present, then "the conversion is negated": */
630*cb565728SJerry Jelinek
631*cb565728SJerry Jelinek if (Sign == ACPI_SIGN_NEGATIVE)
632*cb565728SJerry Jelinek {
633*cb565728SJerry Jelinek ReturnValue = (ACPI_UINT32_MAX - ReturnValue) + 1;
634*cb565728SJerry Jelinek }
635*cb565728SJerry Jelinek
636*cb565728SJerry Jelinek *RetInteger = ReturnValue;
637*cb565728SJerry Jelinek return (Status);
638*cb565728SJerry Jelinek
639*cb565728SJerry Jelinek
640*cb565728SJerry Jelinek ErrorExit:
641*cb565728SJerry Jelinek switch (Base)
642*cb565728SJerry Jelinek {
643*cb565728SJerry Jelinek case 8:
644*cb565728SJerry Jelinek
645*cb565728SJerry Jelinek Status = AE_BAD_OCTAL_CONSTANT;
646*cb565728SJerry Jelinek break;
647*cb565728SJerry Jelinek
648*cb565728SJerry Jelinek case 10:
649*cb565728SJerry Jelinek
650*cb565728SJerry Jelinek Status = AE_BAD_DECIMAL_CONSTANT;
651*cb565728SJerry Jelinek break;
652*cb565728SJerry Jelinek
653*cb565728SJerry Jelinek case 16:
654*cb565728SJerry Jelinek
655*cb565728SJerry Jelinek Status = AE_BAD_HEX_CONSTANT;
656*cb565728SJerry Jelinek break;
657*cb565728SJerry Jelinek
658*cb565728SJerry Jelinek default:
659*cb565728SJerry Jelinek
660*cb565728SJerry Jelinek /* Base validated above */
661*cb565728SJerry Jelinek
662*cb565728SJerry Jelinek break;
663*cb565728SJerry Jelinek }
664*cb565728SJerry Jelinek
665*cb565728SJerry Jelinek return (Status);
666*cb565728SJerry Jelinek }
667*cb565728SJerry Jelinek #endif
668