xref: /freebsd-src/sys/contrib/dev/acpica/components/namespace/nsconvert.c (revision 804fe2660352e090f4481f2c1d646b508859e79a)
19c48c75eSJung-uk Kim /******************************************************************************
29c48c75eSJung-uk Kim  *
39c48c75eSJung-uk Kim  * Module Name: nsconvert - Object conversions for objects returned by
49c48c75eSJung-uk Kim  *                          predefined methods
59c48c75eSJung-uk Kim  *
69c48c75eSJung-uk Kim  *****************************************************************************/
79c48c75eSJung-uk Kim 
80d84335fSJung-uk Kim /******************************************************************************
90d84335fSJung-uk Kim  *
100d84335fSJung-uk Kim  * 1. Copyright Notice
110d84335fSJung-uk Kim  *
12*804fe266SJung-uk Kim  * Some or all of this work - Copyright (c) 1999 - 2024, Intel Corp.
139c48c75eSJung-uk Kim  * All rights reserved.
149c48c75eSJung-uk Kim  *
150d84335fSJung-uk Kim  * 2. License
160d84335fSJung-uk Kim  *
170d84335fSJung-uk Kim  * 2.1. This is your license from Intel Corp. under its intellectual property
180d84335fSJung-uk Kim  * rights. You may have additional license terms from the party that provided
190d84335fSJung-uk Kim  * you this software, covering your right to use that party's intellectual
200d84335fSJung-uk Kim  * property rights.
210d84335fSJung-uk Kim  *
220d84335fSJung-uk Kim  * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
230d84335fSJung-uk Kim  * copy of the source code appearing in this file ("Covered Code") an
240d84335fSJung-uk Kim  * irrevocable, perpetual, worldwide license under Intel's copyrights in the
250d84335fSJung-uk Kim  * base code distributed originally by Intel ("Original Intel Code") to copy,
260d84335fSJung-uk Kim  * make derivatives, distribute, use and display any portion of the Covered
270d84335fSJung-uk Kim  * Code in any form, with the right to sublicense such rights; and
280d84335fSJung-uk Kim  *
290d84335fSJung-uk Kim  * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
300d84335fSJung-uk Kim  * license (with the right to sublicense), under only those claims of Intel
310d84335fSJung-uk Kim  * patents that are infringed by the Original Intel Code, to make, use, sell,
320d84335fSJung-uk Kim  * offer to sell, and import the Covered Code and derivative works thereof
330d84335fSJung-uk Kim  * solely to the minimum extent necessary to exercise the above copyright
340d84335fSJung-uk Kim  * license, and in no event shall the patent license extend to any additions
350d84335fSJung-uk Kim  * to or modifications of the Original Intel Code. No other license or right
360d84335fSJung-uk Kim  * is granted directly or by implication, estoppel or otherwise;
370d84335fSJung-uk Kim  *
380d84335fSJung-uk Kim  * The above copyright and patent license is granted only if the following
390d84335fSJung-uk Kim  * conditions are met:
400d84335fSJung-uk Kim  *
410d84335fSJung-uk Kim  * 3. Conditions
420d84335fSJung-uk Kim  *
430d84335fSJung-uk Kim  * 3.1. Redistribution of Source with Rights to Further Distribute Source.
440d84335fSJung-uk Kim  * Redistribution of source code of any substantial portion of the Covered
450d84335fSJung-uk Kim  * Code or modification with rights to further distribute source must include
460d84335fSJung-uk Kim  * the above Copyright Notice, the above License, this list of Conditions,
470d84335fSJung-uk Kim  * and the following Disclaimer and Export Compliance provision. In addition,
480d84335fSJung-uk Kim  * Licensee must cause all Covered Code to which Licensee contributes to
490d84335fSJung-uk Kim  * contain a file documenting the changes Licensee made to create that Covered
500d84335fSJung-uk Kim  * Code and the date of any change. Licensee must include in that file the
510d84335fSJung-uk Kim  * documentation of any changes made by any predecessor Licensee. Licensee
520d84335fSJung-uk Kim  * must include a prominent statement that the modification is derived,
530d84335fSJung-uk Kim  * directly or indirectly, from Original Intel Code.
540d84335fSJung-uk Kim  *
550d84335fSJung-uk Kim  * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
560d84335fSJung-uk Kim  * Redistribution of source code of any substantial portion of the Covered
570d84335fSJung-uk Kim  * Code or modification without rights to further distribute source must
580d84335fSJung-uk Kim  * include the following Disclaimer and Export Compliance provision in the
590d84335fSJung-uk Kim  * documentation and/or other materials provided with distribution. In
600d84335fSJung-uk Kim  * addition, Licensee may not authorize further sublicense of source of any
610d84335fSJung-uk Kim  * portion of the Covered Code, and must include terms to the effect that the
620d84335fSJung-uk Kim  * license from Licensee to its licensee is limited to the intellectual
630d84335fSJung-uk Kim  * property embodied in the software Licensee provides to its licensee, and
640d84335fSJung-uk Kim  * not to intellectual property embodied in modifications its licensee may
650d84335fSJung-uk Kim  * make.
660d84335fSJung-uk Kim  *
670d84335fSJung-uk Kim  * 3.3. Redistribution of Executable. Redistribution in executable form of any
680d84335fSJung-uk Kim  * substantial portion of the Covered Code or modification must reproduce the
690d84335fSJung-uk Kim  * above Copyright Notice, and the following Disclaimer and Export Compliance
700d84335fSJung-uk Kim  * provision in the documentation and/or other materials provided with the
710d84335fSJung-uk Kim  * distribution.
720d84335fSJung-uk Kim  *
730d84335fSJung-uk Kim  * 3.4. Intel retains all right, title, and interest in and to the Original
740d84335fSJung-uk Kim  * Intel Code.
750d84335fSJung-uk Kim  *
760d84335fSJung-uk Kim  * 3.5. Neither the name Intel nor any other trademark owned or controlled by
770d84335fSJung-uk Kim  * Intel shall be used in advertising or otherwise to promote the sale, use or
780d84335fSJung-uk Kim  * other dealings in products derived from or relating to the Covered Code
790d84335fSJung-uk Kim  * without prior written authorization from Intel.
800d84335fSJung-uk Kim  *
810d84335fSJung-uk Kim  * 4. Disclaimer and Export Compliance
820d84335fSJung-uk Kim  *
830d84335fSJung-uk Kim  * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
840d84335fSJung-uk Kim  * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
850d84335fSJung-uk Kim  * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
860d84335fSJung-uk Kim  * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
870d84335fSJung-uk Kim  * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
880d84335fSJung-uk Kim  * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
890d84335fSJung-uk Kim  * PARTICULAR PURPOSE.
900d84335fSJung-uk Kim  *
910d84335fSJung-uk Kim  * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
920d84335fSJung-uk Kim  * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
930d84335fSJung-uk Kim  * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
940d84335fSJung-uk Kim  * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
950d84335fSJung-uk Kim  * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
960d84335fSJung-uk Kim  * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
970d84335fSJung-uk Kim  * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
980d84335fSJung-uk Kim  * LIMITED REMEDY.
990d84335fSJung-uk Kim  *
1000d84335fSJung-uk Kim  * 4.3. Licensee shall not export, either directly or indirectly, any of this
1010d84335fSJung-uk Kim  * software or system incorporating such software without first obtaining any
1020d84335fSJung-uk Kim  * required license or other approval from the U. S. Department of Commerce or
1030d84335fSJung-uk Kim  * any other agency or department of the United States Government. In the
1040d84335fSJung-uk Kim  * event Licensee exports any such software from the United States or
1050d84335fSJung-uk Kim  * re-exports any such software from a foreign destination, Licensee shall
1060d84335fSJung-uk Kim  * ensure that the distribution and export/re-export of the software is in
1070d84335fSJung-uk Kim  * compliance with all laws, regulations, orders, or other restrictions of the
1080d84335fSJung-uk Kim  * U.S. Export Administration Regulations. Licensee agrees that neither it nor
1090d84335fSJung-uk Kim  * any of its subsidiaries will export/re-export any technical data, process,
1100d84335fSJung-uk Kim  * software, or service, directly or indirectly, to any country for which the
1110d84335fSJung-uk Kim  * United States government or any agency thereof requires an export license,
1120d84335fSJung-uk Kim  * other governmental approval, or letter of assurance, without first obtaining
1130d84335fSJung-uk Kim  * such license, approval or letter.
1140d84335fSJung-uk Kim  *
1150d84335fSJung-uk Kim  *****************************************************************************
1160d84335fSJung-uk Kim  *
1170d84335fSJung-uk Kim  * Alternatively, you may choose to be licensed under the terms of the
1180d84335fSJung-uk Kim  * following license:
1190d84335fSJung-uk Kim  *
1209c48c75eSJung-uk Kim  * Redistribution and use in source and binary forms, with or without
1219c48c75eSJung-uk Kim  * modification, are permitted provided that the following conditions
1229c48c75eSJung-uk Kim  * are met:
1239c48c75eSJung-uk Kim  * 1. Redistributions of source code must retain the above copyright
1249c48c75eSJung-uk Kim  *    notice, this list of conditions, and the following disclaimer,
1259c48c75eSJung-uk Kim  *    without modification.
1269c48c75eSJung-uk Kim  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
1279c48c75eSJung-uk Kim  *    substantially similar to the "NO WARRANTY" disclaimer below
1289c48c75eSJung-uk Kim  *    ("Disclaimer") and any redistribution must be conditioned upon
1299c48c75eSJung-uk Kim  *    including a substantially similar Disclaimer requirement for further
1309c48c75eSJung-uk Kim  *    binary redistribution.
1319c48c75eSJung-uk Kim  * 3. Neither the names of the above-listed copyright holders nor the names
1329c48c75eSJung-uk Kim  *    of any contributors may be used to endorse or promote products derived
1339c48c75eSJung-uk Kim  *    from this software without specific prior written permission.
1349c48c75eSJung-uk Kim  *
1350d84335fSJung-uk Kim  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
1360d84335fSJung-uk Kim  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
1370d84335fSJung-uk Kim  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
1380d84335fSJung-uk Kim  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
1390d84335fSJung-uk Kim  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
1400d84335fSJung-uk Kim  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
1410d84335fSJung-uk Kim  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
1420d84335fSJung-uk Kim  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
1430d84335fSJung-uk Kim  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
1440d84335fSJung-uk Kim  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
1450d84335fSJung-uk Kim  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
1460d84335fSJung-uk Kim  *
1470d84335fSJung-uk Kim  * Alternatively, you may choose to be licensed under the terms of the
1489c48c75eSJung-uk Kim  * GNU General Public License ("GPL") version 2 as published by the Free
1499c48c75eSJung-uk Kim  * Software Foundation.
1509c48c75eSJung-uk Kim  *
1510d84335fSJung-uk Kim  *****************************************************************************/
1529c48c75eSJung-uk Kim 
1539c48c75eSJung-uk Kim #include <contrib/dev/acpica/include/acpi.h>
1549c48c75eSJung-uk Kim #include <contrib/dev/acpica/include/accommon.h>
1559c48c75eSJung-uk Kim #include <contrib/dev/acpica/include/acnamesp.h>
1569c48c75eSJung-uk Kim #include <contrib/dev/acpica/include/acinterp.h>
1579c48c75eSJung-uk Kim #include <contrib/dev/acpica/include/acpredef.h>
1589c48c75eSJung-uk Kim #include <contrib/dev/acpica/include/amlresrc.h>
1599c48c75eSJung-uk Kim 
1609c48c75eSJung-uk Kim #define _COMPONENT          ACPI_NAMESPACE
1619c48c75eSJung-uk Kim         ACPI_MODULE_NAME    ("nsconvert")
1629c48c75eSJung-uk Kim 
1639c48c75eSJung-uk Kim 
1649c48c75eSJung-uk Kim /*******************************************************************************
1659c48c75eSJung-uk Kim  *
1669c48c75eSJung-uk Kim  * FUNCTION:    AcpiNsConvertToInteger
1679c48c75eSJung-uk Kim  *
1689c48c75eSJung-uk Kim  * PARAMETERS:  OriginalObject      - Object to be converted
1699c48c75eSJung-uk Kim  *              ReturnObject        - Where the new converted object is returned
1709c48c75eSJung-uk Kim  *
1719c48c75eSJung-uk Kim  * RETURN:      Status. AE_OK if conversion was successful.
1729c48c75eSJung-uk Kim  *
1739c48c75eSJung-uk Kim  * DESCRIPTION: Attempt to convert a String/Buffer object to an Integer.
1749c48c75eSJung-uk Kim  *
1759c48c75eSJung-uk Kim  ******************************************************************************/
1769c48c75eSJung-uk Kim 
1779c48c75eSJung-uk Kim ACPI_STATUS
1789c48c75eSJung-uk Kim AcpiNsConvertToInteger (
1799c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     *OriginalObject,
1809c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     **ReturnObject)
1819c48c75eSJung-uk Kim {
1829c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     *NewObject;
1839c48c75eSJung-uk Kim     ACPI_STATUS             Status;
1849c48c75eSJung-uk Kim     UINT64                  Value = 0;
1859c48c75eSJung-uk Kim     UINT32                  i;
1869c48c75eSJung-uk Kim 
1879c48c75eSJung-uk Kim 
1889c48c75eSJung-uk Kim     switch (OriginalObject->Common.Type)
1899c48c75eSJung-uk Kim     {
1909c48c75eSJung-uk Kim     case ACPI_TYPE_STRING:
1919c48c75eSJung-uk Kim 
1929c48c75eSJung-uk Kim         /* String-to-Integer conversion */
1939c48c75eSJung-uk Kim 
1942f6a1a81SJung-uk Kim         Status = AcpiUtStrtoul64 (OriginalObject->String.Pointer, &Value);
1959c48c75eSJung-uk Kim         if (ACPI_FAILURE (Status))
1969c48c75eSJung-uk Kim         {
1979c48c75eSJung-uk Kim             return (Status);
1989c48c75eSJung-uk Kim         }
1999c48c75eSJung-uk Kim         break;
2009c48c75eSJung-uk Kim 
2019c48c75eSJung-uk Kim     case ACPI_TYPE_BUFFER:
2029c48c75eSJung-uk Kim 
2039c48c75eSJung-uk Kim         /* Buffer-to-Integer conversion. Max buffer size is 64 bits. */
2049c48c75eSJung-uk Kim 
2059c48c75eSJung-uk Kim         if (OriginalObject->Buffer.Length > 8)
2069c48c75eSJung-uk Kim         {
2079c48c75eSJung-uk Kim             return (AE_AML_OPERAND_TYPE);
2089c48c75eSJung-uk Kim         }
2099c48c75eSJung-uk Kim 
2109c48c75eSJung-uk Kim         /* Extract each buffer byte to create the integer */
2119c48c75eSJung-uk Kim 
2129c48c75eSJung-uk Kim         for (i = 0; i < OriginalObject->Buffer.Length; i++)
2139c48c75eSJung-uk Kim         {
214f8146b88SJung-uk Kim             Value |= ((UINT64)
215f8146b88SJung-uk Kim                 OriginalObject->Buffer.Pointer[i] << (i * 8));
2169c48c75eSJung-uk Kim         }
2179c48c75eSJung-uk Kim         break;
2189c48c75eSJung-uk Kim 
2199c48c75eSJung-uk Kim     default:
220a9d8d09cSJung-uk Kim 
2219c48c75eSJung-uk Kim         return (AE_AML_OPERAND_TYPE);
2229c48c75eSJung-uk Kim     }
2239c48c75eSJung-uk Kim 
2249c48c75eSJung-uk Kim     NewObject = AcpiUtCreateIntegerObject (Value);
2259c48c75eSJung-uk Kim     if (!NewObject)
2269c48c75eSJung-uk Kim     {
2279c48c75eSJung-uk Kim         return (AE_NO_MEMORY);
2289c48c75eSJung-uk Kim     }
2299c48c75eSJung-uk Kim 
2309c48c75eSJung-uk Kim     *ReturnObject = NewObject;
2319c48c75eSJung-uk Kim     return (AE_OK);
2329c48c75eSJung-uk Kim }
2339c48c75eSJung-uk Kim 
2349c48c75eSJung-uk Kim 
2359c48c75eSJung-uk Kim /*******************************************************************************
2369c48c75eSJung-uk Kim  *
2379c48c75eSJung-uk Kim  * FUNCTION:    AcpiNsConvertToString
2389c48c75eSJung-uk Kim  *
2399c48c75eSJung-uk Kim  * PARAMETERS:  OriginalObject      - Object to be converted
2409c48c75eSJung-uk Kim  *              ReturnObject        - Where the new converted object is returned
2419c48c75eSJung-uk Kim  *
2429c48c75eSJung-uk Kim  * RETURN:      Status. AE_OK if conversion was successful.
2439c48c75eSJung-uk Kim  *
2449c48c75eSJung-uk Kim  * DESCRIPTION: Attempt to convert a Integer/Buffer object to a String.
2459c48c75eSJung-uk Kim  *
2469c48c75eSJung-uk Kim  ******************************************************************************/
2479c48c75eSJung-uk Kim 
2489c48c75eSJung-uk Kim ACPI_STATUS
2499c48c75eSJung-uk Kim AcpiNsConvertToString (
2509c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     *OriginalObject,
2519c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     **ReturnObject)
2529c48c75eSJung-uk Kim {
2539c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     *NewObject;
2549c48c75eSJung-uk Kim     ACPI_SIZE               Length;
2559c48c75eSJung-uk Kim     ACPI_STATUS             Status;
2569c48c75eSJung-uk Kim 
2579c48c75eSJung-uk Kim 
2589c48c75eSJung-uk Kim     switch (OriginalObject->Common.Type)
2599c48c75eSJung-uk Kim     {
2609c48c75eSJung-uk Kim     case ACPI_TYPE_INTEGER:
2619c48c75eSJung-uk Kim         /*
2629c48c75eSJung-uk Kim          * Integer-to-String conversion. Commonly, convert
2639c48c75eSJung-uk Kim          * an integer of value 0 to a NULL string. The last element of
2649c48c75eSJung-uk Kim          * _BIF and _BIX packages occasionally need this fix.
2659c48c75eSJung-uk Kim          */
2669c48c75eSJung-uk Kim         if (OriginalObject->Integer.Value == 0)
2679c48c75eSJung-uk Kim         {
2689c48c75eSJung-uk Kim             /* Allocate a new NULL string object */
2699c48c75eSJung-uk Kim 
2709c48c75eSJung-uk Kim             NewObject = AcpiUtCreateStringObject (0);
2719c48c75eSJung-uk Kim             if (!NewObject)
2729c48c75eSJung-uk Kim             {
2739c48c75eSJung-uk Kim                 return (AE_NO_MEMORY);
2749c48c75eSJung-uk Kim             }
2759c48c75eSJung-uk Kim         }
2769c48c75eSJung-uk Kim         else
2779c48c75eSJung-uk Kim         {
278f8146b88SJung-uk Kim             Status = AcpiExConvertToString (OriginalObject,
279f8146b88SJung-uk Kim                 &NewObject, ACPI_IMPLICIT_CONVERT_HEX);
2809c48c75eSJung-uk Kim             if (ACPI_FAILURE (Status))
2819c48c75eSJung-uk Kim             {
2829c48c75eSJung-uk Kim                 return (Status);
2839c48c75eSJung-uk Kim             }
2849c48c75eSJung-uk Kim         }
2859c48c75eSJung-uk Kim         break;
2869c48c75eSJung-uk Kim 
2879c48c75eSJung-uk Kim     case ACPI_TYPE_BUFFER:
2889c48c75eSJung-uk Kim         /*
2899c48c75eSJung-uk Kim          * Buffer-to-String conversion. Use a ToString
2909c48c75eSJung-uk Kim          * conversion, no transform performed on the buffer data. The best
2919c48c75eSJung-uk Kim          * example of this is the _BIF method, where the string data from
2929c48c75eSJung-uk Kim          * the battery is often (incorrectly) returned as buffer object(s).
2939c48c75eSJung-uk Kim          */
2949c48c75eSJung-uk Kim         Length = 0;
2959c48c75eSJung-uk Kim         while ((Length < OriginalObject->Buffer.Length) &&
2969c48c75eSJung-uk Kim                 (OriginalObject->Buffer.Pointer[Length]))
2979c48c75eSJung-uk Kim         {
2989c48c75eSJung-uk Kim             Length++;
2999c48c75eSJung-uk Kim         }
3009c48c75eSJung-uk Kim 
3019c48c75eSJung-uk Kim         /* Allocate a new string object */
3029c48c75eSJung-uk Kim 
3039c48c75eSJung-uk Kim         NewObject = AcpiUtCreateStringObject (Length);
3049c48c75eSJung-uk Kim         if (!NewObject)
3059c48c75eSJung-uk Kim         {
3069c48c75eSJung-uk Kim             return (AE_NO_MEMORY);
3079c48c75eSJung-uk Kim         }
3089c48c75eSJung-uk Kim 
3099c48c75eSJung-uk Kim         /*
3109c48c75eSJung-uk Kim          * Copy the raw buffer data with no transform. String is already NULL
3119c48c75eSJung-uk Kim          * terminated at Length+1.
3129c48c75eSJung-uk Kim          */
3135ef50723SJung-uk Kim         memcpy (NewObject->String.Pointer,
3149c48c75eSJung-uk Kim             OriginalObject->Buffer.Pointer, Length);
3159c48c75eSJung-uk Kim         break;
3169c48c75eSJung-uk Kim 
3179c48c75eSJung-uk Kim     default:
318a9d8d09cSJung-uk Kim 
3199c48c75eSJung-uk Kim         return (AE_AML_OPERAND_TYPE);
3209c48c75eSJung-uk Kim     }
3219c48c75eSJung-uk Kim 
3229c48c75eSJung-uk Kim     *ReturnObject = NewObject;
3239c48c75eSJung-uk Kim     return (AE_OK);
3249c48c75eSJung-uk Kim }
3259c48c75eSJung-uk Kim 
3269c48c75eSJung-uk Kim 
3279c48c75eSJung-uk Kim /*******************************************************************************
3289c48c75eSJung-uk Kim  *
3299c48c75eSJung-uk Kim  * FUNCTION:    AcpiNsConvertToBuffer
3309c48c75eSJung-uk Kim  *
3319c48c75eSJung-uk Kim  * PARAMETERS:  OriginalObject      - Object to be converted
3329c48c75eSJung-uk Kim  *              ReturnObject        - Where the new converted object is returned
3339c48c75eSJung-uk Kim  *
3349c48c75eSJung-uk Kim  * RETURN:      Status. AE_OK if conversion was successful.
3359c48c75eSJung-uk Kim  *
3369c48c75eSJung-uk Kim  * DESCRIPTION: Attempt to convert a Integer/String/Package object to a Buffer.
3379c48c75eSJung-uk Kim  *
3389c48c75eSJung-uk Kim  ******************************************************************************/
3399c48c75eSJung-uk Kim 
3409c48c75eSJung-uk Kim ACPI_STATUS
3419c48c75eSJung-uk Kim AcpiNsConvertToBuffer (
3429c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     *OriginalObject,
3439c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     **ReturnObject)
3449c48c75eSJung-uk Kim {
3459c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     *NewObject;
3469c48c75eSJung-uk Kim     ACPI_STATUS             Status;
3479c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     **Elements;
3489c48c75eSJung-uk Kim     UINT32                  *DwordBuffer;
3499c48c75eSJung-uk Kim     UINT32                  Count;
3509c48c75eSJung-uk Kim     UINT32                  i;
3519c48c75eSJung-uk Kim 
3529c48c75eSJung-uk Kim 
3539c48c75eSJung-uk Kim     switch (OriginalObject->Common.Type)
3549c48c75eSJung-uk Kim     {
3559c48c75eSJung-uk Kim     case ACPI_TYPE_INTEGER:
3569c48c75eSJung-uk Kim         /*
3579c48c75eSJung-uk Kim          * Integer-to-Buffer conversion.
3589c48c75eSJung-uk Kim          * Convert the Integer to a packed-byte buffer. _MAT and other
3599c48c75eSJung-uk Kim          * objects need this sometimes, if a read has been performed on a
3609c48c75eSJung-uk Kim          * Field object that is less than or equal to the global integer
3619c48c75eSJung-uk Kim          * size (32 or 64 bits).
3629c48c75eSJung-uk Kim          */
3639c48c75eSJung-uk Kim         Status = AcpiExConvertToBuffer (OriginalObject, &NewObject);
3649c48c75eSJung-uk Kim         if (ACPI_FAILURE (Status))
3659c48c75eSJung-uk Kim         {
3669c48c75eSJung-uk Kim             return (Status);
3679c48c75eSJung-uk Kim         }
3689c48c75eSJung-uk Kim         break;
3699c48c75eSJung-uk Kim 
3709c48c75eSJung-uk Kim     case ACPI_TYPE_STRING:
3719c48c75eSJung-uk Kim 
3729c48c75eSJung-uk Kim         /* String-to-Buffer conversion. Simple data copy */
3739c48c75eSJung-uk Kim 
374f8146b88SJung-uk Kim         NewObject = AcpiUtCreateBufferObject
375f8146b88SJung-uk Kim             (OriginalObject->String.Length);
3769c48c75eSJung-uk Kim         if (!NewObject)
3779c48c75eSJung-uk Kim         {
3789c48c75eSJung-uk Kim             return (AE_NO_MEMORY);
3799c48c75eSJung-uk Kim         }
3809c48c75eSJung-uk Kim 
3815ef50723SJung-uk Kim         memcpy (NewObject->Buffer.Pointer,
3829c48c75eSJung-uk Kim             OriginalObject->String.Pointer, OriginalObject->String.Length);
3839c48c75eSJung-uk Kim         break;
3849c48c75eSJung-uk Kim 
3859c48c75eSJung-uk Kim     case ACPI_TYPE_PACKAGE:
3869c48c75eSJung-uk Kim         /*
3879c48c75eSJung-uk Kim          * This case is often seen for predefined names that must return a
3889c48c75eSJung-uk Kim          * Buffer object with multiple DWORD integers within. For example,
3899c48c75eSJung-uk Kim          * _FDE and _GTM. The Package can be converted to a Buffer.
3909c48c75eSJung-uk Kim          */
3919c48c75eSJung-uk Kim 
3929c48c75eSJung-uk Kim         /* All elements of the Package must be integers */
3939c48c75eSJung-uk Kim 
3949c48c75eSJung-uk Kim         Elements = OriginalObject->Package.Elements;
3959c48c75eSJung-uk Kim         Count = OriginalObject->Package.Count;
3969c48c75eSJung-uk Kim 
3979c48c75eSJung-uk Kim         for (i = 0; i < Count; i++)
3989c48c75eSJung-uk Kim         {
3999c48c75eSJung-uk Kim             if ((!*Elements) ||
4009c48c75eSJung-uk Kim                 ((*Elements)->Common.Type != ACPI_TYPE_INTEGER))
4019c48c75eSJung-uk Kim             {
4029c48c75eSJung-uk Kim                 return (AE_AML_OPERAND_TYPE);
4039c48c75eSJung-uk Kim             }
4049c48c75eSJung-uk Kim             Elements++;
4059c48c75eSJung-uk Kim         }
4069c48c75eSJung-uk Kim 
4079c48c75eSJung-uk Kim         /* Create the new buffer object to replace the Package */
4089c48c75eSJung-uk Kim 
4099c48c75eSJung-uk Kim         NewObject = AcpiUtCreateBufferObject (ACPI_MUL_4 (Count));
4109c48c75eSJung-uk Kim         if (!NewObject)
4119c48c75eSJung-uk Kim         {
4129c48c75eSJung-uk Kim             return (AE_NO_MEMORY);
4139c48c75eSJung-uk Kim         }
4149c48c75eSJung-uk Kim 
4159c48c75eSJung-uk Kim         /* Copy the package elements (integers) to the buffer as DWORDs */
4169c48c75eSJung-uk Kim 
4179c48c75eSJung-uk Kim         Elements = OriginalObject->Package.Elements;
4189c48c75eSJung-uk Kim         DwordBuffer = ACPI_CAST_PTR (UINT32, NewObject->Buffer.Pointer);
4199c48c75eSJung-uk Kim 
4209c48c75eSJung-uk Kim         for (i = 0; i < Count; i++)
4219c48c75eSJung-uk Kim         {
4229c48c75eSJung-uk Kim             *DwordBuffer = (UINT32) (*Elements)->Integer.Value;
4239c48c75eSJung-uk Kim             DwordBuffer++;
4249c48c75eSJung-uk Kim             Elements++;
4259c48c75eSJung-uk Kim         }
4269c48c75eSJung-uk Kim         break;
4279c48c75eSJung-uk Kim 
4289c48c75eSJung-uk Kim     default:
429a9d8d09cSJung-uk Kim 
4309c48c75eSJung-uk Kim         return (AE_AML_OPERAND_TYPE);
4319c48c75eSJung-uk Kim     }
4329c48c75eSJung-uk Kim 
4339c48c75eSJung-uk Kim     *ReturnObject = NewObject;
4349c48c75eSJung-uk Kim     return (AE_OK);
4359c48c75eSJung-uk Kim }
4369c48c75eSJung-uk Kim 
4379c48c75eSJung-uk Kim 
4389c48c75eSJung-uk Kim /*******************************************************************************
4399c48c75eSJung-uk Kim  *
4409c48c75eSJung-uk Kim  * FUNCTION:    AcpiNsConvertToUnicode
4419c48c75eSJung-uk Kim  *
442f8146b88SJung-uk Kim  * PARAMETERS:  Scope               - Namespace node for the method/object
443f8146b88SJung-uk Kim  *              OriginalObject      - ASCII String Object to be converted
4449c48c75eSJung-uk Kim  *              ReturnObject        - Where the new converted object is returned
4459c48c75eSJung-uk Kim  *
4469c48c75eSJung-uk Kim  * RETURN:      Status. AE_OK if conversion was successful.
4479c48c75eSJung-uk Kim  *
4489c48c75eSJung-uk Kim  * DESCRIPTION: Attempt to convert a String object to a Unicode string Buffer.
4499c48c75eSJung-uk Kim  *
4509c48c75eSJung-uk Kim  ******************************************************************************/
4519c48c75eSJung-uk Kim 
4529c48c75eSJung-uk Kim ACPI_STATUS
4539c48c75eSJung-uk Kim AcpiNsConvertToUnicode (
454f8146b88SJung-uk Kim     ACPI_NAMESPACE_NODE     *Scope,
4559c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     *OriginalObject,
4569c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     **ReturnObject)
4579c48c75eSJung-uk Kim {
4589c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     *NewObject;
4599c48c75eSJung-uk Kim     char                    *AsciiString;
4609c48c75eSJung-uk Kim     UINT16                  *UnicodeBuffer;
4619c48c75eSJung-uk Kim     UINT32                  UnicodeLength;
4629c48c75eSJung-uk Kim     UINT32                  i;
4639c48c75eSJung-uk Kim 
4649c48c75eSJung-uk Kim 
4659c48c75eSJung-uk Kim     if (!OriginalObject)
4669c48c75eSJung-uk Kim     {
4679c48c75eSJung-uk Kim         return (AE_OK);
4689c48c75eSJung-uk Kim     }
4699c48c75eSJung-uk Kim 
4709c48c75eSJung-uk Kim     /* If a Buffer was returned, it must be at least two bytes long */
4719c48c75eSJung-uk Kim 
4729c48c75eSJung-uk Kim     if (OriginalObject->Common.Type == ACPI_TYPE_BUFFER)
4739c48c75eSJung-uk Kim     {
4749c48c75eSJung-uk Kim         if (OriginalObject->Buffer.Length < 2)
4759c48c75eSJung-uk Kim         {
4769c48c75eSJung-uk Kim             return (AE_AML_OPERAND_VALUE);
4779c48c75eSJung-uk Kim         }
4789c48c75eSJung-uk Kim 
4799c48c75eSJung-uk Kim         *ReturnObject = NULL;
4809c48c75eSJung-uk Kim         return (AE_OK);
4819c48c75eSJung-uk Kim     }
4829c48c75eSJung-uk Kim 
4839c48c75eSJung-uk Kim     /*
4849c48c75eSJung-uk Kim      * The original object is an ASCII string. Convert this string to
4859c48c75eSJung-uk Kim      * a unicode buffer.
4869c48c75eSJung-uk Kim      */
4879c48c75eSJung-uk Kim     AsciiString = OriginalObject->String.Pointer;
4889c48c75eSJung-uk Kim     UnicodeLength = (OriginalObject->String.Length * 2) + 2;
4899c48c75eSJung-uk Kim 
4909c48c75eSJung-uk Kim     /* Create a new buffer object for the Unicode data */
4919c48c75eSJung-uk Kim 
4929c48c75eSJung-uk Kim     NewObject = AcpiUtCreateBufferObject (UnicodeLength);
4939c48c75eSJung-uk Kim     if (!NewObject)
4949c48c75eSJung-uk Kim     {
4959c48c75eSJung-uk Kim         return (AE_NO_MEMORY);
4969c48c75eSJung-uk Kim     }
4979c48c75eSJung-uk Kim 
4989c48c75eSJung-uk Kim     UnicodeBuffer = ACPI_CAST_PTR (UINT16, NewObject->Buffer.Pointer);
4999c48c75eSJung-uk Kim 
5009c48c75eSJung-uk Kim     /* Convert ASCII to Unicode */
5019c48c75eSJung-uk Kim 
5029c48c75eSJung-uk Kim     for (i = 0; i < OriginalObject->String.Length; i++)
5039c48c75eSJung-uk Kim     {
5049c48c75eSJung-uk Kim         UnicodeBuffer[i] = (UINT16) AsciiString[i];
5059c48c75eSJung-uk Kim     }
5069c48c75eSJung-uk Kim 
5079c48c75eSJung-uk Kim     *ReturnObject = NewObject;
5089c48c75eSJung-uk Kim     return (AE_OK);
5099c48c75eSJung-uk Kim }
5109c48c75eSJung-uk Kim 
5119c48c75eSJung-uk Kim 
5129c48c75eSJung-uk Kim /*******************************************************************************
5139c48c75eSJung-uk Kim  *
5149c48c75eSJung-uk Kim  * FUNCTION:    AcpiNsConvertToResource
5159c48c75eSJung-uk Kim  *
516f8146b88SJung-uk Kim  * PARAMETERS:  Scope               - Namespace node for the method/object
517f8146b88SJung-uk Kim  *              OriginalObject      - Object to be converted
5189c48c75eSJung-uk Kim  *              ReturnObject        - Where the new converted object is returned
5199c48c75eSJung-uk Kim  *
5209c48c75eSJung-uk Kim  * RETURN:      Status. AE_OK if conversion was successful
5219c48c75eSJung-uk Kim  *
5229c48c75eSJung-uk Kim  * DESCRIPTION: Attempt to convert a Integer object to a ResourceTemplate
5239c48c75eSJung-uk Kim  *              Buffer.
5249c48c75eSJung-uk Kim  *
5259c48c75eSJung-uk Kim  ******************************************************************************/
5269c48c75eSJung-uk Kim 
5279c48c75eSJung-uk Kim ACPI_STATUS
5289c48c75eSJung-uk Kim AcpiNsConvertToResource (
529f8146b88SJung-uk Kim     ACPI_NAMESPACE_NODE     *Scope,
5309c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     *OriginalObject,
5319c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     **ReturnObject)
5329c48c75eSJung-uk Kim {
5339c48c75eSJung-uk Kim     ACPI_OPERAND_OBJECT     *NewObject;
5349c48c75eSJung-uk Kim     UINT8                   *Buffer;
5359c48c75eSJung-uk Kim 
5369c48c75eSJung-uk Kim 
5379c48c75eSJung-uk Kim     /*
5389c48c75eSJung-uk Kim      * We can fix the following cases for an expected resource template:
5399c48c75eSJung-uk Kim      * 1. No return value (interpreter slack mode is disabled)
5409c48c75eSJung-uk Kim      * 2. A "Return (Zero)" statement
5419c48c75eSJung-uk Kim      * 3. A "Return empty buffer" statement
5429c48c75eSJung-uk Kim      *
5439c48c75eSJung-uk Kim      * We will return a buffer containing a single EndTag
5449c48c75eSJung-uk Kim      * resource descriptor.
5459c48c75eSJung-uk Kim      */
5469c48c75eSJung-uk Kim     if (OriginalObject)
5479c48c75eSJung-uk Kim     {
5489c48c75eSJung-uk Kim         switch (OriginalObject->Common.Type)
5499c48c75eSJung-uk Kim         {
5509c48c75eSJung-uk Kim         case ACPI_TYPE_INTEGER:
5519c48c75eSJung-uk Kim 
5529c48c75eSJung-uk Kim             /* We can only repair an Integer==0 */
5539c48c75eSJung-uk Kim 
5549c48c75eSJung-uk Kim             if (OriginalObject->Integer.Value)
5559c48c75eSJung-uk Kim             {
5569c48c75eSJung-uk Kim                 return (AE_AML_OPERAND_TYPE);
5579c48c75eSJung-uk Kim             }
5589c48c75eSJung-uk Kim             break;
5599c48c75eSJung-uk Kim 
5609c48c75eSJung-uk Kim         case ACPI_TYPE_BUFFER:
5619c48c75eSJung-uk Kim 
5629c48c75eSJung-uk Kim             if (OriginalObject->Buffer.Length)
5639c48c75eSJung-uk Kim             {
5649c48c75eSJung-uk Kim                 /* Additional checks can be added in the future */
5659c48c75eSJung-uk Kim 
5669c48c75eSJung-uk Kim                 *ReturnObject = NULL;
5679c48c75eSJung-uk Kim                 return (AE_OK);
5689c48c75eSJung-uk Kim             }
5699c48c75eSJung-uk Kim             break;
5709c48c75eSJung-uk Kim 
5719c48c75eSJung-uk Kim         case ACPI_TYPE_STRING:
5729c48c75eSJung-uk Kim         default:
5739c48c75eSJung-uk Kim 
5749c48c75eSJung-uk Kim             return (AE_AML_OPERAND_TYPE);
5759c48c75eSJung-uk Kim         }
5769c48c75eSJung-uk Kim     }
5779c48c75eSJung-uk Kim 
5789c48c75eSJung-uk Kim     /* Create the new buffer object for the resource descriptor */
5799c48c75eSJung-uk Kim 
5809c48c75eSJung-uk Kim     NewObject = AcpiUtCreateBufferObject (2);
5819c48c75eSJung-uk Kim     if (!NewObject)
5829c48c75eSJung-uk Kim     {
5839c48c75eSJung-uk Kim         return (AE_NO_MEMORY);
5849c48c75eSJung-uk Kim     }
5859c48c75eSJung-uk Kim 
5869c48c75eSJung-uk Kim     Buffer = ACPI_CAST_PTR (UINT8, NewObject->Buffer.Pointer);
5879c48c75eSJung-uk Kim 
5889c48c75eSJung-uk Kim     /* Initialize the Buffer with a single EndTag descriptor */
5899c48c75eSJung-uk Kim 
5909c48c75eSJung-uk Kim     Buffer[0] = (ACPI_RESOURCE_NAME_END_TAG | ASL_RDESC_END_TAG_SIZE);
5919c48c75eSJung-uk Kim     Buffer[1] = 0x00;
5929c48c75eSJung-uk Kim 
5939c48c75eSJung-uk Kim     *ReturnObject = NewObject;
5949c48c75eSJung-uk Kim     return (AE_OK);
5959c48c75eSJung-uk Kim }
596f8146b88SJung-uk Kim 
597f8146b88SJung-uk Kim 
598f8146b88SJung-uk Kim /*******************************************************************************
599f8146b88SJung-uk Kim  *
600f8146b88SJung-uk Kim  * FUNCTION:    AcpiNsConvertToReference
601f8146b88SJung-uk Kim  *
602f8146b88SJung-uk Kim  * PARAMETERS:  Scope               - Namespace node for the method/object
603f8146b88SJung-uk Kim  *              OriginalObject      - Object to be converted
604f8146b88SJung-uk Kim  *              ReturnObject        - Where the new converted object is returned
605f8146b88SJung-uk Kim  *
606f8146b88SJung-uk Kim  * RETURN:      Status. AE_OK if conversion was successful
607f8146b88SJung-uk Kim  *
608f8146b88SJung-uk Kim  * DESCRIPTION: Attempt to convert a Integer object to a ObjectReference.
609f8146b88SJung-uk Kim  *              Buffer.
610f8146b88SJung-uk Kim  *
611f8146b88SJung-uk Kim  ******************************************************************************/
612f8146b88SJung-uk Kim 
613f8146b88SJung-uk Kim ACPI_STATUS
614f8146b88SJung-uk Kim AcpiNsConvertToReference (
615f8146b88SJung-uk Kim     ACPI_NAMESPACE_NODE     *Scope,
616f8146b88SJung-uk Kim     ACPI_OPERAND_OBJECT     *OriginalObject,
617f8146b88SJung-uk Kim     ACPI_OPERAND_OBJECT     **ReturnObject)
618f8146b88SJung-uk Kim {
619f8146b88SJung-uk Kim     ACPI_OPERAND_OBJECT     *NewObject = NULL;
620f8146b88SJung-uk Kim     ACPI_STATUS             Status;
621f8146b88SJung-uk Kim     ACPI_NAMESPACE_NODE     *Node;
622f8146b88SJung-uk Kim     ACPI_GENERIC_STATE      ScopeInfo;
623f8146b88SJung-uk Kim     char                    *Name;
624f8146b88SJung-uk Kim 
625f8146b88SJung-uk Kim 
626f8146b88SJung-uk Kim     ACPI_FUNCTION_NAME (NsConvertToReference);
627f8146b88SJung-uk Kim 
628f8146b88SJung-uk Kim 
629f8146b88SJung-uk Kim     /* Convert path into internal presentation */
630f8146b88SJung-uk Kim 
631f8146b88SJung-uk Kim     Status = AcpiNsInternalizeName (OriginalObject->String.Pointer, &Name);
632f8146b88SJung-uk Kim     if (ACPI_FAILURE (Status))
633f8146b88SJung-uk Kim     {
634f8146b88SJung-uk Kim         return_ACPI_STATUS (Status);
635f8146b88SJung-uk Kim     }
636f8146b88SJung-uk Kim 
637f8146b88SJung-uk Kim     /* Find the namespace node */
638f8146b88SJung-uk Kim 
639f8146b88SJung-uk Kim     ScopeInfo.Scope.Node = ACPI_CAST_PTR (ACPI_NAMESPACE_NODE, Scope);
640f8146b88SJung-uk Kim     Status = AcpiNsLookup (&ScopeInfo, Name,
641f8146b88SJung-uk Kim         ACPI_TYPE_ANY, ACPI_IMODE_EXECUTE,
642f8146b88SJung-uk Kim         ACPI_NS_SEARCH_PARENT | ACPI_NS_DONT_OPEN_SCOPE, NULL, &Node);
643f8146b88SJung-uk Kim     if (ACPI_FAILURE (Status))
644f8146b88SJung-uk Kim     {
645f8146b88SJung-uk Kim         /* Check if we are resolving a named reference within a package */
646f8146b88SJung-uk Kim 
647b7b7e711SJung-uk Kim         ACPI_ERROR_NAMESPACE (&ScopeInfo,
648b7b7e711SJung-uk Kim             OriginalObject->String.Pointer, Status);
649f8146b88SJung-uk Kim         goto ErrorExit;
650f8146b88SJung-uk Kim     }
651f8146b88SJung-uk Kim 
652f8146b88SJung-uk Kim     /* Create and init a new internal ACPI object */
653f8146b88SJung-uk Kim 
654f8146b88SJung-uk Kim     NewObject = AcpiUtCreateInternalObject (ACPI_TYPE_LOCAL_REFERENCE);
655f8146b88SJung-uk Kim     if (!NewObject)
656f8146b88SJung-uk Kim     {
657f8146b88SJung-uk Kim         Status = AE_NO_MEMORY;
658f8146b88SJung-uk Kim         goto ErrorExit;
659f8146b88SJung-uk Kim     }
660f8146b88SJung-uk Kim     NewObject->Reference.Node = Node;
661f8146b88SJung-uk Kim     NewObject->Reference.Object = Node->Object;
662f8146b88SJung-uk Kim     NewObject->Reference.Class = ACPI_REFCLASS_NAME;
663f8146b88SJung-uk Kim 
664f8146b88SJung-uk Kim     /*
665f8146b88SJung-uk Kim      * Increase reference of the object if needed (the object is likely a
666f8146b88SJung-uk Kim      * null for device nodes).
667f8146b88SJung-uk Kim      */
668f8146b88SJung-uk Kim     AcpiUtAddReference (Node->Object);
669f8146b88SJung-uk Kim 
670f8146b88SJung-uk Kim ErrorExit:
671f8146b88SJung-uk Kim     ACPI_FREE (Name);
672f8146b88SJung-uk Kim     *ReturnObject = NewObject;
673a009b7dcSJung-uk Kim     return (Status);
674f8146b88SJung-uk Kim }
675