[prev in list] [next in list] [prev in thread] [next in thread] 

List:       fwts-devel
Subject:    Re: [PATCH] ACPICA: update to version 20131218 (LP: #1262348)
From:       Keng-Yu Lin <kengyu () canonical ! com>
Date:       2013-12-20 9:16:59
Message-ID: CADXHx7Yk0r4HGHqW8Hy56xht2fR5atyRRr3+dOCyg2MpO5JEuw () mail ! gmail ! com
[Download RAW message or body]

On Thu, Dec 19, 2013 at 3:56 AM, Colin King <colin.king@canonical.com> wrote:
> From: Colin Ian King <colin.king@canonical.com>
> 
> This includes APCICA commit a9ca6dbd2f1db4bbbdce0be57800beef002c7351
> which reverts an acpiexec hang on some DSDTs and SSDTs.
> 
> Signed-off-by: Colin Ian King <colin.king@canonical.com>
> ---
> src/acpica/source/common/adfile.c                  |   5 +-
> src/acpica/source/common/adwalk.c                  |  68 ++-
> src/acpica/source/common/dmextern.c                | 571 ++++++++++++---------
> src/acpica/source/common/dmtable.c                 |  34 +-
> src/acpica/source/common/dmtbdump.c                |  31 +-
> src/acpica/source/common/dmtbinfo.c                |  27 +-
> src/acpica/source/compiler/aslbtypes.c             |   2 +-
> src/acpica/source/compiler/asldefine.h             |   2 +-
> src/acpica/source/compiler/aslerror.c              |  13 +-
> src/acpica/source/compiler/aslfiles.c              |   1 +
> src/acpica/source/compiler/aslglobal.h             |   2 +-
> src/acpica/source/compiler/asllookup.c             |  56 +-
> src/acpica/source/compiler/aslmain.c               |  28 +-
> src/acpica/source/compiler/aslmessages.h           |   2 +-
> src/acpica/source/compiler/asloperands.c           |   1 +
> src/acpica/source/compiler/aslopt.c                |  17 +-
> src/acpica/source/compiler/aslstartup.c            |   1 +
> src/acpica/source/compiler/aslstubs.c              |   2 +-
> src/acpica/source/compiler/aslxref.c               |  24 +-
> src/acpica/source/compiler/dtcompile.c             |   9 +
> src/acpica/source/compiler/dtcompiler.h            |  10 +
> src/acpica/source/compiler/dtfield.c               |   3 +-
> src/acpica/source/compiler/dttable.c               | 229 +++++++++
> src/acpica/source/compiler/dttemplate.h            |  59 ++-
> src/acpica/source/compiler/dtutils.c               |   1 +
> src/acpica/source/components/debugger/dbfileio.c   |  10 -
> src/acpica/source/components/debugger/dbinput.c    |   6 +-
> src/acpica/source/components/dispatcher/dsfield.c  |   2 +-
> src/acpica/source/components/dispatcher/dsutils.c  |  16 +-
> src/acpica/source/components/dispatcher/dswexec.c  |   3 +-
> src/acpica/source/components/dispatcher/dswload.c  |   2 +-
> src/acpica/source/components/events/evgpeblk.c     |   7 +-
> src/acpica/source/components/events/evgpeutil.c    |  21 +-
> src/acpica/source/components/executer/exresnte.c   |   4 +-
> src/acpica/source/components/namespace/nsxfeval.c  |  16 +-
> src/acpica/source/components/parser/psopinfo.c     |  52 +-
> src/acpica/source/components/tables/tbfadt.c       | 313 ++++++-----
> src/acpica/source/components/tables/tbutils.c      | 150 +++++-
> src/acpica/source/components/utilities/utaddress.c |  14 +-
> src/acpica/source/components/utilities/utalloc.c   |  10 +-
> src/acpica/source/components/utilities/utcache.c   |  12 +-
> src/acpica/source/components/utilities/utdebug.c   |   4 +-
> src/acpica/source/components/utilities/utxfinit.c  |  12 +-
> src/acpica/source/include/acdisasm.h               |  25 +-
> src/acpica/source/include/acevents.h               |   5 +-
> src/acpica/source/include/acglobal.h               |  32 ++
> src/acpica/source/include/aclocal.h                |  10 +-
> src/acpica/source/include/acpixf.h                 |  18 +-
> src/acpica/source/include/actbl.h                  |   3 +
> src/acpica/source/include/actbl1.h                 |  10 +-
> src/acpica/source/include/actbl2.h                 |   8 +
> src/acpica/source/include/actbl3.h                 |  16 +-
> src/acpica/source/include/actypes.h                |   8 +-
> src/acpica/source/include/platform/acenv.h         |  20 +-
> src/acpica/source/include/platform/aclinux.h       |   8 -
> .../source/os_specific/service_layers/osunixxf.c   |   1 -
> src/acpica/source/tools/acpiexec/aecommon.h        |   1 -
> src/acpica/source/tools/acpiexec/aehandlers.c      |  14 +-
> 58 files changed, 1409 insertions(+), 622 deletions(-)
> 
> diff --git a/src/acpica/source/common/adfile.c b/src/acpica/source/common/adfile.c
> index d598ac8..fc2d815 100644
> --- a/src/acpica/source/common/adfile.c
> +++ b/src/acpica/source/common/adfile.c
> @@ -271,6 +271,7 @@ FlGenerateFilename (
> {
> char                    *Position;
> char                    *NewFilename;
> +    char                    *DirectoryPosition;
> 
> 
> /*
> @@ -283,8 +284,10 @@ FlGenerateFilename (
> 
> /* Try to find the last dot in the filename */
> 
> +    DirectoryPosition = strrchr (NewFilename, '/');
> Position = strrchr (NewFilename, '.');
> -    if (Position)
> +
> +    if (Position && (Position > DirectoryPosition))
> {
> /* Tack on the new suffix */
> 
> diff --git a/src/acpica/source/common/adwalk.c b/src/acpica/source/common/adwalk.c
> index 2d380f4..932c88f 100644
> --- a/src/acpica/source/common/adwalk.c
> +++ b/src/acpica/source/common/adwalk.c
> @@ -541,8 +541,9 @@ AcpiDmFindOrphanDescending (
> !ChildOp->Common.Node)
> {
> AcpiNsExternalizeName (ACPI_UINT32_MAX, ChildOp->Common.Value.String,
> -                            NULL, &Path);
> -            AcpiOsPrintf ("/* %-16s A-NAMEPATH: %s  */\n", Op->Common.AmlOpName, \
> Path); +                NULL, &Path);
> +            AcpiOsPrintf ("/* %-16s A-NAMEPATH: %s  */\n",
> +                Op->Common.AmlOpName, Path);
> ACPI_FREE (Path);
> 
> NextOp = Op->Common.Next;
> @@ -550,22 +551,26 @@ AcpiDmFindOrphanDescending (
> {
> /* This NamePath has no args, assume it is an integer */
> 
> -                AcpiDmAddToExternalList (ChildOp, ChildOp->Common.Value.String, \
> ACPI_TYPE_INTEGER, 0); +                AcpiDmAddOpToExternalList (ChildOp,
> +                    ChildOp->Common.Value.String, ACPI_TYPE_INTEGER, 0, 0);
> return (AE_OK);
> }
> 
> ArgCount = AcpiDmInspectPossibleArgs (3, 1, NextOp);
> -            AcpiOsPrintf ("/* A-CHILDREN: %u Actual %u */\n", ArgCount, \
> AcpiDmCountChildren (Op)); +            AcpiOsPrintf ("/* A-CHILDREN: %u Actual %u \
> */\n", +                ArgCount, AcpiDmCountChildren (Op));
> 
> if (ArgCount < 1)
> {
> /* One Arg means this is just a Store(Name,Target) */
> 
> -                AcpiDmAddToExternalList (ChildOp, ChildOp->Common.Value.String, \
> ACPI_TYPE_INTEGER, 0); +                AcpiDmAddOpToExternalList (ChildOp,
> +                    ChildOp->Common.Value.String, ACPI_TYPE_INTEGER, 0, 0);
> return (AE_OK);
> }
> 
> -            AcpiDmAddToExternalList (ChildOp, ChildOp->Common.Value.String, \
> ACPI_TYPE_METHOD, ArgCount); +            AcpiDmAddOpToExternalList (ChildOp,
> +                ChildOp->Common.Value.String, ACPI_TYPE_METHOD, ArgCount, 0);
> }
> break;
> #endif
> @@ -581,7 +586,8 @@ AcpiDmFindOrphanDescending (
> {
> /* This NamePath has no args, assume it is an integer */
> 
> -                AcpiDmAddToExternalList (ChildOp, ChildOp->Common.Value.String, \
> ACPI_TYPE_INTEGER, 0); +                AcpiDmAddOpToExternalList (ChildOp,
> +                    ChildOp->Common.Value.String, ACPI_TYPE_INTEGER, 0, 0);
> return (AE_OK);
> }
> 
> @@ -590,11 +596,13 @@ AcpiDmFindOrphanDescending (
> {
> /* One Arg means this is just a Store(Name,Target) */
> 
> -                AcpiDmAddToExternalList (ChildOp, ChildOp->Common.Value.String, \
> ACPI_TYPE_INTEGER, 0); +                AcpiDmAddOpToExternalList (ChildOp,
> +                    ChildOp->Common.Value.String, ACPI_TYPE_INTEGER, 0, 0);
> return (AE_OK);
> }
> 
> -            AcpiDmAddToExternalList (ChildOp, ChildOp->Common.Value.String, \
> ACPI_TYPE_METHOD, ArgCount); +            AcpiDmAddOpToExternalList (ChildOp,
> +                ChildOp->Common.Value.String, ACPI_TYPE_METHOD, ArgCount, 0);
> }
> break;
> 
> @@ -626,7 +634,8 @@ AcpiDmFindOrphanDescending (
> /* And namepath is the first argument */
> (ParentOp->Common.Value.Arg == Op))
> {
> -                    AcpiDmAddToExternalList (Op, Op->Common.Value.String, \
> ACPI_TYPE_INTEGER, 0); +                    AcpiDmAddOpToExternalList (Op,
> +                        Op->Common.Value.String, ACPI_TYPE_INTEGER, 0, 0);
> break;
> }
> }
> @@ -636,8 +645,8 @@ AcpiDmFindOrphanDescending (
> * operator) - it *must* be a method invocation, nothing else is
> * grammatically possible.
> */
> -            AcpiDmAddToExternalList (Op, Op->Common.Value.String, \
>                 ACPI_TYPE_METHOD, ArgCount);
> -
> +            AcpiDmAddOpToExternalList (Op,
> +                Op->Common.Value.String, ACPI_TYPE_METHOD, ArgCount, 0);
> }
> break;
> 
> @@ -813,6 +822,7 @@ AcpiDmXrefDescendingOp (
> ACPI_NAMESPACE_NODE     *Node;
> ACPI_OPERAND_OBJECT     *Object;
> UINT32                  ParamCount = 0;
> +    char                    *Pathname;
> 
> 
> WalkState = Info->WalkState;
> @@ -880,11 +890,14 @@ AcpiDmXrefDescendingOp (
> * The namespace is also used as a lookup table for references to resource
> * descriptors and the fields within them.
> */
> +    Node = NULL;
> Status = AcpiNsLookup (WalkState->ScopeInfo, Path, ACPI_TYPE_ANY,
> ACPI_IMODE_EXECUTE, ACPI_NS_SEARCH_PARENT | ACPI_NS_DONT_OPEN_SCOPE,
> WalkState, &Node);
> if (ACPI_SUCCESS (Status) && (Node->Flags & ANOBJ_IS_EXTERNAL))
> {
> +        /* Node was created by an External() statement */
> +
> Status = AE_NOT_FOUND;
> }
> 
> @@ -902,16 +915,28 @@ AcpiDmXrefDescendingOp (
> if (!(Op->Asl.Parent &&
> (Op->Asl.Parent->Asl.AmlOpcode == AML_COND_REF_OF_OP)))
> {
> -                AcpiDmAddToExternalList (Op, Path, (UINT8) ObjectType, 0);
> +                if (Node)
> +                {
> +                    AcpiDmAddNodeToExternalList (Node,
> +                        (UINT8) ObjectType, 0, 0);
> +                }
> +                else
> +                {
> +                    AcpiDmAddOpToExternalList (Op, Path,
> +                        (UINT8) ObjectType, 0, 0);
> +                }
> }
> }
> }
> 
> /*
> -     * Found the node in external table, add it to external list
> -     * Node->OwnerId == 0 indicates built-in ACPI Names, _OS_ etc
> +     * Found the node, but check if it came from an external table.
> +     * Add it to external list. Note: Node->OwnerId == 0 indicates
> +     * one of the built-in ACPI Names (_OS_ etc.) which can safely
> +     * be ignored.
> */
> -    else if (Node->OwnerId && WalkState->OwnerId != Node->OwnerId)
> +    else if (Node->OwnerId &&
> +            (WalkState->OwnerId != Node->OwnerId))
> {
> ObjectType2 = ObjectType;
> 
> @@ -925,7 +950,16 @@ AcpiDmXrefDescendingOp (
> }
> }
> 
> -        AcpiDmAddToExternalList (Op, Path, (UINT8) ObjectType2, ParamCount | \
> 0x80); +        Pathname = AcpiNsGetExternalPathname (Node);
> +        if (!Pathname)
> +        {
> +            return (AE_NO_MEMORY);
> +        }
> +
> +        AcpiDmAddNodeToExternalList (Node, (UINT8) ObjectType2,
> +            ParamCount, ACPI_EXT_RESOLVED_REFERENCE);
> +
> +        ACPI_FREE (Pathname);
> Op->Common.Node = Node;
> }
> else
> diff --git a/src/acpica/source/common/dmextern.c \
> b/src/acpica/source/common/dmextern.c index 5b3a8b1..f6b32f1 100644
> --- a/src/acpica/source/common/dmextern.c
> +++ b/src/acpica/source/common/dmextern.c
> @@ -176,10 +176,19 @@ AcpiDmNormalizeParentPrefix (
> char                    *Path);
> 
> static void
> -AcpiDmAddToExternalListFromFile (
> +AcpiDmAddPathToExternalList (
> char                    *Path,
> UINT8                   Type,
> -    UINT32                  Value);
> +    UINT32                  Value,
> +    UINT16                  Flags);
> +
> +static ACPI_STATUS
> +AcpiDmCreateNewExternal (
> +    char                    *ExternalPath,
> +    char                    *InternalPath,
> +    UINT8                   Type,
> +    UINT32                  Value,
> +    UINT16                  Flags);
> 
> 
> /*******************************************************************************
> @@ -421,196 +430,6 @@ AcpiDmClearExternalFileList (
> 
> /*******************************************************************************
> *
> - * FUNCTION:    AcpiDmAddToExternalList
> - *
> - * PARAMETERS:  Op                  - Current parser Op
> - *              Path                - Internal (AML) path to the object
> - *              Type                - ACPI object type to be added
> - *              Value               - Arg count if adding a Method object
> - *
> - * RETURN:      None
> - *
> - * DESCRIPTION: Insert a new name into the global list of Externals which
> - *              will in turn be later emitted as an External() declaration
> - *              in the disassembled output.
> - *
> - ******************************************************************************/
> -
> -void
> -AcpiDmAddToExternalList (
> -    ACPI_PARSE_OBJECT       *Op,
> -    char                    *Path,
> -    UINT8                   Type,
> -    UINT32                  Value)
> -{
> -    char                    *ExternalPath;
> -    char                    *Fullpath = NULL;
> -    ACPI_EXTERNAL_LIST      *NewExternal;
> -    ACPI_EXTERNAL_LIST      *NextExternal;
> -    ACPI_EXTERNAL_LIST      *PrevExternal = NULL;
> -    ACPI_STATUS             Status;
> -    BOOLEAN                 Resolved = FALSE;
> -
> -
> -    if (!Path)
> -    {
> -        return;
> -    }
> -
> -    if (Type == ACPI_TYPE_METHOD)
> -    {
> -        if (Value & 0x80)
> -        {
> -            Resolved = TRUE;
> -        }
> -        Value &= 0x07;
> -    }
> -
> -    /*
> -     * We don't want External() statements to contain a leading '\'.
> -     * This prevents duplicate external statements of the form:
> -     *
> -     *    External (\ABCD)
> -     *    External (ABCD)
> -     *
> -     * This would cause a compile time error when the disassembled
> -     * output file is recompiled.
> -     */
> -    if ((*Path == AML_ROOT_PREFIX) && (Path[1]))
> -    {
> -        Path++;
> -    }
> -
> -    /* Externalize the ACPI pathname */
> -
> -    Status = AcpiNsExternalizeName (ACPI_UINT32_MAX, Path,
> -                NULL, &ExternalPath);
> -    if (ACPI_FAILURE (Status))
> -    {
> -        return;
> -    }
> -
> -    /*
> -     * Get the full pathname from the root if "Path" has one or more
> -     * parent prefixes (^). Note: path will not contain a leading '\'.
> -     */
> -    if (*Path == (UINT8) AML_PARENT_PREFIX)
> -    {
> -        Fullpath = AcpiDmNormalizeParentPrefix (Op, ExternalPath);
> -        if (Fullpath)
> -        {
> -            /* Set new external path */
> -
> -            ACPI_FREE (ExternalPath);
> -            ExternalPath = Fullpath;
> -        }
> -    }
> -
> -    /* Check all existing externals to ensure no duplicates */
> -
> -    NextExternal = AcpiGbl_ExternalList;
> -    while (NextExternal)
> -    {
> -        if (!ACPI_STRCMP (ExternalPath, NextExternal->Path))
> -        {
> -            /* Duplicate method, check that the Value (ArgCount) is the same */
> -
> -            if ((NextExternal->Type == ACPI_TYPE_METHOD) &&
> -                (NextExternal->Value != Value))
> -            {
> -                ACPI_ERROR ((AE_INFO,
> -                    "External method arg count mismatch %s: Current %u, attempted \
>                 %u",
> -                    NextExternal->Path, NextExternal->Value, Value));
> -            }
> -
> -            /* Allow upgrade of type from ANY */
> -
> -            else if (NextExternal->Type == ACPI_TYPE_ANY)
> -            {
> -                NextExternal->Type = Type;
> -                NextExternal->Value = Value;
> -            }
> -
> -            ACPI_FREE (ExternalPath);
> -            return;
> -        }
> -
> -        NextExternal = NextExternal->Next;
> -    }
> -
> -    /* Allocate and init a new External() descriptor */
> -
> -    NewExternal = ACPI_ALLOCATE_ZEROED (sizeof (ACPI_EXTERNAL_LIST));
> -    if (!NewExternal)
> -    {
> -        ACPI_FREE (ExternalPath);
> -        return;
> -    }
> -
> -    NewExternal->Path = ExternalPath;
> -    NewExternal->Type = Type;
> -    NewExternal->Value = Value;
> -    NewExternal->Resolved = Resolved;
> -    NewExternal->Length = (UINT16) ACPI_STRLEN (ExternalPath);
> -
> -    /* Was the external path with parent prefix normalized to a fullpath? */
> -
> -    if (Fullpath == ExternalPath)
> -    {
> -        /* Get new internal path */
> -
> -        Status = AcpiNsInternalizeName (ExternalPath, &Path);
> -        if (ACPI_FAILURE (Status))
> -        {
> -            ACPI_FREE (ExternalPath);
> -            ACPI_FREE (NewExternal);
> -            return;
> -        }
> -
> -        /* Set flag to indicate External->InternalPath need to be freed */
> -
> -        NewExternal->Flags |= ACPI_IPATH_ALLOCATED;
> -    }
> -
> -    NewExternal->InternalPath = Path;
> -
> -    /* Link the new descriptor into the global list, alphabetically ordered */
> -
> -    NextExternal = AcpiGbl_ExternalList;
> -    while (NextExternal)
> -    {
> -        if (AcpiUtStricmp (NewExternal->Path, NextExternal->Path) < 0)
> -        {
> -            if (PrevExternal)
> -            {
> -                PrevExternal->Next = NewExternal;
> -            }
> -            else
> -            {
> -                AcpiGbl_ExternalList = NewExternal;
> -            }
> -
> -            NewExternal->Next = NextExternal;
> -            return;
> -        }
> -
> -        PrevExternal = NextExternal;
> -        NextExternal = NextExternal->Next;
> -    }
> -
> -    if (PrevExternal)
> -    {
> -        PrevExternal->Next = NewExternal;
> -    }
> -    else
> -    {
> -        AcpiGbl_ExternalList = NewExternal;
> -    }
> -}
> -
> -
> -/*******************************************************************************
> - *
> * FUNCTION:    AcpiDmGetExternalsFromFile
> *
> * PARAMETERS:  None
> @@ -691,7 +510,8 @@ AcpiDmGetExternalsFromFile (
> AcpiOsPrintf ("%s: Importing method external (%u arguments) %s\n",
> Gbl_ExternalRefFilename, ArgCount, MethodName);
> 
> -        AcpiDmAddToExternalListFromFile (MethodName, ACPI_TYPE_METHOD, ArgCount | \
> 0x80); +        AcpiDmAddPathToExternalList (MethodName, ACPI_TYPE_METHOD,
> +            ArgCount, (ACPI_EXT_RESOLVED_REFERENCE | ACPI_EXT_ORIGIN_FROM_FILE));
> ImportCount++;
> }
> 
> @@ -716,11 +536,13 @@ AcpiDmGetExternalsFromFile (
> 
> /*******************************************************************************
> *
> - * FUNCTION:    AcpiDmAddToExternalListFromFile
> + * FUNCTION:    AcpiDmAddOpToExternalList
> *
> - * PARAMETERS:  Path                - Internal (AML) path to the object
> + * PARAMETERS:  Op                  - Current parser Op
> + *              Path                - Internal (AML) path to the object
> *              Type                - ACPI object type to be added
> *              Value               - Arg count if adding a Method object
> + *              Flags               - To be passed to the external object
> *
> * RETURN:      None
> *
> @@ -728,60 +550,315 @@ AcpiDmGetExternalsFromFile (
> *              will in turn be later emitted as an External() declaration
> *              in the disassembled output.
> *
> + *              This function handles the most common case where the referenced
> + *              name is simply not found in the constructed namespace.
> + *
> ******************************************************************************/
> 
> -static void
> -AcpiDmAddToExternalListFromFile (
> +void
> +AcpiDmAddOpToExternalList (
> +    ACPI_PARSE_OBJECT       *Op,
> char                    *Path,
> UINT8                   Type,
> -    UINT32                  Value)
> +    UINT32                  Value,
> +    UINT16                  Flags)
> {
> -    char                    *InternalPath;
> char                    *ExternalPath;
> -    ACPI_EXTERNAL_LIST      *NewExternal;
> -    ACPI_EXTERNAL_LIST      *NextExternal;
> -    ACPI_EXTERNAL_LIST      *PrevExternal = NULL;
> +    char                    *InternalPath = Path;
> +    char                    *Temp;
> ACPI_STATUS             Status;
> -    BOOLEAN                 Resolved = FALSE;
> +
> +
> +    ACPI_FUNCTION_TRACE (DmAddOpToExternalList);
> 
> 
> if (!Path)
> {
> -        return;
> +        return_VOID;
> }
> 
> -    /* TBD: Add a flags parameter */
> +    /* Remove a root backslash if present */
> 
> -    if (Type == ACPI_TYPE_METHOD)
> +    if ((*Path == AML_ROOT_PREFIX) && (Path[1]))
> {
> -        if (Value & 0x80)
> -        {
> -            Resolved = TRUE;
> -        }
> -        Value &= 0x07;
> +        Path++;
> +    }
> +
> +    /* Externalize the pathname */
> +
> +    Status = AcpiNsExternalizeName (ACPI_UINT32_MAX, Path,
> +        NULL, &ExternalPath);
> +    if (ACPI_FAILURE (Status))
> +    {
> +        return_VOID;
> }
> 
> /*
> -     * We don't want External() statements to contain a leading '\'.
> -     * This prevents duplicate external statements of the form:
> -     *
> -     *    External (\ABCD)
> -     *    External (ABCD)
> -     *
> -     * This would cause a compile time error when the disassembled
> -     * output file is recompiled.
> +     * Get the full pathname from the root if "Path" has one or more
> +     * parent prefixes (^). Note: path will not contain a leading '\'.
> */
> +    if (*Path == (UINT8) AML_PARENT_PREFIX)
> +    {
> +        Temp = AcpiDmNormalizeParentPrefix (Op, ExternalPath);
> +
> +        /* Set new external path */
> +
> +        ACPI_FREE (ExternalPath);
> +        ExternalPath = Temp;
> +        if (!Temp)
> +        {
> +            return_VOID;
> +        }
> +
> +        /* Create the new internal pathname */
> +
> +        Flags |= ACPI_EXT_INTERNAL_PATH_ALLOCATED;
> +        Status = AcpiNsInternalizeName (ExternalPath, &InternalPath);
> +        if (ACPI_FAILURE (Status))
> +        {
> +            ACPI_FREE (ExternalPath);
> +            return_VOID;
> +        }
> +    }
> +
> +    /* Create the new External() declaration node */
> +
> +    Status = AcpiDmCreateNewExternal (ExternalPath, InternalPath,
> +        Type, Value, Flags);
> +    if (ACPI_FAILURE (Status))
> +    {
> +        ACPI_FREE (ExternalPath);
> +        if (Flags & ACPI_EXT_INTERNAL_PATH_ALLOCATED)
> +        {
> +            ACPI_FREE (InternalPath);
> +        }
> +    }
> +
> +    return_VOID;
> +}
> +
> +
> +/*******************************************************************************
> + *
> + * FUNCTION:    AcpiDmAddNodeToExternalList
> + *
> + * PARAMETERS:  Node                - Namespace node for object to be added
> + *              Type                - ACPI object type to be added
> + *              Value               - Arg count if adding a Method object
> + *              Flags               - To be passed to the external object
> + *
> + * RETURN:      None
> + *
> + * DESCRIPTION: Insert a new name into the global list of Externals which
> + *              will in turn be later emitted as an External() declaration
> + *              in the disassembled output.
> + *
> + *              This function handles the case where the referenced name has
> + *              been found in the namespace, but the name originated in a
> + *              table other than the one that is being disassembled (such
> + *              as a table that is added via the iASL -e option).
> + *
> + ******************************************************************************/
> +
> +void
> +AcpiDmAddNodeToExternalList (
> +    ACPI_NAMESPACE_NODE     *Node,
> +    UINT8                   Type,
> +    UINT32                  Value,
> +    UINT16                  Flags)
> +{
> +    char                    *ExternalPath;
> +    char                    *InternalPath;
> +    char                    *Temp;
> +    ACPI_STATUS             Status;
> +
> +
> +    ACPI_FUNCTION_TRACE (DmAddNodeToExternalList);
> +
> +
> +    if (!Node)
> +    {
> +        return_VOID;
> +    }
> +
> +    /* Get the full external and internal pathnames to the node */
> +
> +    ExternalPath = AcpiNsGetExternalPathname (Node);
> +    if (!ExternalPath)
> +    {
> +        return_VOID;
> +    }
> +
> +    Status = AcpiNsInternalizeName (ExternalPath, &InternalPath);
> +    if (ACPI_FAILURE (Status))
> +    {
> +        ACPI_FREE (ExternalPath);
> +        return_VOID;
> +    }
> +
> +    /* Remove the root backslash */
> +
> +    if ((*ExternalPath == AML_ROOT_PREFIX) && (ExternalPath[1]))
> +    {
> +        Temp = ACPI_ALLOCATE_ZEROED (ACPI_STRLEN (ExternalPath) + 1);
> +        if (!Temp)
> +        {
> +            return_VOID;
> +        }
> +
> +        ACPI_STRCPY (Temp, &ExternalPath[1]);
> +        ACPI_FREE (ExternalPath);
> +        ExternalPath = Temp;
> +    }
> +
> +    /* Create the new External() declaration node */
> +
> +    Status = AcpiDmCreateNewExternal (ExternalPath, InternalPath, Type,
> +        Value, (Flags | ACPI_EXT_INTERNAL_PATH_ALLOCATED));
> +    if (ACPI_FAILURE (Status))
> +    {
> +        ACPI_FREE (ExternalPath);
> +        ACPI_FREE (InternalPath);
> +    }
> +
> +    return_VOID;
> +}
> +
> +
> +/*******************************************************************************
> + *
> + * FUNCTION:    AcpiDmAddPathToExternalList
> + *
> + * PARAMETERS:  Path                - External name of the object to be added
> + *              Type                - ACPI object type to be added
> + *              Value               - Arg count if adding a Method object
> + *              Flags               - To be passed to the external object
> + *
> + * RETURN:      None
> + *
> + * DESCRIPTION: Insert a new name into the global list of Externals which
> + *              will in turn be later emitted as an External() declaration
> + *              in the disassembled output.
> + *
> + *              This function currently is used to add externals via a
> + *              reference file (via the -fe iASL option).
> + *
> + ******************************************************************************/
> +
> +static void
> +AcpiDmAddPathToExternalList (
> +    char                    *Path,
> +    UINT8                   Type,
> +    UINT32                  Value,
> +    UINT16                  Flags)
> +{
> +    char                    *InternalPath;
> +    char                    *ExternalPath;
> +    ACPI_STATUS             Status;
> +
> +
> +    ACPI_FUNCTION_TRACE (DmAddPathToExternalList);
> +
> +
> +    if (!Path)
> +    {
> +        return_VOID;
> +    }
> +
> +    /* Remove a root backslash if present */
> +
> if ((*Path == AML_ROOT_PREFIX) && (Path[1]))
> {
> Path++;
> }
> 
> +    /* Create the internal and external pathnames */
> +
> +    Status = AcpiNsInternalizeName (Path, &InternalPath);
> +    if (ACPI_FAILURE (Status))
> +    {
> +        return_VOID;
> +    }
> +
> +    Status = AcpiNsExternalizeName (ACPI_UINT32_MAX, InternalPath,
> +        NULL, &ExternalPath);
> +    if (ACPI_FAILURE (Status))
> +    {
> +        ACPI_FREE (InternalPath);
> +        return_VOID;
> +    }
> +
> +    /* Create the new External() declaration node */
> +
> +    Status = AcpiDmCreateNewExternal (ExternalPath, InternalPath,
> +        Type, Value, (Flags | ACPI_EXT_INTERNAL_PATH_ALLOCATED));
> +    if (ACPI_FAILURE (Status))
> +    {
> +        ACPI_FREE (ExternalPath);
> +        ACPI_FREE (InternalPath);
> +    }
> +
> +    return_VOID;
> +}
> +
> +
> +/*******************************************************************************
> + *
> + * FUNCTION:    AcpiDmCreateNewExternal
> + *
> + * PARAMETERS:  ExternalPath        - External path to the object
> + *              InternalPath        - Internal (AML) path to the object
> + *              Type                - ACPI object type to be added
> + *              Value               - Arg count if adding a Method object
> + *              Flags               - To be passed to the external object
> + *
> + * RETURN:      Status
> + *
> + * DESCRIPTION: Common low-level function to insert a new name into the global
> + *              list of Externals which will in turn be later emitted as
> + *              External() declarations in the disassembled output.
> + *
> + *              Note: The external name should not include a root prefix
> + *              (backslash). We do not want External() statements to contain
> + *              a leading '\', as this prevents duplicate external statements
> + *              of the form:
> + *
> + *                  External (\ABCD)
> + *                  External (ABCD)
> + *
> + *              This would cause a compile time error when the disassembled
> + *              output file is recompiled.
> + *
> + *              There are two cases that are handled here. For both, we emit
> + *              an External() statement:
> + *              1) The name was simply not found in the namespace.
> + *              2) The name was found, but it originated in a table other than
> + *              the table that is being disassembled.
> + *
> + ******************************************************************************/
> +
> +static ACPI_STATUS
> +AcpiDmCreateNewExternal (
> +    char                    *ExternalPath,
> +    char                    *InternalPath,
> +    UINT8                   Type,
> +    UINT32                  Value,
> +    UINT16                  Flags)
> +{
> +    ACPI_EXTERNAL_LIST      *NewExternal;
> +    ACPI_EXTERNAL_LIST      *NextExternal;
> +    ACPI_EXTERNAL_LIST      *PrevExternal = NULL;
> +
> +
> +    ACPI_FUNCTION_TRACE (DmCreateNewExternal);
> +
> +
> /* Check all existing externals to ensure no duplicates */
> 
> NextExternal = AcpiGbl_ExternalList;
> while (NextExternal)
> {
> -        if (!ACPI_STRCMP (Path, NextExternal->Path))
> +        if (!ACPI_STRCMP (ExternalPath, NextExternal->Path))
> {
> /* Duplicate method, check that the Value (ArgCount) is the same */
> 
> @@ -789,12 +866,8 @@ AcpiDmAddToExternalListFromFile (
> (NextExternal->Value != Value))
> {
> ACPI_ERROR ((AE_INFO,
> -                    "(File) External method arg count mismatch %s: Current %u, \
> override to %u", +                    "External method arg count mismatch %s: \
> Current %u, attempted %u", NextExternal->Path, NextExternal->Value, Value));
> -
> -                /* Override, since new value came from external reference file */
> -
> -                NextExternal->Value = Value;
> }
> 
> /* Allow upgrade of type from ANY */
> @@ -805,44 +878,31 @@ AcpiDmAddToExternalListFromFile (
> NextExternal->Value = Value;
> }
> 
> -            return;
> +            return_ACPI_STATUS (AE_ALREADY_EXISTS);
> }
> 
> NextExternal = NextExternal->Next;
> }
> 
> -    /* Get the internal pathname (AML format) */
> -
> -    Status = AcpiNsInternalizeName (Path, &InternalPath);
> -    if (ACPI_FAILURE (Status))
> -    {
> -        return;
> -    }
> -
> /* Allocate and init a new External() descriptor */
> 
> NewExternal = ACPI_ALLOCATE_ZEROED (sizeof (ACPI_EXTERNAL_LIST));
> if (!NewExternal)
> {
> -        ACPI_FREE (InternalPath);
> -        return;
> +        return_ACPI_STATUS (AE_NO_MEMORY);
> }
> 
> -    /* Must copy and normalize the input path */
> -
> -    AcpiNsExternalizeName (ACPI_UINT32_MAX, InternalPath, NULL, &ExternalPath);
> +    ACPI_DEBUG_PRINT ((ACPI_DB_NAMES,
> +        "Adding external reference node (%s) type [%s]\n",
> +        ExternalPath, AcpiUtGetTypeName (Type)));
> 
> +    NewExternal->Flags = Flags;
> +    NewExternal->Value = Value;
> NewExternal->Path = ExternalPath;
> NewExternal->Type = Type;
> -    NewExternal->Value = Value;
> -    NewExternal->Resolved = Resolved;
> -    NewExternal->Length = (UINT16) ACPI_STRLEN (Path);
> +    NewExternal->Length = (UINT16) ACPI_STRLEN (ExternalPath);
> NewExternal->InternalPath = InternalPath;
> 
> -    /* Set flag to indicate External->InternalPath needs to be freed */
> -
> -    NewExternal->Flags |= ACPI_IPATH_ALLOCATED | ACPI_FROM_REFERENCE_FILE;
> -
> /* Link the new descriptor into the global list, alphabetically ordered */
> 
> NextExternal = AcpiGbl_ExternalList;
> @@ -860,7 +920,7 @@ AcpiDmAddToExternalListFromFile (
> }
> 
> NewExternal->Next = NextExternal;
> -            return;
> +            return_ACPI_STATUS (AE_OK);
> }
> 
> PrevExternal = NextExternal;
> @@ -875,6 +935,8 @@ AcpiDmAddToExternalListFromFile (
> {
> AcpiGbl_ExternalList = NewExternal;
> }
> +
> +    return_ACPI_STATUS (AE_OK);
> }
> 
> 
> @@ -1050,7 +1112,7 @@ AcpiDmEmitExternals (
> if (NextExternal->Type == ACPI_TYPE_METHOD)
> {
> AcpiGbl_NumExternalMethods++;
> -            if (NextExternal->Resolved)
> +            if (NextExternal->Flags & ACPI_EXT_RESOLVED_REFERENCE)
> {
> AcpiGbl_ResolvedExternalMethods++;
> }
> @@ -1069,7 +1131,7 @@ AcpiDmEmitExternals (
> while (NextExternal)
> {
> if ((NextExternal->Type == ACPI_TYPE_METHOD) &&
> -            (!NextExternal->Resolved))
> +            (!(NextExternal->Flags & ACPI_EXT_RESOLVED_REFERENCE)))
> {
> AcpiOsPrintf ("    External (%s%s",
> NextExternal->Path,
> @@ -1080,7 +1142,7 @@ AcpiDmEmitExternals (
> "guessing %u arguments (may be incorrect, see warning above)\n",
> NextExternal->Value);
> 
> -            NextExternal->Emitted = TRUE;
> +            NextExternal->Flags |= ACPI_EXT_EXTERNAL_EMITTED;
> }
> 
> NextExternal = NextExternal->Next;
> @@ -1101,7 +1163,8 @@ AcpiDmEmitExternals (
> NextExternal = AcpiGbl_ExternalList;
> while (NextExternal)
> {
> -            if (!NextExternal->Emitted && (NextExternal->Flags & \
> ACPI_FROM_REFERENCE_FILE)) +            if (!(NextExternal->Flags & \
> ACPI_EXT_EXTERNAL_EMITTED) && +                (NextExternal->Flags & \
> ACPI_EXT_ORIGIN_FROM_FILE)) {
> AcpiOsPrintf ("    External (%s%s",
> NextExternal->Path,
> @@ -1116,7 +1179,7 @@ AcpiDmEmitExternals (
> {
> AcpiOsPrintf (")\n");
> }
> -                NextExternal->Emitted = TRUE;
> +                NextExternal->Flags |= ACPI_EXT_EXTERNAL_EMITTED;
> }
> 
> NextExternal = NextExternal->Next;
> @@ -1130,7 +1193,7 @@ AcpiDmEmitExternals (
> */
> while (AcpiGbl_ExternalList)
> {
> -        if (!AcpiGbl_ExternalList->Emitted)
> +        if (!(AcpiGbl_ExternalList->Flags & ACPI_EXT_EXTERNAL_EMITTED))
> {
> AcpiOsPrintf ("    External (%s%s",
> AcpiGbl_ExternalList->Path,
> @@ -1152,7 +1215,7 @@ AcpiDmEmitExternals (
> /* Free this external info block and move on to next external */
> 
> NextExternal = AcpiGbl_ExternalList->Next;
> -        if (AcpiGbl_ExternalList->Flags & ACPI_IPATH_ALLOCATED)
> +        if (AcpiGbl_ExternalList->Flags & ACPI_EXT_INTERNAL_PATH_ALLOCATED)
> {
> ACPI_FREE (AcpiGbl_ExternalList->InternalPath);
> }
> diff --git a/src/acpica/source/common/dmtable.c \
> b/src/acpica/source/common/dmtable.c index fa7b300..ccfdfbe 100644
> --- a/src/acpica/source/common/dmtable.c
> +++ b/src/acpica/source/common/dmtable.c
> @@ -277,6 +277,12 @@ static const char           *AcpiDmMadtSubnames[] =
> "Unknown SubTable Type"         /* Reserved */
> };
> 
> +static const char           *AcpiDmPcctSubnames[] =
> +{
> +    "Generic Communications Subspace",  /* ACPI_PCCT_TYPE_GENERIC_SUBSPACE */
> +    "Unknown SubTable Type"             /* Reserved */
> +};
> +
> static const char           *AcpiDmPmttSubnames[] =
> {
> "Socket",                       /* ACPI_PMTT_TYPE_SOCKET */
> @@ -358,7 +364,7 @@ ACPI_DMTABLE_DATA    AcpiDmTableData[] =
> {ACPI_SIG_BOOT, AcpiDmTableInfoBoot,    NULL,           NULL,           \
> TemplateBoot,   "Simple Boot Flag Table"}, {ACPI_SIG_CPEP, NULL,                   \
> AcpiDmDumpCpep, DtCompileCpep,  TemplateCpep,   "Corrected Platform Error Polling \
> table"}, {ACPI_SIG_CSRT, NULL,                   AcpiDmDumpCsrt, DtCompileCsrt,  \
>                 TemplateCsrt,   "Core System Resource Table"},
> -    {ACPI_SIG_DBG2, NULL,                   AcpiDmDumpDbg2, NULL,           NULL,  \
> "Debug Port table type 2"}, +    {ACPI_SIG_DBG2, AcpiDmTableInfoDbg2,    \
> AcpiDmDumpDbg2, DtCompileDbg2,  TemplateDbg2,   "Debug Port table type 2"}, \
> {ACPI_SIG_DBGP, AcpiDmTableInfoDbgp,    NULL,           NULL,           \
> TemplateDbgp,   "Debug Port table"}, {ACPI_SIG_DMAR, NULL,                   \
> AcpiDmDumpDmar, DtCompileDmar,  TemplateDmar,   "DMA Remapping table"}, \
> {ACPI_SIG_ECDT, AcpiDmTableInfoEcdt,    NULL,           NULL,           \
> TemplateEcdt,   "Embedded Controller Boot Resources Table"}, @@ -376,7 +382,7 @@ \
> ACPI_DMTABLE_DATA    AcpiDmTableData[] = {ACPI_SIG_MPST, AcpiDmTableInfoMpst,    \
> AcpiDmDumpMpst, DtCompileMpst,  TemplateMpst,   "Memory Power State Table"}, \
> {ACPI_SIG_MSCT, NULL,                   AcpiDmDumpMsct, DtCompileMsct,  \
> TemplateMsct,   "Maximum System Characteristics Table"}, {ACPI_SIG_MTMR, NULL,      \
>                 AcpiDmDumpMtmr, DtCompileMtmr,  TemplateMtmr,   "MID Timer Table"},
> -    {ACPI_SIG_PCCT, NULL,                   AcpiDmDumpPcct, NULL,           NULL,  \
> "Platform Communications Channel Table"}, +    {ACPI_SIG_PCCT, AcpiDmTableInfoPcct, \
> AcpiDmDumpPcct, DtCompilePcct,  TemplatePcct,   "Platform Communications Channel \
> Table"}, {ACPI_SIG_PMTT, NULL,                   AcpiDmDumpPmtt, DtCompilePmtt,  \
> TemplatePmtt,   "Platform Memory Topology Table"}, {ACPI_SIG_RSDT, NULL,            \
> AcpiDmDumpRsdt, DtCompileRsdt,  TemplateRsdt,   "Root System Description Table"}, \
> {ACPI_SIG_S3PT, NULL,                   NULL,           NULL,           \
> TemplateS3pt,   "S3 Performance Table"}, @@ -722,6 +728,7 @@ AcpiDmDumpTable (
> UINT32                  ByteLength;
> UINT8                   Temp8;
> UINT16                  Temp16;
> +    UINT64                  Value;
> ACPI_DMTABLE_DATA       *TableData;
> const char              *Name;
> BOOLEAN                 LastOutputBlankLine = FALSE;
> @@ -764,6 +771,7 @@ AcpiDmDumpTable (
> case ACPI_DMT_ACCWIDTH:
> case ACPI_DMT_IVRS:
> case ACPI_DMT_MADT:
> +        case ACPI_DMT_PCCT:
> case ACPI_DMT_PMTT:
> case ACPI_DMT_SRAT:
> case ACPI_DMT_ASF:
> @@ -935,10 +943,19 @@ AcpiDmDumpTable (
> * Dump bytes - high byte first, low byte last.
> * Note: All ACPI tables are little-endian.
> */
> +            Value = 0;
> for (Temp8 = (UINT8) ByteLength; Temp8 > 0; Temp8--)
> {
> AcpiOsPrintf ("%2.2X", Target[Temp8 - 1]);
> +                Value |= Target[Temp8 - 1];
> +                Value <<= 8;
> +            }
> +
> +            if (!Value && (Info->Flags & DT_DESCRIBES_OPTIONAL))
> +            {
> +                AcpiOsPrintf (" [Optional field not present]");
> }
> +
> AcpiOsPrintf ("\n");
> break;
> 
> @@ -1194,6 +1211,19 @@ AcpiDmDumpTable (
> AcpiOsPrintf (UINT8_FORMAT, *Target, AcpiDmMadtSubnames[Temp8]);
> break;
> 
> +        case ACPI_DMT_PCCT:
> +
> +            /* PCCT subtable types */
> +
> +            Temp8 = *Target;
> +            if (Temp8 > ACPI_PCCT_TYPE_RESERVED)
> +            {
> +                Temp8 = ACPI_PCCT_TYPE_RESERVED;
> +            }
> +
> +            AcpiOsPrintf (UINT8_FORMAT, *Target, AcpiDmPcctSubnames[Temp8]);
> +            break;
> +
> case ACPI_DMT_PMTT:
> 
> /* PMTT subtable types */
> diff --git a/src/acpica/source/common/dmtbdump.c \
> b/src/acpica/source/common/dmtbdump.c index 84c646a..7619b40 100644
> --- a/src/acpica/source/common/dmtbdump.c
> +++ b/src/acpica/source/common/dmtbdump.c
> @@ -881,8 +881,11 @@ AcpiDmDumpDbg2 (
> 
> /* Dump the OemData (optional) */
> 
> -        AcpiDmDumpBuffer (SubTable, SubTable->OemDataOffset, \
>                 SubTable->OemDataLength,
> -            Offset + SubTable->OemDataOffset, "OEM Data");
> +        if (SubTable->OemDataOffset)
> +        {
> +            AcpiDmDumpBuffer (SubTable, SubTable->OemDataOffset, \
> SubTable->OemDataLength, +                Offset + SubTable->OemDataOffset, "OEM \
> Data"); +        }
> 
> /* Point to next sub-table */
> 
> @@ -2019,11 +2022,31 @@ AcpiDmDumpPcct (
> return;
> }
> 
> -    /* Sub-tables */
> +    /* Subtables */
> 
> SubTable = ACPI_ADD_PTR (ACPI_PCCT_SUBSPACE, Table, Offset);
> while (Offset < Table->Length)
> {
> +        /* Common subtable header */
> +
> +        AcpiOsPrintf ("\n");
> +        Status = AcpiDmDumpTable (Length, Offset, SubTable,
> +                    SubTable->Header.Length, AcpiDmTableInfoPcctHdr);
> +        if (ACPI_FAILURE (Status))
> +        {
> +            return;
> +        }
> +
> +        /* ACPI 5.0: Only one type of PCCT subtable is supported */
> +
> +        if (SubTable->Header.Type != ACPI_PCCT_TYPE_GENERIC_SUBSPACE)
> +        {
> +            AcpiOsPrintf (
> +                "\n**** Unexpected or unknown PCCT subtable type 0x%X\n\n",
> +                SubTable->Header.Type);
> +            return;
> +        }
> +
> AcpiOsPrintf ("\n");
> Status = AcpiDmDumpTable (Length, Offset, SubTable,
> SubTable->Header.Length, AcpiDmTableInfoPcct0);
> @@ -2032,7 +2055,7 @@ AcpiDmDumpPcct (
> return;
> }
> 
> -        /* Point to next sub-table */
> +        /* Point to next subtable */
> 
> Offset += SubTable->Header.Length;
> SubTable = ACPI_ADD_PTR (ACPI_PCCT_SUBSPACE, SubTable,
> diff --git a/src/acpica/source/common/dmtbinfo.c \
> b/src/acpica/source/common/dmtbinfo.c index def6de8..3c68804 100644
> --- a/src/acpica/source/common/dmtbinfo.c
> +++ b/src/acpica/source/common/dmtbinfo.c
> @@ -792,12 +792,12 @@ ACPI_DMTABLE_INFO           AcpiDmTableInfoDbg2[] =
> ACPI_DMTABLE_INFO           AcpiDmTableInfoDbg2Device[] =
> {
> {ACPI_DMT_UINT8,    ACPI_DBG20_OFFSET (Revision),               "Revision", 0},
> -    {ACPI_DMT_UINT16,   ACPI_DBG20_OFFSET (Length),                 "Length", 0},
> +    {ACPI_DMT_UINT16,   ACPI_DBG20_OFFSET (Length),                 "Length", \
> DT_LENGTH}, {ACPI_DMT_UINT8,    ACPI_DBG20_OFFSET (RegisterCount),          \
> "Register Count", 0}, {ACPI_DMT_UINT16,   ACPI_DBG20_OFFSET (NamepathLength),       \
> "Namepath Length", 0}, {ACPI_DMT_UINT16,   ACPI_DBG20_OFFSET (NamepathOffset),      \
>                 "Namepath Offset", 0},
> -    {ACPI_DMT_UINT16,   ACPI_DBG20_OFFSET (OemDataLength),          "OEM Data \
>                 Length", 0},
> -    {ACPI_DMT_UINT16,   ACPI_DBG20_OFFSET (OemDataOffset),          "OEM Data \
> Offset", 0}, +    {ACPI_DMT_UINT16,   ACPI_DBG20_OFFSET (OemDataLength),          \
> "OEM Data Length", DT_DESCRIBES_OPTIONAL}, +    {ACPI_DMT_UINT16,   \
> ACPI_DBG20_OFFSET (OemDataOffset),          "OEM Data Offset", \
> DT_DESCRIBES_OPTIONAL}, {ACPI_DMT_UINT16,   ACPI_DBG20_OFFSET (PortType),           \
> "Port Type", 0}, {ACPI_DMT_UINT16,   ACPI_DBG20_OFFSET (PortSubtype),            \
> "Port Subtype", 0}, {ACPI_DMT_UINT16,   ACPI_DBG20_OFFSET (Reserved),               \
> "Reserved", 0}, @@ -826,6 +826,12 @@ ACPI_DMTABLE_INFO           \
> AcpiDmTableInfoDbg2Name[] = ACPI_DMT_TERMINATOR
> };
> 
> +ACPI_DMTABLE_INFO           AcpiDmTableInfoDbg2OemData[] =
> +{
> +    {ACPI_DMT_BUFFER,   0,                                          "OEM Data", \
> DT_OPTIONAL}, +    ACPI_DMT_TERMINATOR
> +};
> +
> 
> /*******************************************************************************
> *
> @@ -1749,25 +1755,32 @@ ACPI_DMTABLE_INFO           AcpiDmTableInfoPcct[] =
> {
> {ACPI_DMT_UINT32,   ACPI_PCCT_OFFSET (Flags),                   "Flags (decoded \
> below)", DT_FLAG}, {ACPI_DMT_FLAG0,    ACPI_PCCT_FLAG_OFFSET (Flags,0),            \
>                 "Doorbell", 0},
> -    {ACPI_DMT_UINT32,   ACPI_PCCT_OFFSET (Latency),                 "Command \
>                 Latency", 0},
> -    {ACPI_DMT_UINT32,   ACPI_PCCT_OFFSET (Reserved),                "Reserved", \
> 0}, +    {ACPI_DMT_UINT64,   ACPI_PCCT_OFFSET (Reserved),                \
> "Reserved", 0}, ACPI_DMT_TERMINATOR
> };
> 
> /* PCCT subtables */
> 
> +ACPI_DMTABLE_INFO           AcpiDmTableInfoPcctHdr[] =
> +{
> +    {ACPI_DMT_PCCT,     ACPI_PCCT0_OFFSET (Header.Type),            "Subtable \
> Type", 0}, +    {ACPI_DMT_UINT8,    ACPI_PCCT0_OFFSET (Header.Length),          \
> "Length", DT_LENGTH}, +    ACPI_DMT_TERMINATOR
> +};
> +
> /* 0: Generic Communications Subspace */
> 
> ACPI_DMTABLE_INFO           AcpiDmTableInfoPcct0[] =
> {
> -    {ACPI_DMT_UINT8,    ACPI_PCCT0_OFFSET (Header.Type),            "Subtable \
>                 Type", 0},
> -    {ACPI_DMT_UINT8,    ACPI_PCCT0_OFFSET (Header.Length),          "Length", \
> DT_LENGTH}, {ACPI_DMT_UINT48,   ACPI_PCCT0_OFFSET (Reserved[0]),            \
> "Reserved", 0}, {ACPI_DMT_UINT64,   ACPI_PCCT0_OFFSET (BaseAddress),            \
> "Base Address", 0}, {ACPI_DMT_UINT64,   ACPI_PCCT0_OFFSET (Length),                 \
> "Address Length", 0}, {ACPI_DMT_GAS,      ACPI_PCCT0_OFFSET (DoorbellRegister),     \
> "Doorbell Register", 0}, {ACPI_DMT_UINT64,   ACPI_PCCT0_OFFSET (PreserveMask),      \
> "Preserve Mask", 0}, {ACPI_DMT_UINT64,   ACPI_PCCT0_OFFSET (WriteMask),             \
> "Write Mask", 0}, +    {ACPI_DMT_UINT32,   ACPI_PCCT0_OFFSET (Latency),             \
> "Command Latency", 0}, +    {ACPI_DMT_UINT32,   ACPI_PCCT0_OFFSET (MaxAccessRate),  \
> "Maximum Access Rate", 0}, +    {ACPI_DMT_UINT16,   ACPI_PCCT0_OFFSET \
> (MinTurnaroundTime),      "Minimum Turnaround Time", 0}, ACPI_DMT_TERMINATOR
> };
> 
> diff --git a/src/acpica/source/compiler/aslbtypes.c \
> b/src/acpica/source/compiler/aslbtypes.c index 17240cd..4fcd616 100644
> --- a/src/acpica/source/compiler/aslbtypes.c
> +++ b/src/acpica/source/compiler/aslbtypes.c
> @@ -315,7 +315,7 @@ AnMapEtypeToBtype (
> 
> return (ACPI_BTYPE_INTEGER | ACPI_BTYPE_DDB_HANDLE);
> 
> -        case ACPI_BTYPE_DEBUG_OBJECT:
> +        case ACPI_TYPE_DEBUG_OBJECT:
> 
> /* Cannot be used as a source operand */
> 
> diff --git a/src/acpica/source/compiler/asldefine.h \
> b/src/acpica/source/compiler/asldefine.h index 4920f00..a0603a1 100644
> --- a/src/acpica/source/compiler/asldefine.h
> +++ b/src/acpica/source/compiler/asldefine.h
> @@ -127,7 +127,7 @@
> #define ASL_INVOCATION_NAME         "iasl"
> #define ASL_CREATOR_ID              "INTL"
> 
> -#define ASL_COMPLIANCE              "Supports ACPI Specification Revision 5.0"
> +#define ASL_COMPLIANCE              "Supports ACPI Specification Revision 5.0A"
> 
> 
> /* Configuration constants */
> diff --git a/src/acpica/source/compiler/aslerror.c \
> b/src/acpica/source/compiler/aslerror.c index 6439977..e3d1e62 100644
> --- a/src/acpica/source/compiler/aslerror.c
> +++ b/src/acpica/source/compiler/aslerror.c
> @@ -272,6 +272,16 @@ AePrintException (
> 
> switch (Enode->Level)
> {
> +        case ASL_WARNING:
> +        case ASL_WARNING2:
> +        case ASL_WARNING3:
> +
> +            if (!Gbl_DisplayWarnings)
> +            {
> +                return;
> +            }
> +            break;
> +
> case ASL_REMARK:
> 
> if (!Gbl_DisplayRemarks)
> @@ -294,11 +304,10 @@ AePrintException (
> }
> }
> 
> -    /* Get the file handles */
> +    /* Get the various required file handles */
> 
> OutputFile = Gbl_Files[FileId].Handle;
> 
> -
> if (!Enode->SourceLine)
> {
> /* Use the merged header/source file if present, otherwise use input file */
> diff --git a/src/acpica/source/compiler/aslfiles.c \
> b/src/acpica/source/compiler/aslfiles.c index df3d368..c470146 100644
> --- a/src/acpica/source/compiler/aslfiles.c
> +++ b/src/acpica/source/compiler/aslfiles.c
> @@ -896,6 +896,7 @@ FlParseInputPathname (
> *(Substring+1) = 0;
> }
> 
> +    UtConvertBackslashes (Gbl_OutputFilenamePrefix);
> return (AE_OK);
> }
> #endif
> diff --git a/src/acpica/source/compiler/aslglobal.h \
> b/src/acpica/source/compiler/aslglobal.h index 7fb67c9..29e0ff6 100644
> --- a/src/acpica/source/compiler/aslglobal.h
> +++ b/src/acpica/source/compiler/aslglobal.h
> @@ -235,6 +235,7 @@ ASL_EXTERN BOOLEAN                  ASL_INIT_GLOBAL \
> (Gbl_GetAllTables, FALSE); ASL_EXTERN BOOLEAN                  ASL_INIT_GLOBAL \
> (Gbl_IntegerOptimizationFlag, TRUE); ASL_EXTERN BOOLEAN                  \
> ASL_INIT_GLOBAL (Gbl_ReferenceOptimizationFlag, TRUE); ASL_EXTERN BOOLEAN           \
> ASL_INIT_GLOBAL (Gbl_DisplayRemarks, TRUE); +ASL_EXTERN BOOLEAN                  \
> ASL_INIT_GLOBAL (Gbl_DisplayWarnings, TRUE); ASL_EXTERN BOOLEAN                  \
> ASL_INIT_GLOBAL (Gbl_DisplayOptimizations, FALSE); ASL_EXTERN UINT8                 \
> ASL_INIT_GLOBAL (Gbl_WarningLevel, ASL_WARNING); ASL_EXTERN BOOLEAN                 \
> ASL_INIT_GLOBAL (Gbl_UseOriginalCompilerId, FALSE); @@ -304,7 +305,6 @@ ASL_EXTERN \
> UINT32                   ASL_INIT_GLOBAL (Gbl_NumNamespaceObjects, 0) ASL_EXTERN \
> UINT32                   ASL_INIT_GLOBAL (Gbl_ReservedMethods, 0); ASL_EXTERN char  \
> ASL_INIT_GLOBAL (*Gbl_TableSignature, "NO_SIG"); ASL_EXTERN char                    \
>                 ASL_INIT_GLOBAL (*Gbl_TableId, "NO_ID");
> -ASL_EXTERN FILE                     *AcpiGbl_DebugFile; /* Placeholder for oswinxf \
> only */ 
> 
> /* Static structures */
> diff --git a/src/acpica/source/compiler/asllookup.c \
> b/src/acpica/source/compiler/asllookup.c index 82a8334..259df47 100644
> --- a/src/acpica/source/compiler/asllookup.c
> +++ b/src/acpica/source/compiler/asllookup.c
> @@ -177,7 +177,9 @@ LkFindUnreferencedObjects (
> * DESCRIPTION: Check for an unreferenced namespace object and emit a warning.
> *              We have to be careful, because some types and names are
> *              typically or always unreferenced, we don't want to issue
> - *              excessive warnings.
> + *              excessive warnings. Note: Names that are declared within a
> + *              control method are temporary, so we always issue a remark
> + *              if they are not referenced.
> *
> ******************************************************************************/
> 
> @@ -189,6 +191,7 @@ LkIsObjectUsed (
> void                    **ReturnValue)
> {
> ACPI_NAMESPACE_NODE     *Node = ACPI_CAST_PTR (ACPI_NAMESPACE_NODE, ObjHandle);
> +    ACPI_NAMESPACE_NODE     *Next;
> 
> 
> /* Referenced flag is set during the namespace xref */
> @@ -198,23 +201,19 @@ LkIsObjectUsed (
> return (AE_OK);
> }
> 
> -    /*
> -     * Ignore names that start with an underscore,
> -     * these are the reserved ACPI names and are typically not referenced,
> -     * they are called by the host OS.
> -     */
> -    if (Node->Name.Ascii[0] == '_')
> +    if (!Node->Op)
> {
> return (AE_OK);
> }
> 
> -    /* There are some types that are typically not referenced, ignore them */
> +    /* These types are typically never directly referenced, ignore them */
> 
> switch (Node->Type)
> {
> case ACPI_TYPE_DEVICE:
> case ACPI_TYPE_PROCESSOR:
> case ACPI_TYPE_POWER:
> +    case ACPI_TYPE_THERMAL:
> case ACPI_TYPE_LOCAL_RESOURCE:
> 
> return (AE_OK);
> @@ -224,12 +223,47 @@ LkIsObjectUsed (
> break;
> }
> 
> -    /* All others are valid unreferenced namespace objects */
> +    /* Determine if the name is within a control method */
> 
> -    if (Node->Op)
> +    Next = Node->Parent;
> +    while (Next)
> {
> -        AslError (ASL_WARNING2, ASL_MSG_NOT_REFERENCED, LkGetNameOp (Node->Op), \
> NULL); +        if (Next->Type == ACPI_TYPE_METHOD)
> +        {
> +            /*
> +             * Name is within a method, therefore it is temporary.
> +             * Issue a remark even if it is a reserved name (starts
> +             * with an underscore).
> +             */
> +            sprintf (MsgBuffer, "Name is within method [%4.4s]",
> +                Next->Name.Ascii);
> +            AslError (ASL_REMARK, ASL_MSG_NOT_REFERENCED,
> +                LkGetNameOp (Node->Op), MsgBuffer);
> +            return (AE_OK);
> +        }
> +
> +        Next = Next->Parent;
> }
> +
> +    /* The name is not within a control method */
> +
> +    /*
> +     * Ignore names that start with an underscore. These are the reserved
> +     * ACPI names and are typically not referenced since they are meant
> +     * to be called by the host OS.
> +     */
> +    if (Node->Name.Ascii[0] == '_')
> +    {
> +        return (AE_OK);
> +    }
> +
> +    /*
> +     * What remains is an unresolved user name that is not within a method.
> +     * However, the object could be referenced via another table, so issue
> +     * the warning at level 2.
> +     */
> +    AslError (ASL_WARNING2, ASL_MSG_NOT_REFERENCED,
> +        LkGetNameOp (Node->Op), NULL);
> return (AE_OK);
> }
> 
> diff --git a/src/acpica/source/compiler/aslmain.c \
> b/src/acpica/source/compiler/aslmain.c index bc6b658..27fc6b0 100644
> --- a/src/acpica/source/compiler/aslmain.c
> +++ b/src/acpica/source/compiler/aslmain.c
> @@ -166,11 +166,21 @@ Usage (
> printf ("%s\n\n", ASL_COMPLIANCE);
> ACPI_USAGE_HEADER ("iasl [Options] [Files]");
> 
> -    printf ("\nGlobal:\n");
> +    printf ("\nGeneral:\n");
> ACPI_OPTION ("-@ <file>",       "Specify command file");
> ACPI_OPTION ("-I <dir>",        "Specify additional include directory");
> ACPI_OPTION ("-T <sig>|ALL|*",  "Create table template file for ACPI <Sig>");
> +    ACPI_OPTION ("-p <prefix>",     "Specify path/filename prefix for all output \
> files"); ACPI_OPTION ("-v",              "Display compiler version");
> +    ACPI_OPTION ("-vo",             "Enable optimization comments");
> +    ACPI_OPTION ("-vs",             "Disable signon");
> +
> +    printf ("\nHelp:\n");
> +    ACPI_OPTION ("-h",              "This message");
> +    ACPI_OPTION ("-hc",             "Display operators allowed in constant \
> expressions"); +    ACPI_OPTION ("-hf",             "Display help for output \
> filename generation"); +    ACPI_OPTION ("-hr",             "Display ACPI reserved \
> method names"); +    ACPI_OPTION ("-ht",             "Display currently supported \
> ACPI table names"); 
> printf ("\nPreprocessor:\n");
> ACPI_OPTION ("-D <symbol>",     "Define symbol for preprocessor use");
> @@ -178,13 +188,11 @@ Usage (
> ACPI_OPTION ("-P",              "Preprocess only and create preprocessor output \
> file (*.i)"); ACPI_OPTION ("-Pn",             "Disable preprocessor");
> 
> -    printf ("\nGeneral Processing:\n");
> -    ACPI_OPTION ("-p <prefix>",     "Specify path/filename prefix for all output \
>                 files");
> -    ACPI_OPTION ("-va",             "Disable all errors and warnings (summary \
> only)"); +    printf ("\nErrors, Warnings, and Remarks:\n");
> +    ACPI_OPTION ("-va",             "Disable all errors/warnings/remarks");
> +    ACPI_OPTION ("-ve",             "Report only errors (ignore warnings and \
> remarks)"); ACPI_OPTION ("-vi",             "Less verbose errors and warnings for \
>                 use with IDEs");
> -    ACPI_OPTION ("-vo",             "Enable optimization comments");
> ACPI_OPTION ("-vr",             "Disable remarks");
> -    ACPI_OPTION ("-vs",             "Disable signon");
> ACPI_OPTION ("-vw <messageid>", "Disable specific warning or remark");
> ACPI_OPTION ("-w1 -w2 -w3",     "Set warning reporting level");
> ACPI_OPTION ("-we",             "Report warnings as errors");
> @@ -226,13 +234,6 @@ Usage (
> ACPI_OPTION ("-in",             "Ignore NoOp opcodes");
> ACPI_OPTION ("-vt",             "Dump binary table data in hex format within output \
> file"); 
> -    printf ("\nHelp:\n");
> -    ACPI_OPTION ("-h",              "This message");
> -    ACPI_OPTION ("-hc",             "Display operators allowed in constant \
>                 expressions");
> -    ACPI_OPTION ("-hf",             "Display help for output filename \
>                 generation");
> -    ACPI_OPTION ("-hr",             "Display ACPI reserved method names");
> -    ACPI_OPTION ("-ht",             "Display currently supported ACPI table \
>                 names");
> -
> printf ("\nDebug Options:\n");
> ACPI_OPTION ("-bf -bt",         "Create debug file (full or parse tree only) \
> (*.txt)"); ACPI_OPTION ("-f",              "Ignore errors, force creation of AML \
> output file(s)"); @@ -425,6 +426,7 @@ main (
> if (Gbl_UseDefaultAmlFilename)
> {
> Gbl_OutputFilenamePrefix = argv[Index2];
> +            UtConvertBackslashes (Gbl_OutputFilenamePrefix);
> }
> 
> Status = AslDoOneFile (argv[Index2]);
> diff --git a/src/acpica/source/compiler/aslmessages.h \
> b/src/acpica/source/compiler/aslmessages.h index 16c1d94..a3f6c8b 100644
> --- a/src/acpica/source/compiler/aslmessages.h
> +++ b/src/acpica/source/compiler/aslmessages.h
> @@ -441,7 +441,7 @@ char                        *AslMessages [] =
> /*    ASL_MSG_NOT_METHOD */                 "Not a control method, cannot invoke",
> /*    ASL_MSG_NOT_PARAMETER */              "Not a parameter, used as local only",
> /*    ASL_MSG_NOT_REACHABLE */              "Object is not accessible from this \
>                 scope",
> -/*    ASL_MSG_NOT_REFERENCED */             "Namespace object is not referenced",
> +/*    ASL_MSG_NOT_REFERENCED */             "Object is not referenced",
> /*    ASL_MSG_NULL_DESCRIPTOR */            "Min/Max/Length/Gran are all zero, but \
> no resource tag", /*    ASL_MSG_NULL_STRING */                "Invalid zero-length \
> (null) string", /*    ASL_MSG_OPEN */                       "Could not open file",
> diff --git a/src/acpica/source/compiler/asloperands.c \
> b/src/acpica/source/compiler/asloperands.c index 1a85a9f..f011d51 100644
> --- a/src/acpica/source/compiler/asloperands.c
> +++ b/src/acpica/source/compiler/asloperands.c
> @@ -994,6 +994,7 @@ OpnDoDefinitionBlock (
> strcat (Filename, (char *) Child->Asl.Value.Buffer);
> 
> Gbl_OutputFilenamePrefix = Filename;
> +        UtConvertBackslashes (Gbl_OutputFilenamePrefix);
> }
> Child->Asl.ParseOpcode = PARSEOP_DEFAULT_ARG;
> 
> diff --git a/src/acpica/source/compiler/aslopt.c \
> b/src/acpica/source/compiler/aslopt.c index 535d7b0..0588246 100644
> --- a/src/acpica/source/compiler/aslopt.c
> +++ b/src/acpica/source/compiler/aslopt.c
> @@ -648,7 +648,8 @@ OptOptimizeNamePath (
> return_VOID;
> }
> 
> -    ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OPTIMIZATIONS, "%5d [%12.12s] [%12.12s] ",
> +    ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OPTIMIZATIONS,
> +        "PATH OPTIMIZE: Line %5d ParentOp [%12.12s] ThisOp [%12.12s] ",
> Op->Asl.LogicalLineNumber,
> AcpiPsGetOpcodeName (Op->Common.Parent->Common.AmlOpcode),
> AcpiPsGetOpcodeName (Op->Common.AmlOpcode)));
> @@ -692,7 +693,7 @@ OptOptimizeNamePath (
> {
> /* This is the declaration of a new name */
> 
> -        ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OPTIMIZATIONS, "NAME"));
> +        ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OPTIMIZATIONS, "NAME\n"));
> 
> /*
> * The node of interest is the parent of this node (the containing
> @@ -718,7 +719,7 @@ OptOptimizeNamePath (
> {
> /* This is a reference to an existing named object */
> 
> -        ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OPTIMIZATIONS, "REF "));
> +        ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OPTIMIZATIONS, "REFERENCE\n"));
> }
> 
> /*
> @@ -760,9 +761,10 @@ OptOptimizeNamePath (
> }
> 
> ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OPTIMIZATIONS,
> -        "%37s (%2u) ==> %-32s(%2u) %-32s",
> -        (char *) CurrentPath.Pointer, (UINT32) CurrentPath.Length,
> -        (char *) TargetPath.Pointer, (UINT32) TargetPath.Length, \
> ExternalNameString)); +        "CURRENT SCOPE: (%2u) %-37s FULL PATH TO NAME: (%2u) \
> %-32s ACTUAL AML:%-32s\n", +        (UINT32) CurrentPath.Length, (char *) \
> CurrentPath.Pointer, +        (UINT32) TargetPath.Length, (char *) \
> TargetPath.Pointer, +        ExternalNameString));
> 
> ACPI_FREE (ExternalNameString);
> 
> @@ -819,7 +821,8 @@ OptOptimizeNamePath (
> HowMuchShorter = (AmlNameStringLength - ACPI_STRLEN (NewPath));
> OptTotal += HowMuchShorter;
> 
> -        ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OPTIMIZATIONS, " REDUCED %2u (%u)",
> +        ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OPTIMIZATIONS,
> +            " REDUCED BY %2u (TOTAL SAVED %2u)",
> (UINT32) HowMuchShorter, OptTotal));
> 
> if (Flags & AML_NAMED)
> diff --git a/src/acpica/source/compiler/aslstartup.c \
> b/src/acpica/source/compiler/aslstartup.c index 73e1b8f..4504532 100644
> --- a/src/acpica/source/compiler/aslstartup.c
> +++ b/src/acpica/source/compiler/aslstartup.c
> @@ -398,6 +398,7 @@ AslDoOneFile (
> }
> 
> Gbl_Files[ASL_FILE_INPUT].Filename = Filename;
> +    UtConvertBackslashes (Filename);
> 
> /*
> * AML Disassembly (Optional)
> diff --git a/src/acpica/source/compiler/aslstubs.c \
> b/src/acpica/source/compiler/aslstubs.c index 4cf1d42..8d2400e 100644
> --- a/src/acpica/source/compiler/aslstubs.c
> +++ b/src/acpica/source/compiler/aslstubs.c
> @@ -311,7 +311,7 @@ ACPI_THREAD_ID
> AcpiOsGetThreadId (
> void)
> {
> -    return (0xFFFF);
> +    return (1);
> }
> 
> ACPI_STATUS
> diff --git a/src/acpica/source/compiler/aslxref.c \
> b/src/acpica/source/compiler/aslxref.c index 51eb314..78a8775 100644
> --- a/src/acpica/source/compiler/aslxref.c
> +++ b/src/acpica/source/compiler/aslxref.c
> @@ -388,7 +388,7 @@ XfNamespaceLocateBegin (
> */
> if (Op->Asl.CompileFlags & NODE_IS_NAME_DECLARATION)
> {
> -        return (AE_OK);
> +        return_ACPI_STATUS (AE_OK);
> }
> 
> /* We are only interested in opcodes that have an associated name */
> @@ -401,7 +401,7 @@ XfNamespaceLocateBegin (
> (Op->Asl.ParseOpcode != PARSEOP_NAMESEG)    &&
> (Op->Asl.ParseOpcode != PARSEOP_METHODCALL))
> {
> -        return (AE_OK);
> +        return_ACPI_STATUS (AE_OK);
> }
> 
> /*
> @@ -412,7 +412,7 @@ XfNamespaceLocateBegin (
> if ((Op->Asl.Parent) &&
> (Op->Asl.Parent->Asl.ParseOpcode == PARSEOP_CONDREFOF))
> {
> -        return (AE_OK);
> +        return_ACPI_STATUS (AE_OK);
> }
> 
> /*
> @@ -531,7 +531,8 @@ XfNamespaceLocateBegin (
> 
> Status = AE_OK;
> }
> -        return (Status);
> +
> +        return_ACPI_STATUS (Status);
> }
> 
> /* Check for a reference vs. name declaration */
> @@ -696,7 +697,6 @@ XfNamespaceLocateBegin (
> 
> (Op->Asl.ParseOpcode == PARSEOP_METHODCALL))
> {
> -
> /*
> * A reference to a method within one of these opcodes is not an
> * invocation of the method, it is simply a reference to the method.
> @@ -706,7 +706,7 @@ XfNamespaceLocateBegin (
> (Op->Asl.Parent->Asl.ParseOpcode == PARSEOP_DEREFOF)    ||
> (Op->Asl.Parent->Asl.ParseOpcode == PARSEOP_OBJECTTYPE)))
> {
> -            return (AE_OK);
> +            return_ACPI_STATUS (AE_OK);
> }
> /*
> * There are two types of method invocation:
> @@ -722,7 +722,7 @@ XfNamespaceLocateBegin (
> Op->Asl.ExternalName, AcpiUtGetTypeName (Node->Type));
> 
> AslError (ASL_ERROR, ASL_MSG_NOT_METHOD, Op, MsgBuffer);
> -            return (AE_OK);
> +            return_ACPI_STATUS (AE_OK);
> }
> 
> /* Save the method node in the caller's op */
> @@ -730,7 +730,7 @@ XfNamespaceLocateBegin (
> Op->Asl.Node = Node;
> if (Op->Asl.Parent->Asl.ParseOpcode == PARSEOP_CONDREFOF)
> {
> -            return (AE_OK);
> +            return_ACPI_STATUS (AE_OK);
> }
> 
> /*
> @@ -895,7 +895,7 @@ XfNamespaceLocateBegin (
> }
> 
> Op->Asl.Node = Node;
> -    return (Status);
> +    return_ACPI_STATUS (Status);
> }
> 
> 
> @@ -930,7 +930,7 @@ XfNamespaceLocateEnd (
> OpInfo = AcpiPsGetOpcodeInfo (Op->Asl.AmlOpcode);
> if (!(OpInfo->Flags & AML_NAMED))
> {
> -        return (AE_OK);
> +        return_ACPI_STATUS (AE_OK);
> }
> 
> /* Not interested in name references, we did not open a scope for them */
> @@ -939,7 +939,7 @@ XfNamespaceLocateEnd (
> (Op->Asl.ParseOpcode == PARSEOP_NAMESEG)    ||
> (Op->Asl.ParseOpcode == PARSEOP_METHODCALL))
> {
> -        return (AE_OK);
> +        return_ACPI_STATUS (AE_OK);
> }
> 
> /* Pop the scope stack if necessary */
> @@ -954,5 +954,5 @@ XfNamespaceLocateEnd (
> (void) AcpiDsScopeStackPop (WalkState);
> }
> 
> -    return (AE_OK);
> +    return_ACPI_STATUS (AE_OK);
> }
> diff --git a/src/acpica/source/compiler/dtcompile.c \
> b/src/acpica/source/compiler/dtcompile.c index 099018b..926bf72 100644
> --- a/src/acpica/source/compiler/dtcompile.c
> +++ b/src/acpica/source/compiler/dtcompile.c
> @@ -518,6 +518,15 @@ DtCompileTable (
> return (AE_BAD_PARAMETER);
> }
> 
> +    /* Ignore optional subtable if name does not match */
> +
> +    if ((Info->Flags & DT_OPTIONAL) &&
> +        ACPI_STRCMP ((*Field)->Name, Info->Name))
> +    {
> +        *RetSubtable = NULL;
> +        return (AE_OK);
> +    }
> +
> Length = DtGetSubtableLength (*Field, Info);
> if (Length == ASL_EOF)
> {
> diff --git a/src/acpica/source/compiler/dtcompiler.h \
> b/src/acpica/source/compiler/dtcompiler.h index 9868662..4c04508 100644
> --- a/src/acpica/source/compiler/dtcompiler.h
> +++ b/src/acpica/source/compiler/dtcompiler.h
> @@ -472,6 +472,10 @@ DtCompileCsrt (
> void                    **PFieldList);
> 
> ACPI_STATUS
> +DtCompileDbg2 (
> +    void                    **PFieldList);
> +
> +ACPI_STATUS
> DtCompileDmar (
> void                    **PFieldList);
> 
> @@ -524,6 +528,10 @@ DtCompilePmtt (
> void                    **PFieldList);
> 
> ACPI_STATUS
> +DtCompilePcct (
> +    void                    **PFieldList);
> +
> +ACPI_STATUS
> DtCompileRsdt (
> void                    **PFieldList);
> 
> @@ -575,6 +583,7 @@ extern const unsigned char  TemplateBert[];
> extern const unsigned char  TemplateBgrt[];
> extern const unsigned char  TemplateCpep[];
> extern const unsigned char  TemplateCsrt[];
> +extern const unsigned char  TemplateDbg2[];
> extern const unsigned char  TemplateDbgp[];
> extern const unsigned char  TemplateDmar[];
> extern const unsigned char  TemplateEcdt[];
> @@ -592,6 +601,7 @@ extern const unsigned char  TemplateMchi[];
> extern const unsigned char  TemplateMpst[];
> extern const unsigned char  TemplateMsct[];
> extern const unsigned char  TemplateMtmr[];
> +extern const unsigned char  TemplatePcct[];
> extern const unsigned char  TemplatePmtt[];
> extern const unsigned char  TemplateRsdt[];
> extern const unsigned char  TemplateS3pt[];
> diff --git a/src/acpica/source/compiler/dtfield.c \
> b/src/acpica/source/compiler/dtfield.c index 00debb8..4a45519 100644
> --- a/src/acpica/source/compiler/dtfield.c
> +++ b/src/acpica/source/compiler/dtfield.c
> @@ -412,7 +412,8 @@ DtCompileInteger (
> 
> if (Value > MaxValue)
> {
> -        sprintf (MsgBuffer, "%8.8X%8.8X", ACPI_FORMAT_UINT64 (Value));
> +        sprintf (MsgBuffer, "%8.8X%8.8X - max %u bytes",
> +            ACPI_FORMAT_UINT64 (Value), ByteLength);
> DtError (ASL_ERROR, ASL_MSG_INTEGER_SIZE, Field, MsgBuffer);
> }
> 
> diff --git a/src/acpica/source/compiler/dttable.c \
> b/src/acpica/source/compiler/dttable.c index e754cc4..5b9236f 100644
> --- a/src/acpica/source/compiler/dttable.c
> +++ b/src/acpica/source/compiler/dttable.c
> @@ -592,6 +592,156 @@ DtCompileCsrt (
> 
> /******************************************************************************
> *
> + * FUNCTION:    DtCompileDbg2
> + *
> + * PARAMETERS:  List                - Current field list pointer
> + *
> + * RETURN:      Status
> + *
> + * DESCRIPTION: Compile DBG2.
> + *
> + *****************************************************************************/
> +
> +ACPI_STATUS
> +DtCompileDbg2 (
> +    void                    **List)
> +{
> +    ACPI_STATUS             Status;
> +    DT_SUBTABLE             *Subtable;
> +    DT_SUBTABLE             *ParentTable;
> +    DT_FIELD                **PFieldList = (DT_FIELD **) List;
> +    UINT32                  SubtableCount;
> +    ACPI_DBG2_HEADER        *Dbg2Header;
> +    ACPI_DBG2_DEVICE        *DeviceInfo;
> +    UINT16                  CurrentOffset;
> +    UINT32                  i;
> +
> +
> +    /* Main table */
> +
> +    Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2, &Subtable, TRUE);
> +    if (ACPI_FAILURE (Status))
> +    {
> +        return (Status);
> +    }
> +
> +    ParentTable = DtPeekSubtable ();
> +    DtInsertSubtable (ParentTable, Subtable);
> +
> +    /* Main table fields */
> +
> +    Dbg2Header = ACPI_CAST_PTR (ACPI_DBG2_HEADER, Subtable->Buffer);
> +    Dbg2Header->InfoOffset = sizeof (ACPI_TABLE_HEADER) + ACPI_PTR_DIFF (
> +        ACPI_ADD_PTR (UINT8, Dbg2Header, sizeof (ACPI_DBG2_HEADER)), Dbg2Header);
> +
> +    SubtableCount = Dbg2Header->InfoCount;
> +    DtPushSubtable (Subtable);
> +
> +    /* Process all Device Information subtables (Count = InfoCount) */
> +
> +    while (*PFieldList && SubtableCount)
> +    {
> +        /* Subtable: Debug Device Information */
> +
> +        Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2Device,
> +                    &Subtable, TRUE);
> +        if (ACPI_FAILURE (Status))
> +        {
> +            return (Status);
> +        }
> +
> +        DeviceInfo = ACPI_CAST_PTR (ACPI_DBG2_DEVICE, Subtable->Buffer);
> +        CurrentOffset = (UINT16) sizeof (ACPI_DBG2_DEVICE);
> +
> +        ParentTable = DtPeekSubtable ();
> +        DtInsertSubtable (ParentTable, Subtable);
> +        DtPushSubtable (Subtable);
> +
> +        ParentTable = DtPeekSubtable ();
> +
> +        /* BaseAddressRegister GAS array (Required, size is RegisterCount) */
> +
> +        DeviceInfo->BaseAddressOffset = CurrentOffset;
> +        for (i = 0; *PFieldList && (i < DeviceInfo->RegisterCount); i++)
> +        {
> +            Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2Addr,
> +                        &Subtable, TRUE);
> +            if (ACPI_FAILURE (Status))
> +            {
> +                return (Status);
> +            }
> +
> +            CurrentOffset += (UINT16) sizeof (ACPI_GENERIC_ADDRESS);
> +            DtInsertSubtable (ParentTable, Subtable);
> +        }
> +
> +        /* AddressSize array (Required, size = RegisterCount) */
> +
> +        DeviceInfo->AddressSizeOffset = CurrentOffset;
> +        for (i = 0; *PFieldList && (i < DeviceInfo->RegisterCount); i++)
> +        {
> +            Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2Size,
> +                        &Subtable, TRUE);
> +            if (ACPI_FAILURE (Status))
> +            {
> +                return (Status);
> +            }
> +
> +            CurrentOffset += (UINT16) sizeof (UINT32);
> +            DtInsertSubtable (ParentTable, Subtable);
> +        }
> +
> +        /* NamespaceString device identifier (Required, size = NamePathLength) */
> +
> +        DeviceInfo->NamepathOffset = CurrentOffset;
> +        Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2Name,
> +                    &Subtable, TRUE);
> +        if (ACPI_FAILURE (Status))
> +        {
> +            return (Status);
> +        }
> +
> +        /* Update the device info header */
> +
> +        DeviceInfo->NamepathLength = (UINT16) Subtable->Length;
> +        CurrentOffset += (UINT16) DeviceInfo->NamepathLength;
> +        DtInsertSubtable (ParentTable, Subtable);
> +
> +        /* OemData - Variable-length data (Optional, size = OemDataLength) */
> +
> +        Status = DtCompileTable (PFieldList, AcpiDmTableInfoDbg2OemData,
> +                    &Subtable, TRUE);
> +        if (ACPI_FAILURE (Status))
> +        {
> +            return (Status);
> +        }
> +
> +        /* Update the device info header (zeros if no OEM data present) */
> +
> +        DeviceInfo->OemDataOffset = 0;
> +        DeviceInfo->OemDataLength = 0;
> +
> +        /* Optional subtable (OemData) */
> +
> +        if (Subtable && Subtable->Length)
> +        {
> +            DeviceInfo->OemDataOffset = CurrentOffset;
> +            DeviceInfo->OemDataLength = (UINT16) Subtable->Length;
> +
> +            DtInsertSubtable (ParentTable, Subtable);
> +        }
> +
> +        SubtableCount--;
> +        DtPopSubtable (); /* Get next Device Information subtable */
> +    }
> +
> +    DtPopSubtable ();
> +    return (AE_OK);
> +}
> +
> +
> +/******************************************************************************
> + *
> * FUNCTION:    DtCompileDmar
> *
> * PARAMETERS:  List                - Current field list pointer
> @@ -1577,6 +1727,85 @@ DtCompileMtmr (
> 
> /******************************************************************************
> *
> + * FUNCTION:    DtCompilePcct
> + *
> + * PARAMETERS:  List                - Current field list pointer
> + *
> + * RETURN:      Status
> + *
> + * DESCRIPTION: Compile PCCT.
> + *
> + *****************************************************************************/
> +
> +ACPI_STATUS
> +DtCompilePcct (
> +    void                    **List)
> +{
> +    ACPI_STATUS             Status;
> +    DT_SUBTABLE             *Subtable;
> +    DT_SUBTABLE             *ParentTable;
> +    DT_FIELD                **PFieldList = (DT_FIELD **) List;
> +    DT_FIELD                *SubtableStart;
> +    ACPI_SUBTABLE_HEADER    *PcctHeader;
> +    ACPI_DMTABLE_INFO       *InfoTable;
> +
> +
> +    Status = DtCompileTable (PFieldList, AcpiDmTableInfoPcct,
> +                &Subtable, TRUE);
> +    if (ACPI_FAILURE (Status))
> +    {
> +        return (Status);
> +    }
> +
> +    ParentTable = DtPeekSubtable ();
> +    DtInsertSubtable (ParentTable, Subtable);
> +
> +    while (*PFieldList)
> +    {
> +        SubtableStart = *PFieldList;
> +        Status = DtCompileTable (PFieldList, AcpiDmTableInfoPcctHdr,
> +                    &Subtable, TRUE);
> +        if (ACPI_FAILURE (Status))
> +        {
> +            return (Status);
> +        }
> +
> +        ParentTable = DtPeekSubtable ();
> +        DtInsertSubtable (ParentTable, Subtable);
> +        DtPushSubtable (Subtable);
> +
> +        PcctHeader = ACPI_CAST_PTR (ACPI_SUBTABLE_HEADER, Subtable->Buffer);
> +
> +        switch (PcctHeader->Type)
> +        {
> +        case ACPI_PCCT_TYPE_GENERIC_SUBSPACE:
> +
> +            InfoTable = AcpiDmTableInfoPcct0;
> +            break;
> +
> +        default:
> +
> +            DtFatal (ASL_MSG_UNKNOWN_SUBTABLE, SubtableStart, "PCCT");
> +            return (AE_ERROR);
> +        }
> +
> +        Status = DtCompileTable (PFieldList, InfoTable, &Subtable, TRUE);
> +        if (ACPI_FAILURE (Status))
> +        {
> +            return (Status);
> +        }
> +
> +        ParentTable = DtPeekSubtable ();
> +        DtInsertSubtable (ParentTable, Subtable);
> +        DtPopSubtable ();
> +    }
> +
> +    return (AE_OK);
> +}
> +
> +
> +/******************************************************************************
> + *
> * FUNCTION:    DtCompilePmtt
> *
> * PARAMETERS:  List                - Current field list pointer
> diff --git a/src/acpica/source/compiler/dttemplate.h \
> b/src/acpica/source/compiler/dttemplate.h index f131b62..d133d91 100644
> --- a/src/acpica/source/compiler/dttemplate.h
> +++ b/src/acpica/source/compiler/dttemplate.h
> @@ -246,6 +246,33 @@ const unsigned char TemplateCsrt[] =
> 0x43,0x48,0x41,0x37                       /* 00000148    "CHA7"     */
> };
> 
> +const unsigned char TemplateDbg2[] =
> +{
> +    0x44,0x42,0x47,0x32,0xB2,0x00,0x00,0x00,  /* 00000000    "DBG2...." */
> +    0x01,0xBA,0x49,0x4E,0x54,0x45,0x4C,0x20,  /* 00000008    "..INTEL " */
> +    0x54,0x45,0x4D,0x50,0x4C,0x41,0x54,0x45,  /* 00000010    "TEMPLATE" */
> +    0x00,0x00,0x00,0x00,0x49,0x4E,0x54,0x4C,  /* 00000018    "....INTL" */
> +    0x15,0x11,0x13,0x20,0x2C,0x00,0x00,0x00,  /* 00000020    "... ,..." */
> +    0x02,0x00,0x00,0x00,0xEE,0x3F,0x00,0x02,  /* 00000028    ".....?.." */
> +    0x09,0x00,0x36,0x00,0x00,0x00,0x00,0x00,  /* 00000030    "..6....." */
> +    0x00,0x80,0x00,0x00,0x00,0x00,0x16,0x00,  /* 00000038    "........" */
> +    0x2E,0x00,0x01,0x32,0x00,0x03,0x88,0x77,  /* 00000040    "...2...w" */
> +    0x66,0x55,0x44,0x33,0x22,0x11,0x01,0x64,  /* 00000048    "fUD3"..d" */
> +    0x00,0x04,0x11,0x00,0xFF,0xEE,0xDD,0xCC,  /* 00000050    "........" */
> +    0xBB,0xAA,0x10,0x32,0x54,0x76,0x98,0xBA,  /* 00000058    "...2Tv.." */
> +    0xDC,0xFE,0x4D,0x79,0x44,0x65,0x76,0x69,  /* 00000060    "..MyDevi" */
> +    0x63,0x65,0x00,0xEE,0x47,0x00,0x01,0x11,  /* 00000068    "ce..G..." */
> +    0x00,0x26,0x00,0x10,0x00,0x37,0x00,0x00,  /* 00000070    ".&...7.." */
> +    0x80,0x00,0x00,0x00,0x00,0x16,0x00,0x22,  /* 00000078    "......."" */
> +    0x00,0x01,0x64,0x00,0x04,0x11,0x00,0xFF,  /* 00000080    "..d....." */
> +    0xEE,0xDD,0xCC,0xBB,0xAA,0x98,0xBA,0xDC,  /* 00000088    "........" */
> +    0xFE,0x5C,0x5C,0x5F,0x53,0x42,0x5F,0x2E,  /* 00000090    ".\\_SB_." */
> +    0x50,0x43,0x49,0x30,0x2E,0x44,0x42,0x47,  /* 00000098    "PCI0.DBG" */
> +    0x50,0x00,0x41,0x42,0x43,0x44,0x45,0x46,  /* 000000A0    "P.ABCDEF" */
> +    0x47,0x48,0x49,0x50,0x51,0x52,0x53,0x54,  /* 000000A8    "GHIPQRST" */
> +    0x55,0x56                                 /* 000000B0    "UV"       */
> +};
> +
> const unsigned char TemplateDbgp[] =
> {
> 0x44,0x42,0x47,0x50,0x34,0x00,0x00,0x00,  /* 00000000    "DBGP4..." */
> @@ -425,10 +452,10 @@ const unsigned char TemplateFacs[] =
> const unsigned char TemplateFadt[] =
> {
> 0x46,0x41,0x43,0x50,0x0C,0x01,0x00,0x00,  /* 00000000    "FACP...." */
> -    0x05,0x18,0x49,0x4E,0x54,0x45,0x4C,0x20,  /* 00000008    "..INTEL " */
> +    0x05,0x64,0x49,0x4E,0x54,0x45,0x4C,0x20,  /* 00000008    ".dINTEL " */
> 0x54,0x45,0x4D,0x50,0x4C,0x41,0x54,0x45,  /* 00000010    "TEMPLATE" */
> 0x00,0x00,0x00,0x00,0x49,0x4E,0x54,0x4C,  /* 00000018    "....INTL" */
> -    0x23,0x11,0x11,0x20,0x01,0x00,0x00,0x00,  /* 00000020    "#.. ...." */
> +    0x15,0x11,0x13,0x20,0x01,0x00,0x00,0x00,  /* 00000020    "... ...." */
> 0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,  /* 00000028    "........" */
> 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,  /* 00000030    "........" */
> 0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,  /* 00000038    "........" */
> @@ -451,7 +478,7 @@ const unsigned char TemplateFadt[] =
> 0x00,0x00,0x00,0x00,0x01,0x08,0x00,0x00,  /* 000000C0    "........" */
> 0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,  /* 000000C8    "........" */
> 0x01,0x20,0x00,0x03,0x01,0x00,0x00,0x00,  /* 000000D0    ". ......" */
> -    0x00,0x00,0x00,0x00,0x01,0x80,0x00,0x01,  /* 000000D8    "........" */
> +    0x00,0x00,0x00,0x00,0x01,0x40,0x00,0x01,  /* 000000D8    ".....@.." */
> 0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,  /* 000000E0    "........" */
> 0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,  /* 000000E8    "........" */
> 0x00,0x00,0x00,0x00,0x01,0x08,0x00,0x01,  /* 000000F0    "........" */
> @@ -718,6 +745,32 @@ const unsigned char TemplateMtmr[] =
> 0x00,0x00,0x00,0x00                       /* 00000048    "...."     */
> };
> 
> +const unsigned char TemplatePcct[] =
> +{
> +    0x50,0x43,0x43,0x54,0xAC,0x00,0x00,0x00,  /* 00000000    "PCCT...." */
> +    0x01,0x97,0x49,0x4E,0x54,0x45,0x4C,0x20,  /* 00000008    "..INTEL " */
> +    0x54,0x45,0x4D,0x50,0x4C,0x41,0x54,0x45,  /* 00000010    "TEMPLATE" */
> +    0x01,0x00,0x00,0x00,0x49,0x4E,0x54,0x4C,  /* 00000018    "....INTL" */
> +    0x15,0x11,0x13,0x20,0x01,0x00,0x00,0x00,  /* 00000020    "... ...." */
> +    0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,  /* 00000028    "........" */
> +    0x00,0x3E,0x00,0x00,0x00,0x00,0x00,0x00,  /* 00000030    ".>......" */
> +    0x11,0x11,0x11,0x11,0x11,0x11,0x11,0x11,  /* 00000038    "........" */
> +    0x22,0x22,0x22,0x22,0x22,0x22,0x22,0x22,  /* 00000040    """""""""" */
> +    0x01,0x32,0x00,0x03,0x33,0x33,0x33,0x33,  /* 00000048    ".2..3333" */
> +    0x33,0x33,0x33,0x33,0x44,0x44,0x44,0x44,  /* 00000050    "3333DDDD" */
> +    0x44,0x44,0x44,0x44,0x55,0x55,0x55,0x55,  /* 00000058    "DDDDUUUU" */
> +    0x55,0x55,0x55,0x55,0x66,0x66,0x66,0x66,  /* 00000060    "UUUUffff" */
> +    0x77,0x77,0x77,0x77,0x88,0x88,0x00,0x3E,  /* 00000068    "wwww...>" */
> +    0x00,0x00,0x00,0x00,0x00,0x00,0xFF,0xFF,  /* 00000070    "........" */
> +    0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xEE,0xEE,  /* 00000078    "........" */
> +    0xEE,0xEE,0xEE,0xEE,0xEE,0xEE,0x01,0x32,  /* 00000080    ".......2" */
> +    0x00,0x03,0xDD,0xDD,0xDD,0xDD,0xDD,0xDD,  /* 00000088    "........" */
> +    0xDD,0xDD,0xCC,0xCC,0xCC,0xCC,0xCC,0xCC,  /* 00000090    "........" */
> +    0xCC,0xCC,0xBB,0xBB,0xBB,0xBB,0xBB,0xBB,  /* 00000098    "........" */
> +    0xBB,0xBB,0xAA,0xAA,0xAA,0xAA,0x99,0x99,  /* 000000A0    "........" */
> +    0x99,0x99,0x88,0x88                       /* 000000A8    "...."     */
> +};
> +
> const unsigned char TemplatePmtt[] =
> {
> 0x50,0x4D,0x54,0x54,0xB4,0x00,0x00,0x00,  /* 00000000    "PMTT...." */
> diff --git a/src/acpica/source/compiler/dtutils.c \
> b/src/acpica/source/compiler/dtutils.c index 0045e07..d3e8616 100644
> --- a/src/acpica/source/compiler/dtutils.c
> +++ b/src/acpica/source/compiler/dtutils.c
> @@ -604,6 +604,7 @@ DtGetFieldLength (
> case ACPI_DMT_ACCWIDTH:
> case ACPI_DMT_IVRS:
> case ACPI_DMT_MADT:
> +    case ACPI_DMT_PCCT:
> case ACPI_DMT_PMTT:
> case ACPI_DMT_SRAT:
> case ACPI_DMT_ASF:
> diff --git a/src/acpica/source/components/debugger/dbfileio.c \
> b/src/acpica/source/components/debugger/dbfileio.c index 1f0ae72..e9a9ad6 100644
> --- a/src/acpica/source/components/debugger/dbfileio.c
> +++ b/src/acpica/source/components/debugger/dbfileio.c
> @@ -132,16 +132,6 @@
> #define _COMPONENT          ACPI_CA_DEBUGGER
> ACPI_MODULE_NAME    ("dbfileio")
> 
> -/*
> - * NOTE: this is here for lack of a better place. It is used in all
> - * flavors of the debugger, need LCD file
> - */
> -#ifdef ACPI_APPLICATION
> -#include <stdio.h>
> -FILE                        *AcpiGbl_DebugFile = NULL;
> -#endif
> -
> -
> #ifdef ACPI_DEBUGGER
> 
> /* Local prototypes */
> diff --git a/src/acpica/source/components/debugger/dbinput.c \
> b/src/acpica/source/components/debugger/dbinput.c index 91f4e62..4b60389 100644
> --- a/src/acpica/source/components/debugger/dbinput.c
> +++ b/src/acpica/source/components/debugger/dbinput.c
> @@ -200,7 +200,7 @@ enum AcpiExDebuggerCommands
> CMD_METHODS,
> CMD_NAMESPACE,
> CMD_NOTIFY,
> -    CMD_OBJECT,
> +    CMD_OBJECTS,
> CMD_OPEN,
> CMD_OSI,
> CMD_OWNER,
> @@ -273,7 +273,7 @@ static const ACPI_DB_COMMAND_INFO   AcpiGbl_DbCommands[] =
> {"METHODS",      0},
> {"NAMESPACE",    0},
> {"NOTIFY",       2},
> -    {"OBJECT",       1},
> +    {"OBJECTS",      1},
> {"OPEN",         1},
> {"OSI",          0},
> {"OWNER",        1},
> @@ -1072,7 +1072,7 @@ AcpiDbCommandDispatch (
> AcpiDbSendNotify (AcpiGbl_DbArgs[1], Temp);
> break;
> 
> -    case CMD_OBJECT:
> +    case CMD_OBJECTS:
> 
> AcpiUtStrupr (AcpiGbl_DbArgs[1]);
> Status = AcpiDbDisplayObjects (AcpiGbl_DbArgs[1], AcpiGbl_DbArgs[2]);
> diff --git a/src/acpica/source/components/dispatcher/dsfield.c \
> b/src/acpica/source/components/dispatcher/dsfield.c index 56a8d3e..812c30b 100644
> --- a/src/acpica/source/components/dispatcher/dsfield.c
> +++ b/src/acpica/source/components/dispatcher/dsfield.c
> @@ -188,7 +188,7 @@ AcpiDsCreateExternalRegion (
> * OperationRegion not found. Generate an External for it, and
> * insert the name into the namespace.
> */
> -    AcpiDmAddToExternalList (Op, Path, ACPI_TYPE_REGION, 0);
> +    AcpiDmAddOpToExternalList (Op, Path, ACPI_TYPE_REGION, 0, 0);
> Status = AcpiNsLookup (WalkState->ScopeInfo, Path, ACPI_TYPE_REGION,
> ACPI_IMODE_LOAD_PASS1, ACPI_NS_SEARCH_PARENT, WalkState, Node);
> if (ACPI_FAILURE (Status))
> diff --git a/src/acpica/source/components/dispatcher/dsutils.c \
> b/src/acpica/source/components/dispatcher/dsutils.c index d3c9580..7757238 100644
> --- a/src/acpica/source/components/dispatcher/dsutils.c
> +++ b/src/acpica/source/components/dispatcher/dsutils.c
> @@ -851,16 +851,16 @@ AcpiDsCreateOperands (
> Index++;
> }
> 
> -    Index--;
> +    ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH,
> +        "NumOperands %d, ArgCount %d, Index %d\n",
> +        WalkState->NumOperands, ArgCount, Index));
> 
> -    /* It is the appropriate order to get objects from the Result stack */
> +    /* Create the interpreter arguments, in reverse order */
> 
> +    Index--;
> for (i = 0; i < ArgCount; i++)
> {
> Arg = Arguments[Index];
> -
> -        /* Force the filling of the operand stack in inverse order */
> -
> WalkState->OperandIndex = (UINT8) Index;
> 
> Status = AcpiDsCreateOperand (WalkState, Arg, Index);
> @@ -869,10 +869,10 @@ AcpiDsCreateOperands (
> goto Cleanup;
> }
> 
> +        ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH,
> +            "Created Arg #%u (%p) %u args total\n",
> +            Index, Arg, ArgCount));
> Index--;
> -
> -        ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Arg #%u (%p) done, Arg1=%p\n",
> -            Index, Arg, FirstArg));
> }
> 
> return_ACPI_STATUS (Status);
> diff --git a/src/acpica/source/components/dispatcher/dswexec.c \
> b/src/acpica/source/components/dispatcher/dswexec.c index fdc79fe..b8c5be3 100644
> --- a/src/acpica/source/components/dispatcher/dswexec.c
> +++ b/src/acpica/source/components/dispatcher/dswexec.c
> @@ -613,7 +613,8 @@ AcpiDsExecEndOp (
> return_ACPI_STATUS (AE_OK);
> }
> 
> -            ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Method invocation, Op=%p\n", \
> Op)); +            ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH,
> +                "Method invocation, Op=%p\n", Op));
> 
> /*
> * (AML_METHODCALL) Op->Asl.Value.Arg->Asl.Node contains
> diff --git a/src/acpica/source/components/dispatcher/dswload.c \
> b/src/acpica/source/components/dispatcher/dswload.c index 291fced..d7c437a 100644
> --- a/src/acpica/source/components/dispatcher/dswload.c
> +++ b/src/acpica/source/components/dispatcher/dswload.c
> @@ -265,7 +265,7 @@ AcpiDsLoad1BeginOp (
> * Target of Scope() not found. Generate an External for it, and
> * insert the name into the namespace.
> */
> -            AcpiDmAddToExternalList (Op, Path, ACPI_TYPE_DEVICE, 0);
> +            AcpiDmAddOpToExternalList (Op, Path, ACPI_TYPE_DEVICE, 0, 0);
> Status = AcpiNsLookup (WalkState->ScopeInfo, Path, ObjectType,
> ACPI_IMODE_LOAD_PASS1, ACPI_NS_SEARCH_PARENT,
> WalkState, &Node);
> diff --git a/src/acpica/source/components/events/evgpeblk.c \
> b/src/acpica/source/components/events/evgpeblk.c index aed636f..4d45cf0 100644
> --- a/src/acpica/source/components/events/evgpeblk.c
> +++ b/src/acpica/source/components/events/evgpeblk.c
> @@ -169,10 +169,9 @@ AcpiEvInstallGpeBlock (
> return_ACPI_STATUS (Status);
> }
> 
> -    GpeXruptBlock = AcpiEvGetGpeXruptBlock (InterruptNumber);
> -    if (!GpeXruptBlock)
> +    Status = AcpiEvGetGpeXruptBlock (InterruptNumber, &GpeXruptBlock);
> +    if (ACPI_FAILURE (Status))
> {
> -        Status = AE_NO_MEMORY;
> goto UnlockAndExit;
> }
> 
> @@ -200,7 +199,7 @@ AcpiEvInstallGpeBlock (
> 
> 
> UnlockAndExit:
> -    Status = AcpiUtReleaseMutex (ACPI_MTX_EVENTS);
> +    (void) AcpiUtReleaseMutex (ACPI_MTX_EVENTS);
> return_ACPI_STATUS (Status);
> }
> 
> diff --git a/src/acpica/source/components/events/evgpeutil.c \
> b/src/acpica/source/components/events/evgpeutil.c index fd0d717..57a2385 100644
> --- a/src/acpica/source/components/events/evgpeutil.c
> +++ b/src/acpica/source/components/events/evgpeutil.c
> @@ -289,8 +289,9 @@ AcpiEvGetGpeDevice (
> * FUNCTION:    AcpiEvGetGpeXruptBlock
> *
> * PARAMETERS:  InterruptNumber             - Interrupt for a GPE block
> + *              GpeXruptBlock               - Where the block is returned
> *
> - * RETURN:      A GPE interrupt block
> + * RETURN:      Status
> *
> * DESCRIPTION: Get or Create a GPE interrupt block. There is one interrupt
> *              block per unique interrupt level used for GPEs. Should be
> @@ -299,9 +300,10 @@ AcpiEvGetGpeDevice (
> *
> ******************************************************************************/
> 
> -ACPI_GPE_XRUPT_INFO *
> +ACPI_STATUS
> AcpiEvGetGpeXruptBlock (
> -    UINT32                  InterruptNumber)
> +    UINT32                  InterruptNumber,
> +    ACPI_GPE_XRUPT_INFO     **GpeXruptBlock)
> {
> ACPI_GPE_XRUPT_INFO     *NextGpeXrupt;
> ACPI_GPE_XRUPT_INFO     *GpeXrupt;
> @@ -319,7 +321,8 @@ AcpiEvGetGpeXruptBlock (
> {
> if (NextGpeXrupt->InterruptNumber == InterruptNumber)
> {
> -            return_PTR (NextGpeXrupt);
> +            *GpeXruptBlock = NextGpeXrupt;
> +            return_ACPI_STATUS (AE_OK);
> }
> 
> NextGpeXrupt = NextGpeXrupt->Next;
> @@ -330,7 +333,7 @@ AcpiEvGetGpeXruptBlock (
> GpeXrupt = ACPI_ALLOCATE_ZEROED (sizeof (ACPI_GPE_XRUPT_INFO));
> if (!GpeXrupt)
> {
> -        return_PTR (NULL);
> +        return_ACPI_STATUS (AE_NO_MEMORY);
> }
> 
> GpeXrupt->InterruptNumber = InterruptNumber;
> @@ -353,6 +356,7 @@ AcpiEvGetGpeXruptBlock (
> {
> AcpiGbl_GpeXruptListHead = GpeXrupt;
> }
> +
> AcpiOsReleaseLock (AcpiGbl_GpeLock, Flags);
> 
> /* Install new interrupt handler if not SCI_INT */
> @@ -363,14 +367,15 @@ AcpiEvGetGpeXruptBlock (
> AcpiEvGpeXruptHandler, GpeXrupt);
> if (ACPI_FAILURE (Status))
> {
> -            ACPI_ERROR ((AE_INFO,
> +            ACPI_EXCEPTION ((AE_INFO, Status,
> "Could not install GPE interrupt handler at level 0x%X",
> InterruptNumber));
> -            return_PTR (NULL);
> +            return_ACPI_STATUS (Status);
> }
> }
> 
> -    return_PTR (GpeXrupt);
> +    *GpeXruptBlock = GpeXrupt;
> +    return_ACPI_STATUS (AE_OK);
> }
> 
> 
> diff --git a/src/acpica/source/components/executer/exresnte.c \
> b/src/acpica/source/components/executer/exresnte.c index 3c0565c..6100be0 100644
> --- a/src/acpica/source/components/executer/exresnte.c
> +++ b/src/acpica/source/components/executer/exresnte.c
> @@ -206,8 +206,8 @@ AcpiExResolveNodeToValue (
> 
> if (!SourceDesc)
> {
> -        ACPI_ERROR ((AE_INFO, "No object attached to node %p",
> -            Node));
> +        ACPI_ERROR ((AE_INFO, "No object attached to node [%4.4s] %p",
> +            Node->Name.Ascii, Node));
> return_ACPI_STATUS (AE_AML_NO_OPERAND);
> }
> 
> diff --git a/src/acpica/source/components/namespace/nsxfeval.c \
> b/src/acpica/source/components/namespace/nsxfeval.c index d8b3480..881945e 100644
> --- a/src/acpica/source/components/namespace/nsxfeval.c
> +++ b/src/acpica/source/components/namespace/nsxfeval.c
> @@ -164,7 +164,7 @@ AcpiEvaluateObjectTyped (
> ACPI_OBJECT_TYPE        ReturnType)
> {
> ACPI_STATUS             Status;
> -    BOOLEAN                 MustFree = FALSE;
> +    BOOLEAN                 FreeBufferOnError = FALSE;
> 
> 
> ACPI_FUNCTION_TRACE (AcpiEvaluateObjectTyped);
> @@ -179,12 +179,13 @@ AcpiEvaluateObjectTyped (
> 
> if (ReturnBuffer->Length == ACPI_ALLOCATE_BUFFER)
> {
> -        MustFree = TRUE;
> +        FreeBufferOnError = TRUE;
> }
> 
> /* Evaluate the object */
> 
> -    Status = AcpiEvaluateObject (Handle, Pathname, ExternalParams, ReturnBuffer);
> +    Status = AcpiEvaluateObject (Handle, Pathname,
> +        ExternalParams, ReturnBuffer);
> if (ACPI_FAILURE (Status))
> {
> return_ACPI_STATUS (Status);
> @@ -219,13 +220,14 @@ AcpiEvaluateObjectTyped (
> AcpiUtGetTypeName (((ACPI_OBJECT *) ReturnBuffer->Pointer)->Type),
> AcpiUtGetTypeName (ReturnType)));
> 
> -    if (MustFree)
> +    if (FreeBufferOnError)
> {
> /*
> -         * Caller used ACPI_ALLOCATE_BUFFER, free the return buffer.
> +         * Free a buffer created via ACPI_ALLOCATE_BUFFER.
> * Note: We use AcpiOsFree here because AcpiOsAllocate was used
> -         * to allocate the buffer. This purposefully bypasses the internal
> -         * allocation tracking mechanism (if it is enabled).
> +         * to allocate the buffer. This purposefully bypasses the
> +         * (optionally enabled) allocation tracking mechanism since we
> +         * only want to track internal allocations.
> */
> AcpiOsFree (ReturnBuffer->Pointer);
> ReturnBuffer->Pointer = NULL;
> diff --git a/src/acpica/source/components/parser/psopinfo.c \
> b/src/acpica/source/components/parser/psopinfo.c index 9b97f74..f614f6b 100644
> --- a/src/acpica/source/components/parser/psopinfo.c
> +++ b/src/acpica/source/components/parser/psopinfo.c
> @@ -148,6 +148,10 @@ const ACPI_OPCODE_INFO *
> AcpiPsGetOpcodeInfo (
> UINT16                  Opcode)
> {
> +#ifdef ACPI_DEBUG_OUTPUT
> +    const char              *OpcodeName = "Unknown AML opcode";
> +#endif
> +
> ACPI_FUNCTION_NAME (PsGetOpcodeInfo);
> 
> 
> @@ -169,10 +173,56 @@ AcpiPsGetOpcodeInfo (
> return (&AcpiGbl_AmlOpInfo [AcpiGbl_LongOpIndex [(UINT8) Opcode]]);
> }
> 
> +#if defined ACPI_ASL_COMPILER && defined ACPI_DEBUG_OUTPUT
> +#include "asldefine.h"
> +
> +    switch (Opcode)
> +    {
> +    case AML_RAW_DATA_BYTE:
> +        OpcodeName = "-Raw Data Byte-";
> +        break;
> +
> +    case AML_RAW_DATA_WORD:
> +        OpcodeName = "-Raw Data Word-";
> +        break;
> +
> +    case AML_RAW_DATA_DWORD:
> +        OpcodeName = "-Raw Data Dword-";
> +        break;
> +
> +    case AML_RAW_DATA_QWORD:
> +        OpcodeName = "-Raw Data Qword-";
> +        break;
> +
> +    case AML_RAW_DATA_BUFFER:
> +        OpcodeName = "-Raw Data Buffer-";
> +        break;
> +
> +    case AML_RAW_DATA_CHAIN:
> +        OpcodeName = "-Raw Data Buffer Chain-";
> +        break;
> +
> +    case AML_PACKAGE_LENGTH:
> +        OpcodeName = "-Package Length-";
> +        break;
> +
> +    case AML_UNASSIGNED_OPCODE:
> +        OpcodeName = "-Unassigned Opcode-";
> +        break;
> +
> +    case AML_DEFAULT_ARG_OP:
> +        OpcodeName = "-Default Arg-";
> +        break;
> +
> +    default:
> +        break;
> +    }
> +#endif
> +
> /* Unknown AML opcode */
> 
> ACPI_DEBUG_PRINT ((ACPI_DB_EXEC,
> -        "Unknown AML opcode [%4.4X]\n", Opcode));
> +        "%s [%4.4X]\n", OpcodeName, Opcode));
> 
> return (&AcpiGbl_AmlOpInfo [_UNK]);
> }
> diff --git a/src/acpica/source/components/tables/tbfadt.c \
> b/src/acpica/source/components/tables/tbfadt.c index d90baba..5f7bab5 100644
> --- a/src/acpica/source/components/tables/tbfadt.c
> +++ b/src/acpica/source/components/tables/tbfadt.c
> @@ -137,13 +137,15 @@ AcpiTbConvertFadt (
> void);
> 
> static void
> -AcpiTbValidateFadt (
> -    void);
> -
> -static void
> AcpiTbSetupFadtRegisters (
> void);
> 
> +static UINT64
> +AcpiTbSelectAddress (
> +    char                    *RegisterName,
> +    UINT32                  Address32,
> +    UINT64                  Address64);
> +
> 
> /* Table for conversion of FADT to common internal format and FADT validation */
> 
> @@ -266,6 +268,7 @@ static ACPI_FADT_PM_INFO    FadtPmInfoTable[] =
> *              SpaceId             - ACPI Space ID for this register
> *              ByteWidth           - Width of this register
> *              Address             - Address of the register
> + *              RegisterName        - ASCII name of the ACPI register
> *
> * RETURN:      None
> *
> @@ -317,6 +320,72 @@ AcpiTbInitGenericAddress (
> 
> /*******************************************************************************
> *
> + * FUNCTION:    AcpiTbSelectAddress
> + *
> + * PARAMETERS:  RegisterName        - ASCII name of the ACPI register
> + *              Address32           - 32-bit address of the register
> + *              Address64           - 64-bit address of the register
> + *
> + * RETURN:      The resolved 64-bit address
> + *
> + * DESCRIPTION: Select between 32-bit and 64-bit versions of addresses within
> + *              the FADT. Used for the FACS and DSDT addresses.
> + *
> + * NOTES:
> + *
> + * Check for FACS and DSDT address mismatches. An address mismatch between
> + * the 32-bit and 64-bit address fields (FIRMWARE_CTRL/X_FIRMWARE_CTRL and
> + * DSDT/X_DSDT) could be a corrupted address field or it might indicate
> + * the presence of two FACS or two DSDT tables.
> + *
> + * November 2013:
> + * By default, as per the ACPICA specification, a valid 64-bit address is
> + * used regardless of the value of the 32-bit address. However, this
> + * behavior can be overridden via the AcpiGbl_Use32BitFadtAddresses flag.
> + *
> + ******************************************************************************/
> +
> +static UINT64
> +AcpiTbSelectAddress (
> +    char                    *RegisterName,
> +    UINT32                  Address32,
> +    UINT64                  Address64)
> +{
> +
> +    if (!Address64)
> +    {
> +        /* 64-bit address is zero, use 32-bit address */
> +
> +        return ((UINT64) Address32);
> +    }
> +
> +    if (Address32 &&
> +       (Address64 != (UINT64) Address32))
> +    {
> +        /* Address mismatch between 32-bit and 64-bit versions */
> +
> +        ACPI_BIOS_WARNING ((AE_INFO,
> +            "32/64X %s address mismatch in FADT: "
> +            "0x%8.8X/0x%8.8X%8.8X, using %u-bit address",
> +            RegisterName, Address32, ACPI_FORMAT_UINT64 (Address64),
> +            AcpiGbl_Use32BitFadtAddresses ? 32 : 64));
> +
> +        /* 32-bit address override */
> +
> +        if (AcpiGbl_Use32BitFadtAddresses)
> +        {
> +            return ((UINT64) Address32);
> +        }
> +    }
> +
> +    /* Default is to use the 64-bit address */
> +
> +    return (Address64);
> +}
> +
> +
> +/*******************************************************************************
> + *
> * FUNCTION:    AcpiTbParseFadt
> *
> * PARAMETERS:  TableIndex          - Index for the FADT
> @@ -437,10 +506,6 @@ AcpiTbCreateLocalFadt (
> 
> AcpiTbConvertFadt ();
> 
> -    /* Validate FADT values now, before we make any changes */
> -
> -    AcpiTbValidateFadt ();
> -
> /* Initialize the global ACPI register structures */
> 
> AcpiTbSetupFadtRegisters ();
> @@ -451,33 +516,43 @@ AcpiTbCreateLocalFadt (
> *
> * FUNCTION:    AcpiTbConvertFadt
> *
> - * PARAMETERS:  None, uses AcpiGbl_FADT
> + * PARAMETERS:  None - AcpiGbl_FADT is used.
> *
> * RETURN:      None
> *
> * DESCRIPTION: Converts all versions of the FADT to a common internal format.
> - *              Expand 32-bit addresses to 64-bit as necessary.
> + *              Expand 32-bit addresses to 64-bit as necessary. Also validate
> + *              important fields within the FADT.
> *
> - * NOTE:        AcpiGbl_FADT must be of size (ACPI_TABLE_FADT),
> - *              and must contain a copy of the actual FADT.
> + * NOTE:        AcpiGbl_FADT must be of size (ACPI_TABLE_FADT), and must
> + *              contain a copy of the actual BIOS-provided FADT.
> *
> * Notes on 64-bit register addresses:
> *
> * After this FADT conversion, later ACPICA code will only use the 64-bit "X"
> * fields of the FADT for all ACPI register addresses.
> *
> - * The 64-bit "X" fields are optional extensions to the original 32-bit FADT
> + * The 64-bit X fields are optional extensions to the original 32-bit FADT
> * V1.0 fields. Even if they are present in the FADT, they are optional and
> * are unused if the BIOS sets them to zero. Therefore, we must copy/expand
> - * 32-bit V1.0 fields if the corresponding X field is zero.
> + * 32-bit V1.0 fields to the 64-bit X fields if the the 64-bit X field is
> + * originally zero.
> *
> - * For ACPI 1.0 FADTs, all 32-bit address fields are expanded to the
> - * corresponding "X" fields in the internal FADT.
> + * For ACPI 1.0 FADTs (that contain no 64-bit addresses), all 32-bit address
> + * fields are expanded to the corresponding 64-bit X fields in the internal
> + * common FADT.
> *
> * For ACPI 2.0+ FADTs, all valid (non-zero) 32-bit address fields are expanded
> - * to the corresponding 64-bit X fields. For compatibility with other ACPI
> - * implementations, we ignore the 64-bit field if the 32-bit field is valid,
> - * regardless of whether the host OS is 32-bit or 64-bit.
> + * to the corresponding 64-bit X fields, if the 64-bit field is originally
> + * zero. Adhering to the ACPI specification, we completely ignore the 32-bit
> + * field if the 64-bit field is valid, regardless of whether the host OS is
> + * 32-bit or 64-bit.
> + *
> + * Possible additional checks:
> + *  (AcpiGbl_FADT.Pm1EventLength >= 4)
> + *  (AcpiGbl_FADT.Pm1ControlLength >= 2)
> + *  (AcpiGbl_FADT.PmTimerLength >= 4)
> + *  Gpe block lengths must be multiple of 2
> *
> ******************************************************************************/
> 
> @@ -485,25 +560,14 @@ static void
> AcpiTbConvertFadt (
> void)
> {
> +    char                    *Name;
> ACPI_GENERIC_ADDRESS    *Address64;
> UINT32                  Address32;
> +    UINT8                   Length;
> UINT32                  i;
> 
> 
> /*
> -     * Expand the 32-bit FACS and DSDT addresses to 64-bit as necessary.
> -     * Later code will always use the X 64-bit field.
> -     */
> -    if (!AcpiGbl_FADT.XFacs)
> -    {
> -        AcpiGbl_FADT.XFacs = (UINT64) AcpiGbl_FADT.Facs;
> -    }
> -    if (!AcpiGbl_FADT.XDsdt)
> -    {
> -        AcpiGbl_FADT.XDsdt = (UINT64) AcpiGbl_FADT.Dsdt;
> -    }
> -
> -    /*
> * For ACPI 1.0 FADTs (revision 1 or 2), ensure that reserved fields which
> * should be zero are indeed zero. This will workaround BIOSs that
> * inadvertently place values in these fields.
> @@ -530,113 +594,14 @@ AcpiTbConvertFadt (
> AcpiGbl_FADT.Header.Length = sizeof (ACPI_TABLE_FADT);
> 
> /*
> -     * Expand the ACPI 1.0 32-bit addresses to the ACPI 2.0 64-bit "X"
> -     * generic address structures as necessary. Later code will always use
> -     * the 64-bit address structures.
> -     *
> -     * March 2009:
> -     * We now always use the 32-bit address if it is valid (non-null). This
> -     * is not in accordance with the ACPI specification which states that
> -     * the 64-bit address supersedes the 32-bit version, but we do this for
> -     * compatibility with other ACPI implementations. Most notably, in the
> -     * case where both the 32 and 64 versions are non-null, we use the 32-bit
> -     * version. This is the only address that is guaranteed to have been
> -     * tested by the BIOS manufacturer.
> -     */
> -    for (i = 0; i < ACPI_FADT_INFO_ENTRIES; i++)
> -    {
> -        Address32 = *ACPI_ADD_PTR (UINT32,
> -            &AcpiGbl_FADT, FadtInfoTable[i].Address32);
> -
> -        Address64 = ACPI_ADD_PTR (ACPI_GENERIC_ADDRESS,
> -            &AcpiGbl_FADT, FadtInfoTable[i].Address64);
> -
> -        /*
> -         * If both 32- and 64-bit addresses are valid (non-zero),
> -         * they must match.
> -         */
> -        if (Address64->Address && Address32 &&
> -           (Address64->Address != (UINT64) Address32))
> -        {
> -            ACPI_BIOS_ERROR ((AE_INFO,
> -                "32/64X address mismatch in FADT/%s: "
> -                "0x%8.8X/0x%8.8X%8.8X, using 32",
> -                FadtInfoTable[i].Name, Address32,
> -                ACPI_FORMAT_UINT64 (Address64->Address)));
> -        }
> -
> -        /* Always use 32-bit address if it is valid (non-null) */
> -
> -        if (Address32)
> -        {
> -            /*
> -             * Copy the 32-bit address to the 64-bit GAS structure. The
> -             * Space ID is always I/O for 32-bit legacy address fields
> -             */
> -            AcpiTbInitGenericAddress (Address64, ACPI_ADR_SPACE_SYSTEM_IO,
> -                *ACPI_ADD_PTR (UINT8, &AcpiGbl_FADT, FadtInfoTable[i].Length),
> -                (UINT64) Address32, FadtInfoTable[i].Name);
> -        }
> -    }
> -}
> -
> -
> -/*******************************************************************************
> - *
> - * FUNCTION:    AcpiTbValidateFadt
> - *
> - * PARAMETERS:  Table           - Pointer to the FADT to be validated
> - *
> - * RETURN:      None
> - *
> - * DESCRIPTION: Validate various important fields within the FADT. If a problem
> - *              is found, issue a message, but no status is returned.
> - *              Used by both the table manager and the disassembler.
> - *
> - * Possible additional checks:
> - * (AcpiGbl_FADT.Pm1EventLength >= 4)
> - * (AcpiGbl_FADT.Pm1ControlLength >= 2)
> - * (AcpiGbl_FADT.PmTimerLength >= 4)
> - * Gpe block lengths must be multiple of 2
> - *
> - ******************************************************************************/
> -
> -static void
> -AcpiTbValidateFadt (
> -    void)
> -{
> -    char                    *Name;
> -    ACPI_GENERIC_ADDRESS    *Address64;
> -    UINT8                   Length;
> -    UINT32                  i;
> -
> -
> -    /*
> -     * Check for FACS and DSDT address mismatches. An address mismatch between
> -     * the 32-bit and 64-bit address fields (FIRMWARE_CTRL/X_FIRMWARE_CTRL and
> -     * DSDT/X_DSDT) would indicate the presence of two FACS or two DSDT tables.
> +     * Expand the 32-bit FACS and DSDT addresses to 64-bit as necessary.
> +     * Later ACPICA code will always use the X 64-bit field.
> */
> -    if (AcpiGbl_FADT.Facs &&
> -        (AcpiGbl_FADT.XFacs != (UINT64) AcpiGbl_FADT.Facs))
> -    {
> -        ACPI_BIOS_WARNING ((AE_INFO,
> -            "32/64X FACS address mismatch in FADT - "
> -            "0x%8.8X/0x%8.8X%8.8X, using 32",
> -            AcpiGbl_FADT.Facs, ACPI_FORMAT_UINT64 (AcpiGbl_FADT.XFacs)));
> +    AcpiGbl_FADT.XFacs = AcpiTbSelectAddress ("FACS",
> +        AcpiGbl_FADT.Facs, AcpiGbl_FADT.XFacs);
> 
> -        AcpiGbl_FADT.XFacs = (UINT64) AcpiGbl_FADT.Facs;
> -    }
> -
> -    if (AcpiGbl_FADT.Dsdt &&
> -        (AcpiGbl_FADT.XDsdt != (UINT64) AcpiGbl_FADT.Dsdt))
> -    {
> -        ACPI_BIOS_WARNING ((AE_INFO,
> -            "32/64X DSDT address mismatch in FADT - "
> -            "0x%8.8X/0x%8.8X%8.8X, using 32",
> -            AcpiGbl_FADT.Dsdt, ACPI_FORMAT_UINT64 (AcpiGbl_FADT.XDsdt)));
> -
> -        AcpiGbl_FADT.XDsdt = (UINT64) AcpiGbl_FADT.Dsdt;
> -    }
> +    AcpiGbl_FADT.XDsdt = AcpiTbSelectAddress ("DSDT",
> +        AcpiGbl_FADT.Dsdt, AcpiGbl_FADT.XDsdt);
> 
> /* If Hardware Reduced flag is set, we are all done */
> 
> @@ -650,16 +615,82 @@ AcpiTbValidateFadt (
> for (i = 0; i < ACPI_FADT_INFO_ENTRIES; i++)
> {
> /*
> -         * Generate pointer to the 64-bit address, get the register
> -         * length (width) and the register name
> +         * Get the 32-bit and 64-bit addresses, as well as the register
> +         * length and register name.
> */
> +        Address32 = *ACPI_ADD_PTR (UINT32,
> +            &AcpiGbl_FADT, FadtInfoTable[i].Address32);
> +
> Address64 = ACPI_ADD_PTR (ACPI_GENERIC_ADDRESS,
> -                        &AcpiGbl_FADT, FadtInfoTable[i].Address64);
> +            &AcpiGbl_FADT, FadtInfoTable[i].Address64);
> +
> Length = *ACPI_ADD_PTR (UINT8,
> -                        &AcpiGbl_FADT, FadtInfoTable[i].Length);
> +            &AcpiGbl_FADT, FadtInfoTable[i].Length);
> +
> Name = FadtInfoTable[i].Name;
> 
> /*
> +         * Expand the ACPI 1.0 32-bit addresses to the ACPI 2.0 64-bit "X"
> +         * generic address structures as necessary. Later code will always use
> +         * the 64-bit address structures.
> +         *
> +         * November 2013:
> +         * Now always use the 64-bit address if it is valid (non-zero), in
> +         * accordance with the ACPI specification which states that a 64-bit
> +         * address supersedes the 32-bit version. This behavior can be
> +         * overridden by the AcpiGbl_Use32BitFadtAddresses flag.
> +         *
> +         * During 64-bit address construction and verification,
> +         * these cases are handled:
> +         *
> +         * Address32 zero, Address64 [don't care]   - Use Address64
> +         *
> +         * Address32 non-zero, Address64 zero       - Copy/use Address32
> +         * Address32 non-zero == Address64 non-zero - Use Address64
> +         * Address32 non-zero != Address64 non-zero - Warning, use Address64
> +         *
> +         * Override: if AcpiGbl_Use32BitFadtAddresses is TRUE, and:
> +         * Address32 non-zero != Address64 non-zero - Warning, copy/use Address32
> +         *
> +         * Note: SpaceId is always I/O for 32-bit legacy address fields
> +         */
> +        if (Address32)
> +        {
> +            if (!Address64->Address)
> +            {
> +                /* 64-bit address is zero, use 32-bit address */
> +
> +                AcpiTbInitGenericAddress (Address64,
> +                    ACPI_ADR_SPACE_SYSTEM_IO,
> +                    *ACPI_ADD_PTR (UINT8, &AcpiGbl_FADT,
> +                        FadtInfoTable[i].Length),
> +                    (UINT64) Address32, Name);
> +            }
> +            else if (Address64->Address != (UINT64) Address32)
> +            {
> +                /* Address mismatch */
> +
> +                ACPI_BIOS_WARNING ((AE_INFO,
> +                    "32/64X address mismatch in FADT/%s: "
> +                    "0x%8.8X/0x%8.8X%8.8X, using %u-bit address",
> +                    Name, Address32,
> +                    ACPI_FORMAT_UINT64 (Address64->Address),
> +                    AcpiGbl_Use32BitFadtAddresses ? 32 : 64));
> +
> +                if (AcpiGbl_Use32BitFadtAddresses)
> +                {
> +                    /* 32-bit address override */
> +
> +                    AcpiTbInitGenericAddress (Address64,
> +                        ACPI_ADR_SPACE_SYSTEM_IO,
> +                        *ACPI_ADD_PTR (UINT8, &AcpiGbl_FADT,
> +                            FadtInfoTable[i].Length),
> +                        (UINT64) Address32, Name);
> +                }
> +            }
> +        }
> +
> +        /*
> * For each extended field, check for length mismatch between the
> * legacy length field and the corresponding 64-bit X length field.
> * Note: If the legacy length field is > 0xFF bits, ignore this
> diff --git a/src/acpica/source/components/tables/tbutils.c \
> b/src/acpica/source/components/tables/tbutils.c index 1d4a538..97aaef2 100644
> --- a/src/acpica/source/components/tables/tbutils.c
> +++ b/src/acpica/source/components/tables/tbutils.c
> @@ -125,6 +125,10 @@
> 
> /* Local prototypes */
> 
> +static ACPI_STATUS
> +AcpiTbValidateXsdt (
> +    ACPI_PHYSICAL_ADDRESS   Address);
> +
> static ACPI_PHYSICAL_ADDRESS
> AcpiTbGetRootTableEntry (
> UINT8                   *TableEntry,
> @@ -425,7 +429,7 @@ AcpiTbGetRootTableEntry (
> * Get the table physical address (32-bit for RSDT, 64-bit for XSDT):
> * Note: Addresses are 32-bit aligned (not 64) in both RSDT and XSDT
> */
> -    if (TableEntrySize == sizeof (UINT32))
> +    if (TableEntrySize == ACPI_RSDT_ENTRY_SIZE)
> {
> /*
> * 32-bit platform, RSDT: Return 32-bit table entry
> @@ -460,6 +464,92 @@ AcpiTbGetRootTableEntry (
> 
> /*******************************************************************************
> *
> + * FUNCTION:    AcpiTbValidateXsdt
> + *
> + * PARAMETERS:  Address             - Physical address of the XSDT (from RSDP)
> + *
> + * RETURN:      Status. AE_OK if the table appears to be valid.
> + *
> + * DESCRIPTION: Validate an XSDT to ensure that it is of minimum size and does
> + *              not contain any NULL entries. A problem that is seen in the
> + *              field is that the XSDT exists, but is actually useless because
> + *              of one or more (or all) NULL entries.
> + *
> + ******************************************************************************/
> +
> +static ACPI_STATUS
> +AcpiTbValidateXsdt (
> +    ACPI_PHYSICAL_ADDRESS   XsdtAddress)
> +{
> +    ACPI_TABLE_HEADER       *Table;
> +    UINT8                   *NextEntry;
> +    ACPI_PHYSICAL_ADDRESS   Address;
> +    UINT32                  Length;
> +    UINT32                  EntryCount;
> +    ACPI_STATUS             Status;
> +    UINT32                  i;
> +
> +
> +    /* Get the XSDT length */
> +
> +    Table = AcpiOsMapMemory (XsdtAddress, sizeof (ACPI_TABLE_HEADER));
> +    if (!Table)
> +    {
> +        return (AE_NO_MEMORY);
> +    }
> +
> +    Length = Table->Length;
> +    AcpiOsUnmapMemory (Table, sizeof (ACPI_TABLE_HEADER));
> +
> +    /*
> +     * Minimum XSDT length is the size of the standard ACPI header
> +     * plus one physical address entry
> +     */
> +    if (Length < (sizeof (ACPI_TABLE_HEADER) + ACPI_XSDT_ENTRY_SIZE))
> +    {
> +        return (AE_INVALID_TABLE_LENGTH);
> +    }
> +
> +    /* Map the entire XSDT */
> +
> +    Table = AcpiOsMapMemory (XsdtAddress, Length);
> +    if (!Table)
> +    {
> +        return (AE_NO_MEMORY);
> +    }
> +
> +    /* Get the number of entries and pointer to first entry */
> +
> +    Status = AE_OK;
> +    NextEntry = ACPI_ADD_PTR (UINT8, Table, sizeof (ACPI_TABLE_HEADER));
> +    EntryCount = (UINT32) ((Table->Length - sizeof (ACPI_TABLE_HEADER)) /
> +        ACPI_XSDT_ENTRY_SIZE);
> +
> +    /* Validate each entry (physical address) within the XSDT */
> +
> +    for (i = 0; i < EntryCount; i++)
> +    {
> +        Address = AcpiTbGetRootTableEntry (NextEntry, ACPI_XSDT_ENTRY_SIZE);
> +        if (!Address)
> +        {
> +            /* Detected a NULL entry, XSDT is invalid */
> +
> +            Status = AE_NULL_ENTRY;
> +            break;
> +        }
> +
> +        NextEntry += ACPI_XSDT_ENTRY_SIZE;
> +    }
> +
> +    /* Unmap table */
> +
> +    AcpiOsUnmapMemory (Table, Length);
> +    return (Status);
> +}
> +
> +
> +/*******************************************************************************
> + *
> * FUNCTION:    AcpiTbParseRootTable
> *
> * PARAMETERS:  Rsdp                    - Pointer to the RSDP
> @@ -493,9 +583,8 @@ AcpiTbParseRootTable (
> ACPI_FUNCTION_TRACE (TbParseRootTable);
> 
> 
> -    /*
> -     * Map the entire RSDP and extract the address of the RSDT or XSDT
> -     */
> +    /* Map the entire RSDP and extract the address of the RSDT or XSDT */
> +
> Rsdp = AcpiOsMapMemory (RsdpAddress, sizeof (ACPI_TABLE_RSDP));
> if (!Rsdp)
> {
> @@ -505,24 +594,26 @@ AcpiTbParseRootTable (
> AcpiTbPrintTableHeader (RsdpAddress,
> ACPI_CAST_PTR (ACPI_TABLE_HEADER, Rsdp));
> 
> -    /* Differentiate between RSDT and XSDT root tables */
> +    /* Use XSDT if present and not overridden. Otherwise, use RSDT */
> 
> -    if (Rsdp->Revision > 1 && Rsdp->XsdtPhysicalAddress)
> +    if ((Rsdp->Revision > 1) &&
> +        Rsdp->XsdtPhysicalAddress &&
> +        !AcpiGbl_DoNotUseXsdt)
> {
> /*
> -         * Root table is an XSDT (64-bit physical addresses). We must use the
> -         * XSDT if the revision is > 1 and the XSDT pointer is present, as per
> -         * the ACPI specification.
> +         * RSDP contains an XSDT (64-bit physical addresses). We must use
> +         * the XSDT if the revision is > 1 and the XSDT pointer is present,
> +         * as per the ACPI specification.
> */
> Address = (ACPI_PHYSICAL_ADDRESS) Rsdp->XsdtPhysicalAddress;
> -        TableEntrySize = sizeof (UINT64);
> +        TableEntrySize = ACPI_XSDT_ENTRY_SIZE;
> }
> else
> {
> /* Root table is an RSDT (32-bit physical addresses) */
> 
> Address = (ACPI_PHYSICAL_ADDRESS) Rsdp->RsdtPhysicalAddress;
> -        TableEntrySize = sizeof (UINT32);
> +        TableEntrySize = ACPI_RSDT_ENTRY_SIZE;
> }
> 
> /*
> @@ -531,6 +622,24 @@ AcpiTbParseRootTable (
> */
> AcpiOsUnmapMemory (Rsdp, sizeof (ACPI_TABLE_RSDP));
> 
> +    /*
> +     * If it is present and used, validate the XSDT for access/size
> +     * and ensure that all table entries are at least non-NULL
> +     */
> +    if (TableEntrySize == ACPI_XSDT_ENTRY_SIZE)
> +    {
> +        Status = AcpiTbValidateXsdt (Address);
> +        if (ACPI_FAILURE (Status))
> +        {
> +            ACPI_BIOS_WARNING ((AE_INFO, "XSDT is invalid (%s), using RSDT",
> +                AcpiFormatException (Status)));
> +
> +            /* Fall back to the RSDT */
> +
> +            Address = (ACPI_PHYSICAL_ADDRESS) Rsdp->RsdtPhysicalAddress;
> +            TableEntrySize = ACPI_RSDT_ENTRY_SIZE;
> +        }
> +    }
> 
> /* Map the RSDT/XSDT table header to get the full table length */
> 
> @@ -542,12 +651,14 @@ AcpiTbParseRootTable (
> 
> AcpiTbPrintTableHeader (Address, Table);
> 
> -    /* Get the length of the full table, verify length and map entire table */
> -
> +    /*
> +     * Validate length of the table, and map entire table.
> +     * Minimum length table must contain at least one entry.
> +     */
> Length = Table->Length;
> AcpiOsUnmapMemory (Table, sizeof (ACPI_TABLE_HEADER));
> 
> -    if (Length < sizeof (ACPI_TABLE_HEADER))
> +    if (Length < (sizeof (ACPI_TABLE_HEADER) + TableEntrySize))
> {
> ACPI_BIOS_ERROR ((AE_INFO,
> "Invalid table length 0x%X in RSDT/XSDT", Length));
> @@ -569,22 +680,21 @@ AcpiTbParseRootTable (
> return_ACPI_STATUS (Status);
> }
> 
> -    /* Calculate the number of tables described in the root table */
> +    /* Get the number of entries and pointer to first entry */
> 
> TableCount = (UINT32) ((Table->Length - sizeof (ACPI_TABLE_HEADER)) /
> TableEntrySize);
> +    TableEntry = ACPI_ADD_PTR (UINT8, Table, sizeof (ACPI_TABLE_HEADER));
> 
> /*
> * First two entries in the table array are reserved for the DSDT
> * and FACS, which are not actually present in the RSDT/XSDT - they
> * come from the FADT
> */
> -    TableEntry = ACPI_CAST_PTR (UINT8, Table) + sizeof (ACPI_TABLE_HEADER);
> AcpiGbl_RootTableList.CurrentTableCount = 2;
> 
> -    /*
> -     * Initialize the root table array from the RSDT/XSDT
> -     */
> +    /* Initialize the root table array from the RSDT/XSDT */
> +
> for (i = 0; i < TableCount; i++)
> {
> if (AcpiGbl_RootTableList.CurrentTableCount >=
> @@ -626,7 +736,7 @@ AcpiTbParseRootTable (
> AcpiTbInstallTable (AcpiGbl_RootTableList.Tables[i].Address,
> NULL, i);
> 
> -        /* Special case for FADT - get the DSDT and FACS */
> +        /* Special case for FADT - validate it then get the DSDT and FACS */
> 
> if (ACPI_COMPARE_NAME (
> &AcpiGbl_RootTableList.Tables[i].Signature, ACPI_SIG_FADT))
> diff --git a/src/acpica/source/components/utilities/utaddress.c \
> b/src/acpica/source/components/utilities/utaddress.c index 7c0197b..38069cc 100644
> --- a/src/acpica/source/components/utilities/utaddress.c
> +++ b/src/acpica/source/components/utilities/utaddress.c
> @@ -320,10 +320,11 @@ AcpiUtCheckAddressRange (
> while (RangeInfo)
> {
> /*
> -         * Check if the requested Address/Length overlaps this AddressRange.
> -         * Four cases to consider:
> +         * Check if the requested address/length overlaps this
> +         * address range. There are four cases to consider:
> *
> -         * 1) Input address/length is contained completely in the address range
> +         * 1) Input address/length is contained completely in the
> +         *    address range
> * 2) Input address/length overlaps range at the range start
> * 3) Input address/length overlaps range at the range end
> * 4) Input address/length completely encompasses the range
> @@ -339,10 +340,13 @@ AcpiUtCheckAddressRange (
> Pathname = AcpiNsGetExternalPathname (RangeInfo->RegionNode);
> 
> ACPI_WARNING ((AE_INFO,
> -                    "0x%p-0x%p %s conflicts with Region %s %d",
> +                    "%s range 0x%p-0x%p conflicts with OpRegion 0x%p-0x%p (%s)",
> +                    AcpiUtGetRegionName (SpaceId),
> ACPI_CAST_PTR (void, Address),
> ACPI_CAST_PTR (void, EndAddress),
> -                    AcpiUtGetRegionName (SpaceId), Pathname, OverlapCount));
> +                    ACPI_CAST_PTR (void, RangeInfo->StartAddress),
> +                    ACPI_CAST_PTR (void, RangeInfo->EndAddress),
> +                    Pathname));
> ACPI_FREE (Pathname);
> }
> }
> diff --git a/src/acpica/source/components/utilities/utalloc.c \
> b/src/acpica/source/components/utilities/utalloc.c index 5c672fd..cf14068 100644
> --- a/src/acpica/source/components/utilities/utalloc.c
> +++ b/src/acpica/source/components/utilities/utalloc.c
> @@ -396,9 +396,13 @@ AcpiUtInitializeBuffer (
> return (AE_BUFFER_OVERFLOW);
> 
> case ACPI_ALLOCATE_BUFFER:
> -
> -        /* Allocate a new buffer */
> -
> +        /*
> +         * Allocate a new buffer. We directectly call AcpiOsAllocate here to
> +         * purposefully bypass the (optionally enabled) internal allocation
> +         * tracking mechanism since we only want to track internal
> +         * allocations. Note: The caller should use AcpiOsFree to free this
> +         * buffer created via ACPI_ALLOCATE_BUFFER.
> +         */
> Buffer->Pointer = AcpiOsAllocate (RequiredLength);
> break;
> 
> diff --git a/src/acpica/source/components/utilities/utcache.c \
> b/src/acpica/source/components/utilities/utcache.c index 2280027..3a89cd6 100644
> --- a/src/acpica/source/components/utilities/utcache.c
> +++ b/src/acpica/source/components/utilities/utcache.c
> @@ -358,13 +358,13 @@ AcpiOsAcquireObject (
> 
> if (!Cache)
> {
> -        return (NULL);
> +        return_PTR (NULL);
> }
> 
> Status = AcpiUtAcquireMutex (ACPI_MTX_CACHES);
> if (ACPI_FAILURE (Status))
> {
> -        return (NULL);
> +        return_PTR (NULL);
> }
> 
> ACPI_MEM_TRACKING (Cache->Requests++);
> @@ -387,7 +387,7 @@ AcpiOsAcquireObject (
> Status = AcpiUtReleaseMutex (ACPI_MTX_CACHES);
> if (ACPI_FAILURE (Status))
> {
> -            return (NULL);
> +            return_PTR (NULL);
> }
> 
> /* Clear (zero) the previously used Object */
> @@ -412,16 +412,16 @@ AcpiOsAcquireObject (
> Status = AcpiUtReleaseMutex (ACPI_MTX_CACHES);
> if (ACPI_FAILURE (Status))
> {
> -            return (NULL);
> +            return_PTR (NULL);
> }
> 
> Object = ACPI_ALLOCATE_ZEROED (Cache->ObjectSize);
> if (!Object)
> {
> -            return (NULL);
> +            return_PTR (NULL);
> }
> }
> 
> -    return (Object);
> +    return_PTR (Object);
> }
> #endif /* ACPI_USE_LOCAL_CACHE */
> diff --git a/src/acpica/source/components/utilities/utdebug.c \
> b/src/acpica/source/components/utilities/utdebug.c index 0a57f76..eeff454 100644
> --- a/src/acpica/source/components/utilities/utdebug.c
> +++ b/src/acpica/source/components/utilities/utdebug.c
> @@ -292,9 +292,9 @@ AcpiDebugPrint (
> */
> AcpiOsPrintf ("%9s-%04ld ", ModuleName, LineNumber);
> 
> -#ifdef ACPI_EXEC_APP
> +#ifdef ACPI_APPLICATION
> /*
> -     * For AcpiExec only, emit the thread ID and nesting level.
> +     * For AcpiExec/iASL only, emit the thread ID and nesting level.
> * Note: nesting level is really only useful during a single-thread
> * execution. Otherwise, multiple threads will keep resetting the
> * level.
> diff --git a/src/acpica/source/components/utilities/utxfinit.c \
> b/src/acpica/source/components/utilities/utxfinit.c index 9ee0309..3d04a15 100644
> --- a/src/acpica/source/components/utilities/utxfinit.c
> +++ b/src/acpica/source/components/utilities/utxfinit.c
> @@ -203,8 +203,16 @@ AcpiInitializeSubsystem (
> 
> /* If configured, initialize the AML debugger */
> 
> -    ACPI_DEBUGGER_EXEC (Status = AcpiDbInitialize ());
> -    return_ACPI_STATUS (Status);
> +#ifdef ACPI_DEBUGGER
> +    Status = AcpiDbInitialize ();
> +    if (ACPI_FAILURE (Status))
> +    {
> +        ACPI_EXCEPTION ((AE_INFO, Status, "During Debugger initialization"));
> +        return_ACPI_STATUS (Status);
> +    }
> +#endif
> +
> +    return_ACPI_STATUS (AE_OK);
> }
> 
> ACPI_EXPORT_SYMBOL_INIT (AcpiInitializeSubsystem)
> diff --git a/src/acpica/source/include/acdisasm.h \
> b/src/acpica/source/include/acdisasm.h index 571efce..a640af0 100644
> --- a/src/acpica/source/include/acdisasm.h
> +++ b/src/acpica/source/include/acdisasm.h
> @@ -141,14 +141,14 @@ typedef const struct acpi_dmtable_info
> 
> } ACPI_DMTABLE_INFO;
> 
> +/* Values for Flags field above */
> +
> #define DT_LENGTH                       0x01    /* Field is a subtable length */
> #define DT_FLAG                         0x02    /* Field is a flag value */
> #define DT_NON_ZERO                     0x04    /* Field must be non-zero */
> -
> -/* TBD: Not used at this time */
> -
> -#define DT_OPTIONAL                     0x08
> -#define DT_COUNT                        0x10
> +#define DT_OPTIONAL                     0x08    /* Field is optional */
> +#define DT_DESCRIBES_OPTIONAL           0x10    /* Field describes an optional \
> field (length, etc.) */ +#define DT_COUNT                        0x20    /* \
> Currently not used */ 
> /*
> * Values for Opcode above.
> @@ -219,6 +219,7 @@ typedef enum
> ACPI_DMT_HESTNTYP,
> ACPI_DMT_IVRS,
> ACPI_DMT_MADT,
> +    ACPI_DMT_PCCT,
> ACPI_DMT_PMTT,
> ACPI_DMT_SLIC,
> ACPI_DMT_SRAT,
> @@ -316,6 +317,7 @@ extern ACPI_DMTABLE_INFO        AcpiDmTableInfoDbg2Device[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoDbg2Addr[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoDbg2Size[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoDbg2Name[];
> +extern ACPI_DMTABLE_INFO        AcpiDmTableInfoDbg2OemData[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoDbgp[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoDmar[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoDmarHdr[];
> @@ -396,6 +398,7 @@ extern ACPI_DMTABLE_INFO        AcpiDmTableInfoPmtt1a[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoPmtt2[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoPmttHdr[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoPcct[];
> +extern ACPI_DMTABLE_INFO        AcpiDmTableInfoPcctHdr[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoPcct0[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoRsdp1[];
> extern ACPI_DMTABLE_INFO        AcpiDmTableInfoRsdp2[];
> @@ -740,11 +743,19 @@ AcpiDmClearExternalFileList (
> void);
> 
> void
> -AcpiDmAddToExternalList (
> +AcpiDmAddOpToExternalList (
> ACPI_PARSE_OBJECT       *Op,
> char                    *Path,
> UINT8                   Type,
> -    UINT32                  Value);
> +    UINT32                  Value,
> +    UINT16                  Flags);
> +
> +void
> +AcpiDmAddNodeToExternalList (
> +    ACPI_NAMESPACE_NODE     *Node,
> +    UINT8                   Type,
> +    UINT32                  Value,
> +    UINT16                  Flags);
> 
> void
> AcpiDmAddExternalsToNamespace (
> diff --git a/src/acpica/source/include/acevents.h \
> b/src/acpica/source/include/acevents.h index 3205113..ff94961 100644
> --- a/src/acpica/source/include/acevents.h
> +++ b/src/acpica/source/include/acevents.h
> @@ -278,9 +278,10 @@ AcpiEvGetGpeDevice (
> ACPI_GPE_BLOCK_INFO     *GpeBlock,
> void                    *Context);
> 
> -ACPI_GPE_XRUPT_INFO *
> +ACPI_STATUS
> AcpiEvGetGpeXruptBlock (
> -    UINT32                  InterruptNumber);
> +    UINT32                  InterruptNumber,
> +    ACPI_GPE_XRUPT_INFO     **GpeXruptBlock);
> 
> ACPI_STATUS
> AcpiEvDeleteGpeXrupt (
> diff --git a/src/acpica/source/include/acglobal.h \
> b/src/acpica/source/include/acglobal.h index b9ebec5..16dc0ad 100644
> --- a/src/acpica/source/include/acglobal.h
> +++ b/src/acpica/source/include/acglobal.h
> @@ -193,6 +193,25 @@ UINT8       ACPI_INIT_GLOBAL (AcpiGbl_EnableAmlDebugObject, \
> FALSE); UINT8       ACPI_INIT_GLOBAL (AcpiGbl_CopyDsdtLocally, FALSE);
> 
> /*
> + * Optionally ignore an XSDT if present and use the RSDT instead.
> + * Although the ACPI specification requires that an XSDT be used instead
> + * of the RSDT, the XSDT has been found to be corrupt or ill-formed on
> + * some machines. Default behavior is to use the XSDT if present.
> + */
> +UINT8       ACPI_INIT_GLOBAL (AcpiGbl_DoNotUseXsdt, FALSE);
> +
> +
> +/*
> + * Optionally use 32-bit FADT addresses if and when there is a conflict
> + * (address mismatch) between the 32-bit and 64-bit versions of the
> + * address. Although ACPICA adheres to the ACPI specification which
> + * requires the use of the corresponding 64-bit address if it is non-zero,
> + * some machines have been found to have a corrupted non-zero 64-bit
> + * address. Default is FALSE, do not favor the 32-bit addresses.
> + */
> +UINT8       ACPI_INIT_GLOBAL (AcpiGbl_Use32BitFadtAddresses, FALSE);
> +
> +/*
> * Optionally truncate I/O addresses to 16 bits. Provides compatibility
> * with other ACPI implementations. NOTE: During ACPICA initialization,
> * this value is set to TRUE if any Windows OSI strings have been
> @@ -564,6 +583,19 @@ ACPI_EXTERN UINT32                      \
> AcpiGbl_SizeOfAcpiObjects; 
> /*****************************************************************************
> *
> + * Application globals
> + *
> + ****************************************************************************/
> +
> +#ifdef ACPI_APPLICATION
> +
> +ACPI_FILE   ACPI_INIT_GLOBAL (AcpiGbl_DebugFile, NULL);
> +
> +#endif /* ACPI_APPLICATION */
> +
> +
> +/*****************************************************************************
> + *
> * Info/help support
> *
> ****************************************************************************/
> diff --git a/src/acpica/source/include/aclocal.h \
> b/src/acpica/source/include/aclocal.h index 37c46b2..f2f4c1e 100644
> --- a/src/acpica/source/include/aclocal.h
> +++ b/src/acpica/source/include/aclocal.h
> @@ -1290,17 +1290,17 @@ typedef struct acpi_external_list
> struct acpi_external_list   *Next;
> UINT32                      Value;
> UINT16                      Length;
> +    UINT16                      Flags;
> UINT8                       Type;
> -    UINT8                       Flags;
> -    BOOLEAN                     Resolved;
> -    BOOLEAN                     Emitted;
> 
> } ACPI_EXTERNAL_LIST;
> 
> /* Values for Flags field above */
> 
> -#define ACPI_IPATH_ALLOCATED        0x01
> -#define ACPI_FROM_REFERENCE_FILE    0x02
> +#define ACPI_EXT_RESOLVED_REFERENCE         0x01    /* Object was resolved during \
> cross ref */ +#define ACPI_EXT_ORIGIN_FROM_FILE           0x02    /* External came \
> from a file */ +#define ACPI_EXT_INTERNAL_PATH_ALLOCATED    0x04    /* Deallocate \
> internal path on completion */ +#define ACPI_EXT_EXTERNAL_EMITTED           0x08    \
> /* External() statement has been emitted */ 
> 
> typedef struct acpi_external_file
> diff --git a/src/acpica/source/include/acpixf.h \
> b/src/acpica/source/include/acpixf.h index ea0ff78..86a2643 100644
> --- a/src/acpica/source/include/acpixf.h
> +++ b/src/acpica/source/include/acpixf.h
> @@ -119,7 +119,7 @@
> 
> /* Current ACPICA subsystem version in YYYYMMDD format */
> 
> -#define ACPI_CA_VERSION                 0x20131115
> +#define ACPI_CA_VERSION                 0x20131218
> 
> #include "acconfig.h"
> #include "actypes.h"
> @@ -142,17 +142,19 @@ extern UINT32               AcpiDbgLayer;
> 
> /* ACPICA runtime options */
> 
> -extern UINT8                AcpiGbl_EnableInterpreterSlack;
> extern UINT8                AcpiGbl_AllMethodsSerialized;
> -extern UINT8                AcpiGbl_CreateOsiMethod;
> -extern UINT8                AcpiGbl_UseDefaultRegisterWidths;
> -extern ACPI_NAME            AcpiGbl_TraceMethodName;
> -extern UINT32               AcpiGbl_TraceFlags;
> -extern UINT8                AcpiGbl_EnableAmlDebugObject;
> extern UINT8                AcpiGbl_CopyDsdtLocally;
> -extern UINT8                AcpiGbl_TruncateIoAddresses;
> +extern UINT8                AcpiGbl_CreateOsiMethod;
> extern UINT8                AcpiGbl_DisableAutoRepair;
> extern UINT8                AcpiGbl_DisableSsdtTableLoad;
> +extern UINT8                AcpiGbl_DoNotUseXsdt;
> +extern UINT8                AcpiGbl_EnableAmlDebugObject;
> +extern UINT8                AcpiGbl_EnableInterpreterSlack;
> +extern UINT32               AcpiGbl_TraceFlags;
> +extern ACPI_NAME            AcpiGbl_TraceMethodName;
> +extern UINT8                AcpiGbl_TruncateIoAddresses;
> +extern UINT8                AcpiGbl_Use32BitFadtAddresses;
> +extern UINT8                AcpiGbl_UseDefaultRegisterWidths;
> 
> 
> /*
> diff --git a/src/acpica/source/include/actbl.h b/src/acpica/source/include/actbl.h
> index 77ae82c..c1ba0e9 100644
> --- a/src/acpica/source/include/actbl.h
> +++ b/src/acpica/source/include/actbl.h
> @@ -275,6 +275,9 @@ typedef struct acpi_table_xsdt
> 
> } ACPI_TABLE_XSDT;
> 
> +#define ACPI_RSDT_ENTRY_SIZE        (sizeof (UINT32))
> +#define ACPI_XSDT_ENTRY_SIZE        (sizeof (UINT64))
> +
> 
> /*******************************************************************************
> *
> diff --git a/src/acpica/source/include/actbl1.h \
> b/src/acpica/source/include/actbl1.h index 883547c..0476fa5 100644
> --- a/src/acpica/source/include/actbl1.h
> +++ b/src/acpica/source/include/actbl1.h
> @@ -596,7 +596,7 @@ typedef struct acpi_hest_aer_common
> UINT8                   Enabled;
> UINT32                  RecordsToPreallocate;
> UINT32                  MaxSectionsPerRecord;
> -    UINT32                  Bus;
> +    UINT32                  Bus;                    /* Bus and Segment numbers */
> UINT16                  Device;
> UINT16                  Function;
> UINT16                  DeviceControl;
> @@ -613,6 +613,14 @@ typedef struct acpi_hest_aer_common
> #define ACPI_HEST_FIRMWARE_FIRST        (1)
> #define ACPI_HEST_GLOBAL                (1<<1)
> 
> +/*
> + * Macros to access the bus/segment numbers in Bus field above:
> + *  Bus number is encoded in bits 7:0
> + *  Segment number is encoded in bits 23:8
> + */
> +#define ACPI_HEST_BUS(Bus)              ((Bus) & 0xFF)
> +#define ACPI_HEST_SEGMENT(Bus)          (((Bus) >> 8) & 0xFFFF)
> +
> 
> /* Hardware Error Notification */
> 
> diff --git a/src/acpica/source/include/actbl2.h \
> b/src/acpica/source/include/actbl2.h index 3479648..1443d24 100644
> --- a/src/acpica/source/include/actbl2.h
> +++ b/src/acpica/source/include/actbl2.h
> @@ -445,6 +445,14 @@ typedef struct acpi_table_dbg2
> } ACPI_TABLE_DBG2;
> 
> 
> +typedef struct acpi_dbg2_header
> +{
> +    UINT32                  InfoOffset;
> +    UINT32                  InfoCount;
> +
> +} ACPI_DBG2_HEADER;
> +
> +
> /* Debug Device Information Subtable */
> 
> typedef struct acpi_dbg2_device
> diff --git a/src/acpica/source/include/actbl3.h \
> b/src/acpica/source/include/actbl3.h index 85ff620..51ab879 100644
> --- a/src/acpica/source/include/actbl3.h
> +++ b/src/acpica/source/include/actbl3.h
> @@ -512,8 +512,7 @@ typedef struct acpi_table_pcct
> {
> ACPI_TABLE_HEADER       Header;             /* Common ACPI table header */
> UINT32                  Flags;
> -    UINT32                  Latency;
> -    UINT32                  Reserved;
> +    UINT64                  Reserved;
> 
> } ACPI_TABLE_PCCT;
> 
> @@ -521,8 +520,16 @@ typedef struct acpi_table_pcct
> 
> #define ACPI_PCCT_DOORBELL              1
> 
> +/* Values for subtable type in ACPI_SUBTABLE_HEADER */
> +
> +enum AcpiPcctType
> +{
> +    ACPI_PCCT_TYPE_GENERIC_SUBSPACE     = 0,
> +    ACPI_PCCT_TYPE_RESERVED             = 1     /* 1 and greater are reserved */
> +};
> +
> /*
> - * PCCT subtables
> + * PCCT Subtables, correspond to Type in ACPI_SUBTABLE_HEADER
> */
> 
> /* 0: Generic Communications Subspace */
> @@ -536,6 +543,9 @@ typedef struct acpi_pcct_subspace
> ACPI_GENERIC_ADDRESS    DoorbellRegister;
> UINT64                  PreserveMask;
> UINT64                  WriteMask;
> +    UINT32                  Latency;
> +    UINT32                  MaxAccessRate;
> +    UINT16                  MinTurnaroundTime;
> 
> } ACPI_PCCT_SUBSPACE;
> 
> diff --git a/src/acpica/source/include/actypes.h \
> b/src/acpica/source/include/actypes.h index 072b946..b134fc2 100644
> --- a/src/acpica/source/include/actypes.h
> +++ b/src/acpica/source/include/actypes.h
> @@ -1026,8 +1026,8 @@ typedef struct acpi_object_list
> * Miscellaneous common Data Structures used by the interfaces
> */
> #define ACPI_NO_BUFFER              0
> -#define ACPI_ALLOCATE_BUFFER        (ACPI_SIZE) (-1)
> -#define ACPI_ALLOCATE_LOCAL_BUFFER  (ACPI_SIZE) (-2)
> +#define ACPI_ALLOCATE_BUFFER        (ACPI_SIZE) (-1)    /* Let ACPICA allocate \
> buffer */ +#define ACPI_ALLOCATE_LOCAL_BUFFER  (ACPI_SIZE) (-2)    /* For internal \
> use only (enables tracking) */ 
> typedef struct acpi_buffer
> {
> @@ -1036,10 +1036,6 @@ typedef struct acpi_buffer
> 
> } ACPI_BUFFER;
> 
> -/* Free a buffer created in an ACPI_BUFFER via ACPI_ALLOCATE_LOCAL_BUFFER */
> -
> -#define ACPI_FREE_BUFFER(b)         ACPI_FREE(b.Pointer)
> -
> 
> /*
> * NameType for AcpiGetName
> diff --git a/src/acpica/source/include/platform/acenv.h \
> b/src/acpica/source/include/platform/acenv.h index 3838e79..79ae6aa 100644
> --- a/src/acpica/source/include/platform/acenv.h
> +++ b/src/acpica/source/include/platform/acenv.h
> @@ -169,13 +169,14 @@
> #endif
> 
> /*
> - * AcpiBin/AcpiDump/AcpiSrc/AcpiXtract configuration. All single
> + * AcpiBin/AcpiDump/AcpiSrc/AcpiXtract/Example configuration. All single
> * threaded, with no debug output.
> */
> -#if (defined ACPI_BIN_APP)   || \
> -    (defined ACPI_DUMP_APP)  || \
> -    (defined ACPI_SRC_APP)   || \
> -    (defined ACPI_XTRACT_APP)
> +#if (defined ACPI_BIN_APP)      || \
> +    (defined ACPI_DUMP_APP)     || \
> +    (defined ACPI_SRC_APP)      || \
> +    (defined ACPI_XTRACT_APP)   || \
> +    (defined ACPI_EXAMPLE_APP)
> #define ACPI_APPLICATION
> #define ACPI_SINGLE_THREADED
> #endif
> @@ -468,4 +469,13 @@ typedef char *va_list;
> 
> #endif /* ACPI_USE_SYSTEM_CLIBRARY */
> 
> +#ifndef ACPI_FILE
> +#ifdef ACPI_APPLICATION
> +#include <stdio.h>
> +#define ACPI_FILE              FILE *
> +#else
> +#define ACPI_FILE              void *
> +#endif /* ACPI_APPLICATION */
> +#endif /* ACPI_FILE */
> +
> #endif /* __ACENV_H__ */
> diff --git a/src/acpica/source/include/platform/aclinux.h \
> b/src/acpica/source/include/platform/aclinux.h index e806e59..2d04973 100644
> --- a/src/acpica/source/include/platform/aclinux.h
> +++ b/src/acpica/source/include/platform/aclinux.h
> @@ -329,14 +329,6 @@ EarlyAcpiOsUnmapMemory (
> void __iomem            *Virt,
> ACPI_SIZE               Size);
> 
> -void
> -AcpiOsGpeCount (
> -    UINT32                  GpeNumber);
> -
> -void
> -AcpiOsFixedEventCount (
> -    UINT32                  FixedEventNumber);
> -
> ACPI_STATUS
> AcpiOsHotplugExecute (
> ACPI_OSD_EXEC_CALLBACK  Function,
> diff --git a/src/acpica/source/os_specific/service_layers/osunixxf.c \
> b/src/acpica/source/os_specific/service_layers/osunixxf.c index ad003c1..5e2c538 \
>                 100644
> --- a/src/acpica/source/os_specific/service_layers/osunixxf.c
> +++ b/src/acpica/source/os_specific/service_layers/osunixxf.c
> @@ -137,7 +137,6 @@
> ACPI_MODULE_NAME    ("osunixxf")
> 
> 
> -extern FILE                    *AcpiGbl_DebugFile;
> FILE                           *AcpiGbl_OutputFile;
> BOOLEAN                        AcpiGbl_DebugTimeout = FALSE;
> 
> diff --git a/src/acpica/source/tools/acpiexec/aecommon.h \
> b/src/acpica/source/tools/acpiexec/aecommon.h index 4083b69..8375bea 100644
> --- a/src/acpica/source/tools/acpiexec/aecommon.h
> +++ b/src/acpica/source/tools/acpiexec/aecommon.h
> @@ -135,7 +135,6 @@
> #include <string.h>
> #include <signal.h>
> 
> -extern FILE                 *AcpiGbl_DebugFile;
> extern BOOLEAN              AcpiGbl_IgnoreErrors;
> extern UINT8                AcpiGbl_RegionFillValue;
> extern UINT8                AcpiGbl_UseHwReducedFadt;
> diff --git a/src/acpica/source/tools/acpiexec/aehandlers.c \
> b/src/acpica/source/tools/acpiexec/aehandlers.c index 294abea..fe1fb8c 100644
> --- a/src/acpica/source/tools/acpiexec/aehandlers.c
> +++ b/src/acpica/source/tools/acpiexec/aehandlers.c
> @@ -532,6 +532,8 @@ AeExceptionHandler (
> NewAmlStatus = (ACPI_STATUS)
> ((ACPI_OBJECT *) ReturnObj.Pointer)->Integer.Value;
> 
> +            /* Free a buffer created via ACPI_ALLOCATE_BUFFER */
> +
> AcpiOsFree (ReturnObj.Pointer);
> }
> }
> @@ -1121,21 +1123,11 @@ AeInstallEarlyHandlers (
> Status = AcpiDetachData (Handle, AeAttachedDataHandler);
> AE_CHECK_OK (AcpiDetachData, Status);
> 
> -        /* Test attach data at the root object */
> -
> -        Status = AcpiAttachData (ACPI_ROOT_OBJECT, AeAttachedDataHandler,
> -            AcpiGbl_RootNode);
> -        AE_CHECK_OK (AcpiAttachData, Status);
> -
> -        Status = AcpiAttachData (ACPI_ROOT_OBJECT, AeAttachedDataHandler2,
> -            AcpiGbl_RootNode);
> +        Status = AcpiAttachData (Handle, AeAttachedDataHandler, Handle);
> AE_CHECK_OK (AcpiAttachData, Status);
> 
> /* Test support for multiple attaches */
> 
> -        Status = AcpiAttachData (Handle, AeAttachedDataHandler, Handle);
> -        AE_CHECK_OK (AcpiAttachData, Status);
> -
> Status = AcpiAttachData (Handle, AeAttachedDataHandler2, Handle);
> AE_CHECK_OK (AcpiAttachData, Status);
> }
> --
> 1.8.5.2
> 

Acked-by: Keng-Yu Lin <kengyu@canonical.com>


[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic