Blame source/components/resources/rsmisc.c

Packit Service 1fb00e
/*******************************************************************************
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * Module Name: rsmisc - Miscellaneous resource descriptors
Packit Service 1fb00e
 *
Packit Service 1fb00e
 ******************************************************************************/
Packit Service 1fb00e
Packit Service 1fb00e
/*
Packit Service 1fb00e
 * Copyright (C) 2000 - 2018, Intel Corp.
Packit Service 1fb00e
 * All rights reserved.
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * Redistribution and use in source and binary forms, with or without
Packit Service 1fb00e
 * modification, are permitted provided that the following conditions
Packit Service 1fb00e
 * are met:
Packit Service 1fb00e
 * 1. Redistributions of source code must retain the above copyright
Packit Service 1fb00e
 *    notice, this list of conditions, and the following disclaimer,
Packit Service 1fb00e
 *    without modification.
Packit Service 1fb00e
 * 2. Redistributions in binary form must reproduce at minimum a disclaimer
Packit Service 1fb00e
 *    substantially similar to the "NO WARRANTY" disclaimer below
Packit Service 1fb00e
 *    ("Disclaimer") and any redistribution must be conditioned upon
Packit Service 1fb00e
 *    including a substantially similar Disclaimer requirement for further
Packit Service 1fb00e
 *    binary redistribution.
Packit Service 1fb00e
 * 3. Neither the names of the above-listed copyright holders nor the names
Packit Service 1fb00e
 *    of any contributors may be used to endorse or promote products derived
Packit Service 1fb00e
 *    from this software without specific prior written permission.
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * Alternatively, this software may be distributed under the terms of the
Packit Service 1fb00e
 * GNU General Public License ("GPL") version 2 as published by the Free
Packit Service 1fb00e
 * Software Foundation.
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * NO WARRANTY
Packit Service 1fb00e
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit Service 1fb00e
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit Service 1fb00e
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
Packit Service 1fb00e
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
Packit Service 1fb00e
 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
Packit Service 1fb00e
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
Packit Service 1fb00e
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
Packit Service 1fb00e
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
Packit Service 1fb00e
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
Packit Service 1fb00e
 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
Packit Service 1fb00e
 * POSSIBILITY OF SUCH DAMAGES.
Packit Service 1fb00e
 */
Packit Service 1fb00e
Packit Service 1fb00e
#include "acpi.h"
Packit Service 1fb00e
#include "accommon.h"
Packit Service 1fb00e
#include "acresrc.h"
Packit Service 1fb00e
Packit Service 1fb00e
#define _COMPONENT          ACPI_RESOURCES
Packit Service 1fb00e
        ACPI_MODULE_NAME    ("rsmisc")
Packit Service 1fb00e
Packit Service 1fb00e
Packit Service 1fb00e
#define INIT_RESOURCE_TYPE(i)       i->ResourceOffset
Packit Service 1fb00e
#define INIT_RESOURCE_LENGTH(i)     i->AmlOffset
Packit Service 1fb00e
#define INIT_TABLE_LENGTH(i)        i->Value
Packit Service 1fb00e
Packit Service 1fb00e
#define COMPARE_OPCODE(i)           i->ResourceOffset
Packit Service 1fb00e
#define COMPARE_TARGET(i)           i->AmlOffset
Packit Service 1fb00e
#define COMPARE_VALUE(i)            i->Value
Packit Service 1fb00e
Packit Service 1fb00e
Packit Service 1fb00e
/*******************************************************************************
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * FUNCTION:    AcpiRsConvertAmlToResource
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * PARAMETERS:  Resource            - Pointer to the resource descriptor
Packit Service 1fb00e
 *              Aml                 - Where the AML descriptor is returned
Packit Service 1fb00e
 *              Info                - Pointer to appropriate conversion table
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * RETURN:      Status
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * DESCRIPTION: Convert an external AML resource descriptor to the corresponding
Packit Service 1fb00e
 *              internal resource descriptor
Packit Service 1fb00e
 *
Packit Service 1fb00e
 ******************************************************************************/
Packit Service 1fb00e
Packit Service 1fb00e
ACPI_STATUS
Packit Service 1fb00e
AcpiRsConvertAmlToResource (
Packit Service 1fb00e
    ACPI_RESOURCE           *Resource,
Packit Service 1fb00e
    AML_RESOURCE            *Aml,
Packit Service 1fb00e
    ACPI_RSCONVERT_INFO     *Info)
Packit Service 1fb00e
{
Packit Service 1fb00e
    ACPI_RS_LENGTH          AmlResourceLength;
Packit Service 1fb00e
    void                    *Source;
Packit Service 1fb00e
    void                    *Destination;
Packit Service 1fb00e
    char                    *Target;
Packit Service 1fb00e
    UINT8                   Count;
Packit Service 1fb00e
    UINT8                   FlagsMode = FALSE;
Packit Service 1fb00e
    UINT16                  ItemCount = 0;
Packit Service 1fb00e
    UINT16                  Temp16 = 0;
Packit Service 1fb00e
Packit Service 1fb00e
Packit Service 1fb00e
    ACPI_FUNCTION_TRACE (RsConvertAmlToResource);
Packit Service 1fb00e
Packit Service 1fb00e
Packit Service 1fb00e
    if (!Info)
Packit Service 1fb00e
    {
Packit Service 1fb00e
        return_ACPI_STATUS (AE_BAD_PARAMETER);
Packit Service 1fb00e
    }
Packit Service 1fb00e
Packit Service 1fb00e
    if (((ACPI_SIZE) Resource) & 0x3)
Packit Service 1fb00e
    {
Packit Service 1fb00e
        /* Each internal resource struct is expected to be 32-bit aligned */
Packit Service 1fb00e
Packit Service 1fb00e
        ACPI_WARNING ((AE_INFO,
Packit Service 1fb00e
            "Misaligned resource pointer (get): %p Type 0x%2.2X Length %u",
Packit Service 1fb00e
            Resource, Resource->Type, Resource->Length));
Packit Service 1fb00e
    }
Packit Service 1fb00e
Packit Service 1fb00e
    /* Extract the resource Length field (does not include header length) */
Packit Service 1fb00e
Packit Service 1fb00e
    AmlResourceLength = AcpiUtGetResourceLength (Aml);
Packit Service 1fb00e
Packit Service 1fb00e
    /*
Packit Service 1fb00e
     * First table entry must be ACPI_RSC_INITxxx and must contain the
Packit Service 1fb00e
     * table length (# of table entries)
Packit Service 1fb00e
     */
Packit Service 1fb00e
    Count = INIT_TABLE_LENGTH (Info);
Packit Service 1fb00e
    while (Count)
Packit Service 1fb00e
    {
Packit Service 1fb00e
        /*
Packit Service 1fb00e
         * Source is the external AML byte stream buffer,
Packit Service 1fb00e
         * destination is the internal resource descriptor
Packit Service 1fb00e
         */
Packit Service 1fb00e
        Source = ACPI_ADD_PTR (void, Aml, Info->AmlOffset);
Packit Service 1fb00e
        Destination = ACPI_ADD_PTR (void, Resource, Info->ResourceOffset);
Packit Service 1fb00e
Packit Service 1fb00e
        switch (Info->Opcode)
Packit Service 1fb00e
        {
Packit Service 1fb00e
        case ACPI_RSC_INITGET:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Get the resource type and the initial (minimum) length
Packit Service 1fb00e
             */
Packit Service 1fb00e
            memset (Resource, 0, INIT_RESOURCE_LENGTH (Info));
Packit Service 1fb00e
            Resource->Type = INIT_RESOURCE_TYPE (Info);
Packit Service 1fb00e
            Resource->Length = INIT_RESOURCE_LENGTH (Info);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_INITSET:
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_FLAGINIT:
Packit Service 1fb00e
Packit Service 1fb00e
            FlagsMode = TRUE;
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_1BITFLAG:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Mask and shift the flag bit
Packit Service 1fb00e
             */
Packit Service 1fb00e
            ACPI_SET8 (Destination,
Packit Service 1fb00e
                ((ACPI_GET8 (Source) >> Info->Value) & 0x01));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_2BITFLAG:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Mask and shift the flag bits
Packit Service 1fb00e
             */
Packit Service 1fb00e
            ACPI_SET8 (Destination,
Packit Service 1fb00e
                ((ACPI_GET8 (Source) >> Info->Value) & 0x03));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_3BITFLAG:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Mask and shift the flag bits
Packit Service 1fb00e
             */
Packit Service 1fb00e
            ACPI_SET8 (Destination,
Packit Service 1fb00e
                ((ACPI_GET8 (Source) >> Info->Value) & 0x07));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = ACPI_GET8 (Source);
Packit Service 1fb00e
            ACPI_SET8 (Destination, ItemCount);
Packit Service 1fb00e
Packit Service 1fb00e
            Resource->Length = Resource->Length +
Packit Service 1fb00e
                (Info->Value * (ItemCount - 1));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT16:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = AmlResourceLength;
Packit Service 1fb00e
            ACPI_SET16 (Destination, ItemCount);
Packit Service 1fb00e
Packit Service 1fb00e
            Resource->Length = Resource->Length +
Packit Service 1fb00e
                (Info->Value * (ItemCount - 1));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT_GPIO_PIN:
Packit Service 1fb00e
Packit Service 1fb00e
            Target = ACPI_ADD_PTR (void, Aml, Info->Value);
Packit Service 1fb00e
            ItemCount = ACPI_GET16 (Target) - ACPI_GET16 (Source);
Packit Service 1fb00e
Packit Service 1fb00e
            Resource->Length = Resource->Length + ItemCount;
Packit Service 1fb00e
            ItemCount = ItemCount / 2;
Packit Service 1fb00e
            ACPI_SET16 (Destination, ItemCount);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT_GPIO_VEN:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = ACPI_GET8 (Source);
Packit Service 1fb00e
            ACPI_SET8 (Destination, ItemCount);
Packit Service 1fb00e
Packit Service 1fb00e
            Resource->Length = Resource->Length + (Info->Value * ItemCount);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT_GPIO_RES:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Vendor data is optional (length/offset may both be zero)
Packit Service 1fb00e
             * Examine vendor data length field first
Packit Service 1fb00e
             */
Packit Service 1fb00e
            Target = ACPI_ADD_PTR (void, Aml, (Info->Value + 2));
Packit Service 1fb00e
            if (ACPI_GET16 (Target))
Packit Service 1fb00e
            {
Packit Service 1fb00e
                /* Use vendor offset to get resource source length */
Packit Service 1fb00e
Packit Service 1fb00e
                Target = ACPI_ADD_PTR (void, Aml, Info->Value);
Packit Service 1fb00e
                ItemCount = ACPI_GET16 (Target) - ACPI_GET16 (Source);
Packit Service 1fb00e
            }
Packit Service 1fb00e
            else
Packit Service 1fb00e
            {
Packit Service 1fb00e
                /* No vendor data to worry about */
Packit Service 1fb00e
Packit Service 1fb00e
                ItemCount = Aml->LargeHeader.ResourceLength +
Packit Service 1fb00e
                    sizeof (AML_RESOURCE_LARGE_HEADER) -
Packit Service 1fb00e
                    ACPI_GET16 (Source);
Packit Service 1fb00e
            }
Packit Service 1fb00e
Packit Service 1fb00e
            Resource->Length = Resource->Length + ItemCount;
Packit Service 1fb00e
            ACPI_SET16 (Destination, ItemCount);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT_SERIAL_VEN:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = ACPI_GET16 (Source) - Info->Value;
Packit Service 1fb00e
Packit Service 1fb00e
            Resource->Length = Resource->Length + ItemCount;
Packit Service 1fb00e
            ACPI_SET16 (Destination, ItemCount);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT_SERIAL_RES:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = (AmlResourceLength +
Packit Service 1fb00e
                sizeof (AML_RESOURCE_LARGE_HEADER)) -
Packit Service 1fb00e
                ACPI_GET16 (Source) - Info->Value;
Packit Service 1fb00e
Packit Service 1fb00e
            Resource->Length = Resource->Length + ItemCount;
Packit Service 1fb00e
            ACPI_SET16 (Destination, ItemCount);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_LENGTH:
Packit Service 1fb00e
Packit Service 1fb00e
            Resource->Length = Resource->Length + Info->Value;
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_MOVE8:
Packit Service 1fb00e
        case ACPI_RSC_MOVE16:
Packit Service 1fb00e
        case ACPI_RSC_MOVE32:
Packit Service 1fb00e
        case ACPI_RSC_MOVE64:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Raw data move. Use the Info value field unless ItemCount has
Packit Service 1fb00e
             * been previously initialized via a COUNT opcode
Packit Service 1fb00e
             */
Packit Service 1fb00e
            if (Info->Value)
Packit Service 1fb00e
            {
Packit Service 1fb00e
                ItemCount = Info->Value;
Packit Service 1fb00e
            }
Packit Service 1fb00e
            AcpiRsMoveData (Destination, Source, ItemCount, Info->Opcode);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_MOVE_GPIO_PIN:
Packit Service 1fb00e
Packit Service 1fb00e
            /* Generate and set the PIN data pointer */
Packit Service 1fb00e
Packit Service 1fb00e
            Target = (char *) ACPI_ADD_PTR (void, Resource,
Packit Service 1fb00e
                (Resource->Length - ItemCount * 2));
Packit Service 1fb00e
            *(UINT16 **) Destination = ACPI_CAST_PTR (UINT16, Target);
Packit Service 1fb00e
Packit Service 1fb00e
            /* Copy the PIN data */
Packit Service 1fb00e
Packit Service 1fb00e
            Source = ACPI_ADD_PTR (void, Aml, ACPI_GET16 (Source));
Packit Service 1fb00e
            AcpiRsMoveData (Target, Source, ItemCount, Info->Opcode);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_MOVE_GPIO_RES:
Packit Service 1fb00e
Packit Service 1fb00e
            /* Generate and set the ResourceSource string pointer */
Packit Service 1fb00e
Packit Service 1fb00e
            Target = (char *) ACPI_ADD_PTR (void, Resource,
Packit Service 1fb00e
                (Resource->Length - ItemCount));
Packit Service 1fb00e
            *(UINT8 **) Destination = ACPI_CAST_PTR (UINT8, Target);
Packit Service 1fb00e
Packit Service 1fb00e
            /* Copy the ResourceSource string */
Packit Service 1fb00e
Packit Service 1fb00e
            Source = ACPI_ADD_PTR (void, Aml, ACPI_GET16 (Source));
Packit Service 1fb00e
            AcpiRsMoveData (Target, Source, ItemCount, Info->Opcode);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_MOVE_SERIAL_VEN:
Packit Service 1fb00e
Packit Service 1fb00e
            /* Generate and set the Vendor Data pointer */
Packit Service 1fb00e
Packit Service 1fb00e
            Target = (char *) ACPI_ADD_PTR (void, Resource,
Packit Service 1fb00e
                (Resource->Length - ItemCount));
Packit Service 1fb00e
            *(UINT8 **) Destination = ACPI_CAST_PTR (UINT8, Target);
Packit Service 1fb00e
Packit Service 1fb00e
            /* Copy the Vendor Data */
Packit Service 1fb00e
Packit Service 1fb00e
            Source = ACPI_ADD_PTR (void, Aml, Info->Value);
Packit Service 1fb00e
            AcpiRsMoveData (Target, Source, ItemCount, Info->Opcode);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_MOVE_SERIAL_RES:
Packit Service 1fb00e
Packit Service 1fb00e
            /* Generate and set the ResourceSource string pointer */
Packit Service 1fb00e
Packit Service 1fb00e
            Target = (char *) ACPI_ADD_PTR (void, Resource,
Packit Service 1fb00e
                (Resource->Length - ItemCount));
Packit Service 1fb00e
            *(UINT8 **) Destination = ACPI_CAST_PTR (UINT8, Target);
Packit Service 1fb00e
Packit Service 1fb00e
            /* Copy the ResourceSource string */
Packit Service 1fb00e
Packit Service 1fb00e
            Source = ACPI_ADD_PTR (
Packit Service 1fb00e
                void, Aml, (ACPI_GET16 (Source) + Info->Value));
Packit Service 1fb00e
            AcpiRsMoveData (Target, Source, ItemCount, Info->Opcode);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_SET8:
Packit Service 1fb00e
Packit Service 1fb00e
            memset (Destination, Info->AmlOffset, Info->Value);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_DATA8:
Packit Service 1fb00e
Packit Service 1fb00e
            Target = ACPI_ADD_PTR (char, Resource, Info->Value);
Packit Service 1fb00e
            memcpy (Destination, Source,  ACPI_GET16 (Target));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_ADDRESS:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Common handler for address descriptor flags
Packit Service 1fb00e
             */
Packit Service 1fb00e
            if (!AcpiRsGetAddressCommon (Resource, Aml))
Packit Service 1fb00e
            {
Packit Service 1fb00e
                return_ACPI_STATUS (AE_AML_INVALID_RESOURCE_TYPE);
Packit Service 1fb00e
            }
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_SOURCE:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Optional ResourceSource (Index and String)
Packit Service 1fb00e
             */
Packit Service 1fb00e
            Resource->Length +=
Packit Service 1fb00e
                AcpiRsGetResourceSource (AmlResourceLength, Info->Value,
Packit Service 1fb00e
                    Destination, Aml, NULL);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_SOURCEX:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Optional ResourceSource (Index and String). This is the more
Packit Service 1fb00e
             * complicated case used by the Interrupt() macro
Packit Service 1fb00e
             */
Packit Service 1fb00e
            Target = ACPI_ADD_PTR (char, Resource,
Packit Service 1fb00e
                Info->AmlOffset + (ItemCount * 4));
Packit Service 1fb00e
Packit Service 1fb00e
            Resource->Length +=
Packit Service 1fb00e
                AcpiRsGetResourceSource (AmlResourceLength, (ACPI_RS_LENGTH)
Packit Service 1fb00e
                    (((ItemCount - 1) * sizeof (UINT32)) + Info->Value),
Packit Service 1fb00e
                    Destination, Aml, Target);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_BITMASK:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * 8-bit encoded bitmask (DMA macro)
Packit Service 1fb00e
             */
Packit Service 1fb00e
            ItemCount = AcpiRsDecodeBitmask (ACPI_GET8 (Source), Destination);
Packit Service 1fb00e
            if (ItemCount)
Packit Service 1fb00e
            {
Packit Service 1fb00e
                Resource->Length += (ItemCount - 1);
Packit Service 1fb00e
            }
Packit Service 1fb00e
Packit Service 1fb00e
            Target = ACPI_ADD_PTR (char, Resource, Info->Value);
Packit Service 1fb00e
            ACPI_SET8 (Target, ItemCount);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_BITMASK16:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * 16-bit encoded bitmask (IRQ macro)
Packit Service 1fb00e
             */
Packit Service 1fb00e
            ACPI_MOVE_16_TO_16 (&Temp16, Source);
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = AcpiRsDecodeBitmask (Temp16, Destination);
Packit Service 1fb00e
            if (ItemCount)
Packit Service 1fb00e
            {
Packit Service 1fb00e
                Resource->Length += (ItemCount - 1);
Packit Service 1fb00e
            }
Packit Service 1fb00e
Packit Service 1fb00e
            Target = ACPI_ADD_PTR (char, Resource, Info->Value);
Packit Service 1fb00e
            ACPI_SET8 (Target, ItemCount);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_EXIT_NE:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Control - Exit conversion if not equal
Packit Service 1fb00e
             */
Packit Service 1fb00e
            switch (Info->ResourceOffset)
Packit Service 1fb00e
            {
Packit Service 1fb00e
            case ACPI_RSC_COMPARE_AML_LENGTH:
Packit Service 1fb00e
Packit Service 1fb00e
                if (AmlResourceLength != Info->Value)
Packit Service 1fb00e
                {
Packit Service 1fb00e
                    goto Exit;
Packit Service 1fb00e
                }
Packit Service 1fb00e
                break;
Packit Service 1fb00e
Packit Service 1fb00e
            case ACPI_RSC_COMPARE_VALUE:
Packit Service 1fb00e
Packit Service 1fb00e
                if (ACPI_GET8 (Source) != Info->Value)
Packit Service 1fb00e
                {
Packit Service 1fb00e
                    goto Exit;
Packit Service 1fb00e
                }
Packit Service 1fb00e
                break;
Packit Service 1fb00e
Packit Service 1fb00e
            default:
Packit Service 1fb00e
Packit Service 1fb00e
                ACPI_ERROR ((AE_INFO, "Invalid conversion sub-opcode"));
Packit Service 1fb00e
                return_ACPI_STATUS (AE_BAD_PARAMETER);
Packit Service 1fb00e
            }
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        default:
Packit Service 1fb00e
Packit Service 1fb00e
            ACPI_ERROR ((AE_INFO, "Invalid conversion opcode"));
Packit Service 1fb00e
            return_ACPI_STATUS (AE_BAD_PARAMETER);
Packit Service 1fb00e
        }
Packit Service 1fb00e
Packit Service 1fb00e
        Count--;
Packit Service 1fb00e
        Info++;
Packit Service 1fb00e
    }
Packit Service 1fb00e
Packit Service 1fb00e
Exit:
Packit Service 1fb00e
    if (!FlagsMode)
Packit Service 1fb00e
    {
Packit Service 1fb00e
        /* Round the resource struct length up to the next boundary (32 or 64) */
Packit Service 1fb00e
Packit Service 1fb00e
        Resource->Length = (UINT32)
Packit Service 1fb00e
            ACPI_ROUND_UP_TO_NATIVE_WORD (Resource->Length);
Packit Service 1fb00e
    }
Packit Service 1fb00e
    return_ACPI_STATUS (AE_OK);
Packit Service 1fb00e
}
Packit Service 1fb00e
Packit Service 1fb00e
Packit Service 1fb00e
/*******************************************************************************
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * FUNCTION:    AcpiRsConvertResourceToAml
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * PARAMETERS:  Resource            - Pointer to the resource descriptor
Packit Service 1fb00e
 *              Aml                 - Where the AML descriptor is returned
Packit Service 1fb00e
 *              Info                - Pointer to appropriate conversion table
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * RETURN:      Status
Packit Service 1fb00e
 *
Packit Service 1fb00e
 * DESCRIPTION: Convert an internal resource descriptor to the corresponding
Packit Service 1fb00e
 *              external AML resource descriptor.
Packit Service 1fb00e
 *
Packit Service 1fb00e
 ******************************************************************************/
Packit Service 1fb00e
Packit Service 1fb00e
ACPI_STATUS
Packit Service 1fb00e
AcpiRsConvertResourceToAml (
Packit Service 1fb00e
    ACPI_RESOURCE           *Resource,
Packit Service 1fb00e
    AML_RESOURCE            *Aml,
Packit Service 1fb00e
    ACPI_RSCONVERT_INFO     *Info)
Packit Service 1fb00e
{
Packit Service 1fb00e
    void                    *Source = NULL;
Packit Service 1fb00e
    void                    *Destination;
Packit Service 1fb00e
    char                    *Target;
Packit Service 1fb00e
    ACPI_RSDESC_SIZE        AmlLength = 0;
Packit Service 1fb00e
    UINT8                   Count;
Packit Service 1fb00e
    UINT16                  Temp16 = 0;
Packit Service 1fb00e
    UINT16                  ItemCount = 0;
Packit Service 1fb00e
Packit Service 1fb00e
Packit Service 1fb00e
    ACPI_FUNCTION_TRACE (RsConvertResourceToAml);
Packit Service 1fb00e
Packit Service 1fb00e
Packit Service 1fb00e
    if (!Info)
Packit Service 1fb00e
    {
Packit Service 1fb00e
        return_ACPI_STATUS (AE_BAD_PARAMETER);
Packit Service 1fb00e
    }
Packit Service 1fb00e
Packit Service 1fb00e
    /*
Packit Service 1fb00e
     * First table entry must be ACPI_RSC_INITxxx and must contain the
Packit Service 1fb00e
     * table length (# of table entries)
Packit Service 1fb00e
     */
Packit Service 1fb00e
    Count = INIT_TABLE_LENGTH (Info);
Packit Service 1fb00e
Packit Service 1fb00e
    while (Count)
Packit Service 1fb00e
    {
Packit Service 1fb00e
        /*
Packit Service 1fb00e
         * Source is the internal resource descriptor,
Packit Service 1fb00e
         * destination is the external AML byte stream buffer
Packit Service 1fb00e
         */
Packit Service 1fb00e
        Source = ACPI_ADD_PTR (void, Resource, Info->ResourceOffset);
Packit Service 1fb00e
        Destination = ACPI_ADD_PTR (void, Aml, Info->AmlOffset);
Packit Service 1fb00e
Packit Service 1fb00e
        switch (Info->Opcode)
Packit Service 1fb00e
        {
Packit Service 1fb00e
        case ACPI_RSC_INITSET:
Packit Service 1fb00e
Packit Service 1fb00e
            memset (Aml, 0, INIT_RESOURCE_LENGTH (Info));
Packit Service 1fb00e
            AmlLength = INIT_RESOURCE_LENGTH (Info);
Packit Service 1fb00e
            AcpiRsSetResourceHeader (
Packit Service 1fb00e
                INIT_RESOURCE_TYPE (Info), AmlLength, Aml);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_INITGET:
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_FLAGINIT:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Clear the flag byte
Packit Service 1fb00e
             */
Packit Service 1fb00e
            ACPI_SET8 (Destination, 0);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_1BITFLAG:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Mask and shift the flag bit
Packit Service 1fb00e
             */
Packit Service 1fb00e
            ACPI_SET_BIT (*ACPI_CAST8 (Destination), (UINT8)
Packit Service 1fb00e
                ((ACPI_GET8 (Source) & 0x01) << Info->Value));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_2BITFLAG:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Mask and shift the flag bits
Packit Service 1fb00e
             */
Packit Service 1fb00e
            ACPI_SET_BIT (*ACPI_CAST8 (Destination), (UINT8)
Packit Service 1fb00e
                ((ACPI_GET8 (Source) & 0x03) << Info->Value));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_3BITFLAG:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Mask and shift the flag bits
Packit Service 1fb00e
             */
Packit Service 1fb00e
            ACPI_SET_BIT (*ACPI_CAST8 (Destination), (UINT8)
Packit Service 1fb00e
                ((ACPI_GET8 (Source) & 0x07) << Info->Value));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = ACPI_GET8 (Source);
Packit Service 1fb00e
            ACPI_SET8 (Destination, ItemCount);
Packit Service 1fb00e
Packit Service 1fb00e
            AmlLength = (UINT16)
Packit Service 1fb00e
                (AmlLength + (Info->Value * (ItemCount - 1)));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT16:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = ACPI_GET16 (Source);
Packit Service 1fb00e
            AmlLength = (UINT16) (AmlLength + ItemCount);
Packit Service 1fb00e
            AcpiRsSetResourceLength (AmlLength, Aml);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT_GPIO_PIN:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = ACPI_GET16 (Source);
Packit Service 1fb00e
            ACPI_SET16 (Destination, AmlLength);
Packit Service 1fb00e
Packit Service 1fb00e
            AmlLength = (UINT16) (AmlLength + ItemCount * 2);
Packit Service 1fb00e
            Target = ACPI_ADD_PTR (void, Aml, Info->Value);
Packit Service 1fb00e
            ACPI_SET16 (Target, AmlLength);
Packit Service 1fb00e
            AcpiRsSetResourceLength (AmlLength, Aml);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT_GPIO_VEN:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = ACPI_GET16 (Source);
Packit Service 1fb00e
            ACPI_SET16 (Destination, ItemCount);
Packit Service 1fb00e
Packit Service 1fb00e
            AmlLength = (UINT16) (
Packit Service 1fb00e
                AmlLength + (Info->Value * ItemCount));
Packit Service 1fb00e
            AcpiRsSetResourceLength (AmlLength, Aml);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT_GPIO_RES:
Packit Service 1fb00e
Packit Service 1fb00e
            /* Set resource source string length */
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = ACPI_GET16 (Source);
Packit Service 1fb00e
            ACPI_SET16 (Destination, AmlLength);
Packit Service 1fb00e
Packit Service 1fb00e
            /* Compute offset for the Vendor Data */
Packit Service 1fb00e
Packit Service 1fb00e
            AmlLength = (UINT16) (AmlLength + ItemCount);
Packit Service 1fb00e
            Target = ACPI_ADD_PTR (void, Aml, Info->Value);
Packit Service 1fb00e
Packit Service 1fb00e
            /* Set vendor offset only if there is vendor data */
Packit Service 1fb00e
Packit Service 1fb00e
            ACPI_SET16 (Target, AmlLength);
Packit Service 1fb00e
Packit Service 1fb00e
            AcpiRsSetResourceLength (AmlLength, Aml);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT_SERIAL_VEN:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = ACPI_GET16 (Source);
Packit Service 1fb00e
            ACPI_SET16 (Destination, ItemCount + Info->Value);
Packit Service 1fb00e
            AmlLength = (UINT16) (AmlLength + ItemCount);
Packit Service 1fb00e
            AcpiRsSetResourceLength (AmlLength, Aml);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_COUNT_SERIAL_RES:
Packit Service 1fb00e
Packit Service 1fb00e
            ItemCount = ACPI_GET16 (Source);
Packit Service 1fb00e
            AmlLength = (UINT16) (AmlLength + ItemCount);
Packit Service 1fb00e
            AcpiRsSetResourceLength (AmlLength, Aml);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_LENGTH:
Packit Service 1fb00e
Packit Service 1fb00e
            AcpiRsSetResourceLength (Info->Value, Aml);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_MOVE8:
Packit Service 1fb00e
        case ACPI_RSC_MOVE16:
Packit Service 1fb00e
        case ACPI_RSC_MOVE32:
Packit Service 1fb00e
        case ACPI_RSC_MOVE64:
Packit Service 1fb00e
Packit Service 1fb00e
            if (Info->Value)
Packit Service 1fb00e
            {
Packit Service 1fb00e
                ItemCount = Info->Value;
Packit Service 1fb00e
            }
Packit Service 1fb00e
            AcpiRsMoveData (Destination, Source, ItemCount, Info->Opcode);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_MOVE_GPIO_PIN:
Packit Service 1fb00e
Packit Service 1fb00e
            Destination = (char *) ACPI_ADD_PTR (void, Aml,
Packit Service 1fb00e
                ACPI_GET16 (Destination));
Packit Service 1fb00e
            Source = * (UINT16 **) Source;
Packit Service 1fb00e
            AcpiRsMoveData (Destination, Source, ItemCount, Info->Opcode);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_MOVE_GPIO_RES:
Packit Service 1fb00e
Packit Service 1fb00e
            /* Used for both ResourceSource string and VendorData */
Packit Service 1fb00e
Packit Service 1fb00e
            Destination = (char *) ACPI_ADD_PTR (void, Aml,
Packit Service 1fb00e
                ACPI_GET16 (Destination));
Packit Service 1fb00e
            Source = * (UINT8 **) Source;
Packit Service 1fb00e
            AcpiRsMoveData (Destination, Source, ItemCount, Info->Opcode);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_MOVE_SERIAL_VEN:
Packit Service 1fb00e
Packit Service 1fb00e
            Destination = (char *) ACPI_ADD_PTR (void, Aml,
Packit Service 1fb00e
                (AmlLength - ItemCount));
Packit Service 1fb00e
            Source = * (UINT8 **) Source;
Packit Service 1fb00e
            AcpiRsMoveData (Destination, Source, ItemCount, Info->Opcode);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_MOVE_SERIAL_RES:
Packit Service 1fb00e
Packit Service 1fb00e
            Destination = (char *) ACPI_ADD_PTR (void, Aml,
Packit Service 1fb00e
                (AmlLength - ItemCount));
Packit Service 1fb00e
            Source = * (UINT8 **) Source;
Packit Service 1fb00e
            AcpiRsMoveData (Destination, Source, ItemCount, Info->Opcode);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_ADDRESS:
Packit Service 1fb00e
Packit Service 1fb00e
            /* Set the Resource Type, General Flags, and Type-Specific Flags */
Packit Service 1fb00e
Packit Service 1fb00e
            AcpiRsSetAddressCommon (Aml, Resource);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_SOURCEX:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Optional ResourceSource (Index and String)
Packit Service 1fb00e
             */
Packit Service 1fb00e
            AmlLength = AcpiRsSetResourceSource (
Packit Service 1fb00e
                Aml, (ACPI_RS_LENGTH) AmlLength, Source);
Packit Service 1fb00e
            AcpiRsSetResourceLength (AmlLength, Aml);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_SOURCE:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Optional ResourceSource (Index and String). This is the more
Packit Service 1fb00e
             * complicated case used by the Interrupt() macro
Packit Service 1fb00e
             */
Packit Service 1fb00e
            AmlLength = AcpiRsSetResourceSource (Aml, Info->Value, Source);
Packit Service 1fb00e
            AcpiRsSetResourceLength (AmlLength, Aml);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_BITMASK:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * 8-bit encoded bitmask (DMA macro)
Packit Service 1fb00e
             */
Packit Service 1fb00e
            ACPI_SET8 (Destination,
Packit Service 1fb00e
                AcpiRsEncodeBitmask (Source,
Packit Service 1fb00e
                    *ACPI_ADD_PTR (UINT8, Resource, Info->Value)));
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_BITMASK16:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * 16-bit encoded bitmask (IRQ macro)
Packit Service 1fb00e
             */
Packit Service 1fb00e
            Temp16 = AcpiRsEncodeBitmask (
Packit Service 1fb00e
                Source, *ACPI_ADD_PTR (UINT8, Resource, Info->Value));
Packit Service 1fb00e
            ACPI_MOVE_16_TO_16 (Destination, &Temp16);
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_EXIT_LE:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Control - Exit conversion if less than or equal
Packit Service 1fb00e
             */
Packit Service 1fb00e
            if (ItemCount <= Info->Value)
Packit Service 1fb00e
            {
Packit Service 1fb00e
                goto Exit;
Packit Service 1fb00e
            }
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_EXIT_NE:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Control - Exit conversion if not equal
Packit Service 1fb00e
             */
Packit Service 1fb00e
            switch (COMPARE_OPCODE (Info))
Packit Service 1fb00e
            {
Packit Service 1fb00e
            case ACPI_RSC_COMPARE_VALUE:
Packit Service 1fb00e
Packit Service 1fb00e
                if (*ACPI_ADD_PTR (UINT8, Resource,
Packit Service 1fb00e
                    COMPARE_TARGET (Info)) != COMPARE_VALUE (Info))
Packit Service 1fb00e
                {
Packit Service 1fb00e
                    goto Exit;
Packit Service 1fb00e
                }
Packit Service 1fb00e
                break;
Packit Service 1fb00e
Packit Service 1fb00e
            default:
Packit Service 1fb00e
Packit Service 1fb00e
                ACPI_ERROR ((AE_INFO, "Invalid conversion sub-opcode"));
Packit Service 1fb00e
                return_ACPI_STATUS (AE_BAD_PARAMETER);
Packit Service 1fb00e
            }
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        case ACPI_RSC_EXIT_EQ:
Packit Service 1fb00e
            /*
Packit Service 1fb00e
             * Control - Exit conversion if equal
Packit Service 1fb00e
             */
Packit Service 1fb00e
            if (*ACPI_ADD_PTR (UINT8, Resource,
Packit Service 1fb00e
                COMPARE_TARGET (Info)) == COMPARE_VALUE (Info))
Packit Service 1fb00e
            {
Packit Service 1fb00e
                goto Exit;
Packit Service 1fb00e
            }
Packit Service 1fb00e
            break;
Packit Service 1fb00e
Packit Service 1fb00e
        default:
Packit Service 1fb00e
Packit Service 1fb00e
            ACPI_ERROR ((AE_INFO, "Invalid conversion opcode"));
Packit Service 1fb00e
            return_ACPI_STATUS (AE_BAD_PARAMETER);
Packit Service 1fb00e
        }
Packit Service 1fb00e
Packit Service 1fb00e
        Count--;
Packit Service 1fb00e
        Info++;
Packit Service 1fb00e
    }
Packit Service 1fb00e
Packit Service 1fb00e
Exit:
Packit Service 1fb00e
    return_ACPI_STATUS (AE_OK);
Packit Service 1fb00e
}
Packit Service 1fb00e
Packit Service 1fb00e
Packit Service 1fb00e
#if 0
Packit Service 1fb00e
/* Previous resource validations */
Packit Service 1fb00e
Packit Service 1fb00e
    if (Aml->ExtAddress64.RevisionID !=
Packit Service 1fb00e
        AML_RESOURCE_EXTENDED_ADDRESS_REVISION)
Packit Service 1fb00e
    {
Packit Service 1fb00e
        return_ACPI_STATUS (AE_SUPPORT);
Packit Service 1fb00e
    }
Packit Service 1fb00e
Packit Service 1fb00e
    if (Resource->Data.StartDpf.PerformanceRobustness >= 3)
Packit Service 1fb00e
    {
Packit Service 1fb00e
        return_ACPI_STATUS (AE_AML_BAD_RESOURCE_VALUE);
Packit Service 1fb00e
    }
Packit Service 1fb00e
Packit Service 1fb00e
    if (((Aml->Irq.Flags & 0x09) == 0x00) ||
Packit Service 1fb00e
        ((Aml->Irq.Flags & 0x09) == 0x09))
Packit Service 1fb00e
    {
Packit Service 1fb00e
        /*
Packit Service 1fb00e
         * Only [ActiveHigh, EdgeSensitive] or [ActiveLow, LevelSensitive]
Packit Service 1fb00e
         * polarity/trigger interrupts are allowed (ACPI spec, section
Packit Service 1fb00e
         * "IRQ Format"), so 0x00 and 0x09 are illegal.
Packit Service 1fb00e
         */
Packit Service 1fb00e
        ACPI_ERROR ((AE_INFO,
Packit Service 1fb00e
            "Invalid interrupt polarity/trigger in resource list, 0x%X",
Packit Service 1fb00e
            Aml->Irq.Flags));
Packit Service 1fb00e
        return_ACPI_STATUS (AE_BAD_DATA);
Packit Service 1fb00e
    }
Packit Service 1fb00e
Packit Service 1fb00e
    Resource->Data.ExtendedIrq.InterruptCount = Temp8;
Packit Service 1fb00e
    if (Temp8 < 1)
Packit Service 1fb00e
    {
Packit Service 1fb00e
        /* Must have at least one IRQ */
Packit Service 1fb00e
Packit Service 1fb00e
        return_ACPI_STATUS (AE_AML_BAD_RESOURCE_LENGTH);
Packit Service 1fb00e
    }
Packit Service 1fb00e
Packit Service 1fb00e
    if (Resource->Data.Dma.Transfer == 0x03)
Packit Service 1fb00e
    {
Packit Service 1fb00e
        ACPI_ERROR ((AE_INFO,
Packit Service 1fb00e
            "Invalid DMA.Transfer preference (3)"));
Packit Service 1fb00e
        return_ACPI_STATUS (AE_BAD_DATA);
Packit Service 1fb00e
    }
Packit Service 1fb00e
#endif