Index: acconfig.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acconfig.h,v retrieving revision 1.18 diff -u -r1.18 acconfig.h --- acconfig.h 30 Jun 2002 17:53:04 -0000 1.18 +++ acconfig.h 1 Jul 2002 21:39:53 -0000 @@ -145,36 +145,36 @@ /* Version string */ -#define ACPI_CA_VERSION 0x20020403 +#define ACPI_CA_VERSION 0x20020611 /* Version of ACPI supported */ -#define ACPI_CA_SUPPORT_LEVEL 2 +#define ACPI_CA_SUPPORT_LEVEL 2 /* Maximum objects in the various object caches */ -#define MAX_STATE_CACHE_DEPTH 64 /* State objects for stacks */ -#define MAX_PARSE_CACHE_DEPTH 96 /* Parse tree objects */ -#define MAX_EXTPARSE_CACHE_DEPTH 64 /* Parse tree objects */ -#define MAX_OBJECT_CACHE_DEPTH 64 /* Interpreter operand objects */ -#define MAX_WALK_CACHE_DEPTH 4 /* Objects for parse tree walks */ +#define MAX_STATE_CACHE_DEPTH 64 /* State objects for stacks */ +#define MAX_PARSE_CACHE_DEPTH 96 /* Parse tree objects */ +#define MAX_EXTPARSE_CACHE_DEPTH 64 /* Parse tree objects */ +#define MAX_OBJECT_CACHE_DEPTH 64 /* Interpreter operand objects */ +#define MAX_WALK_CACHE_DEPTH 4 /* Objects for parse tree walks */ /* String size constants */ -#define MAX_STRING_LENGTH 512 -#define PATHNAME_MAX 256 /* A full namespace pathname */ +#define MAX_STRING_LENGTH 512 +#define PATHNAME_MAX 256 /* A full namespace pathname */ /* Maximum count for a semaphore object */ -#define MAX_SEMAPHORE_COUNT 256 +#define MAX_SEMAPHORE_COUNT 256 /* Max reference count (for debug only) */ -#define MAX_REFERENCE_COUNT 0x400 +#define MAX_REFERENCE_COUNT 0x400 /* Size of cached memory mapping for system memory operation region */ -#define SYSMEM_REGION_WINDOW_SIZE 4096 +#define SYSMEM_REGION_WINDOW_SIZE 4096 /****************************************************************************** @@ -183,31 +183,12 @@ * *****************************************************************************/ -/* - * Debugger threading model - * Use single threaded if the entire subsystem is contained in an application - * Use multiple threaded when the subsystem is running in the kernel. - * - * By default the model is single threaded if ACPI_APPLICATION is set, - * multi-threaded if ACPI_APPLICATION is not set. - */ -#define DEBUGGER_SINGLE_THREADED 0 -#define DEBUGGER_MULTI_THREADED 1 - -#ifndef DEBUGGER_THREADING -#ifdef ACPI_APPLICATION -#define DEBUGGER_THREADING DEBUGGER_SINGLE_THREADED - -#else -#define DEBUGGER_THREADING DEBUGGER_MULTI_THREADED -#endif -#endif /* * Should the subystem abort the loading of an ACPI table if the * table checksum is incorrect? */ -#define ACPI_CHECKSUM_ABORT FALSE +#define ACPI_CHECKSUM_ABORT FALSE /****************************************************************************** @@ -218,54 +199,54 @@ /* Number of distinct GPE register blocks */ -#define ACPI_MAX_GPE_BLOCKS 2 +#define ACPI_MAX_GPE_BLOCKS 2 /* * Method info (in WALK_STATE), containing local variables and argumetns */ -#define MTH_NUM_LOCALS 8 -#define MTH_MAX_LOCAL 7 +#define MTH_NUM_LOCALS 8 +#define MTH_MAX_LOCAL 7 -#define MTH_NUM_ARGS 7 -#define MTH_MAX_ARG 6 +#define MTH_NUM_ARGS 7 +#define MTH_MAX_ARG 6 /* Maximum length of resulting string when converting from a buffer */ -#define ACPI_MAX_STRING_CONVERSION 200 +#define ACPI_MAX_STRING_CONVERSION 200 /* * Operand Stack (in WALK_STATE), Must be large enough to contain MTH_MAX_ARG */ -#define OBJ_NUM_OPERANDS 8 -#define OBJ_MAX_OPERAND 7 +#define OBJ_NUM_OPERANDS 8 +#define OBJ_MAX_OPERAND 7 /* Names within the namespace are 4 bytes long */ -#define ACPI_NAME_SIZE 4 -#define PATH_SEGMENT_LENGTH 5 /* 4 chars for name + 1 char for separator */ -#define PATH_SEPARATOR '.' +#define ACPI_NAME_SIZE 4 +#define PATH_SEGMENT_LENGTH 5 /* 4 chars for name + 1 char for separator */ +#define PATH_SEPARATOR '.' /* Constants used in searching for the RSDP in low memory */ -#define LO_RSDP_WINDOW_BASE 0 /* Physical Address */ -#define HI_RSDP_WINDOW_BASE 0xE0000 /* Physical Address */ -#define LO_RSDP_WINDOW_SIZE 0x400 -#define HI_RSDP_WINDOW_SIZE 0x20000 -#define RSDP_SCAN_STEP 16 +#define LO_RSDP_WINDOW_BASE 0 /* Physical Address */ +#define HI_RSDP_WINDOW_BASE 0xE0000 /* Physical Address */ +#define LO_RSDP_WINDOW_SIZE 0x400 +#define HI_RSDP_WINDOW_SIZE 0x20000 +#define RSDP_SCAN_STEP 16 /* Operation regions */ -#define ACPI_NUM_PREDEFINED_REGIONS 8 -#define ACPI_USER_REGION_BEGIN 0x80 +#define ACPI_NUM_PREDEFINED_REGIONS 8 +#define ACPI_USER_REGION_BEGIN 0x80 /* Maximum SpaceIds for Operation Regions */ -#define ACPI_MAX_ADDRESS_SPACE 255 +#define ACPI_MAX_ADDRESS_SPACE 255 /* RSDP checksums */ -#define ACPI_RSDP_CHECKSUM_LENGTH 20 -#define ACPI_RSDP_XCHECKSUM_LENGTH 36 +#define ACPI_RSDP_CHECKSUM_LENGTH 20 +#define ACPI_RSDP_XCHECKSUM_LENGTH 36 /****************************************************************************** @@ -275,10 +256,10 @@ *****************************************************************************/ -#define ACPI_DEBUGGER_MAX_ARGS 8 /* Must be max method args + 1 */ +#define ACPI_DEBUGGER_MAX_ARGS 8 /* Must be max method args + 1 */ -#define ACPI_DEBUGGER_COMMAND_PROMPT '-' -#define ACPI_DEBUGGER_EXECUTE_PROMPT '%' +#define ACPI_DEBUGGER_COMMAND_PROMPT '-' +#define ACPI_DEBUGGER_EXECUTE_PROMPT '%' #endif /* _ACCONFIG_H */ Index: acdebug.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acdebug.h,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 acdebug.h --- acdebug.h 30 Jun 2002 17:50:42 -0000 1.1.1.11 +++ acdebug.h 1 Jul 2002 21:39:53 -0000 @@ -154,7 +154,7 @@ * dbapi - external debugger interfaces */ -int +ACPI_STATUS AcpiDbInitialize ( void); @@ -173,7 +173,6 @@ * dbcmds - debug commands and output routines */ - void AcpiDbDisplayTableInfo ( NATIVE_CHAR *TableArg); @@ -244,6 +243,39 @@ AcpiDbDisplayResources ( NATIVE_CHAR *ObjectArg); +void +AcpiDbCheckIntegrity ( + void); + +ACPI_STATUS +AcpiDbIntegrityWalk ( + ACPI_HANDLE ObjHandle, + UINT32 NestingLevel, + void *Context, + void **ReturnValue); + +ACPI_STATUS +AcpiDbWalkAndMatchName ( + ACPI_HANDLE ObjHandle, + UINT32 NestingLevel, + void *Context, + void **ReturnValue); + +ACPI_STATUS +AcpiDbWalkForReferences ( + ACPI_HANDLE ObjHandle, + UINT32 NestingLevel, + void *Context, + void **ReturnValue); + +ACPI_STATUS +AcpiDbWalkForSpecificObjects ( + ACPI_HANDLE ObjHandle, + UINT32 NestingLevel, + void *Context, + void **ReturnValue); + + /* * dbdisasm - AML disassembler @@ -272,12 +304,20 @@ AcpiDbDecodeInternalObject ( ACPI_OPERAND_OBJECT *ObjDesc); +UINT32 +AcpiDbBlockType ( + ACPI_PARSE_OBJECT *Op); + +ACPI_STATUS +AcpiPsDisplayObjectPathname ( + ACPI_WALK_STATE *WalkState, + ACPI_PARSE_OBJECT *Op); + /* * dbdisply - debug display commands */ - void AcpiDbDisplayMethodInfo ( ACPI_PARSE_OBJECT *Op); @@ -322,6 +362,14 @@ ACPI_OPERAND_OBJECT *ObjDesc, ACPI_WALK_STATE *WalkState); +void +AcpiDbDumpParserDescriptor ( + ACPI_PARSE_OBJECT *Op); + +void * +AcpiDbGetPointer ( + void *Target); + /* * dbexec - debugger control method execution @@ -339,6 +387,23 @@ NATIVE_CHAR *NumLoopsArg, NATIVE_CHAR *MethodNameArg); +ACPI_STATUS +AcpiDbExecuteMethod ( + ACPI_DB_METHOD_INFO *Info, + ACPI_BUFFER *ReturnObj); + +void +AcpiDbExecuteSetup ( + ACPI_DB_METHOD_INFO *Info); + +UINT32 +AcpiDbGetOutstandingAllocations ( + void); + +void ACPI_SYSTEM_XFACE +AcpiDbMethodThread ( + void *Context); + /* * dbfileio - Debugger file I/O commands @@ -349,6 +414,9 @@ NATIVE_CHAR *UserArgument, ARGUMENT_INFO *Arguments); +ACPI_STATUS +AeLocalLoadTable ( + ACPI_TABLE_HEADER *TablePtr); void AcpiDbCloseDebugFile ( @@ -401,6 +469,27 @@ NATIVE_CHAR Prompt, ACPI_PARSE_OBJECT *Op); +void +AcpiDbDisplayHelp ( + NATIVE_CHAR *HelpType); + +NATIVE_CHAR * +AcpiDbGetNextToken ( + NATIVE_CHAR *String, + NATIVE_CHAR **Next); + +UINT32 +AcpiDbGetLine ( + NATIVE_CHAR *InputBuffer); + +UINT32 +AcpiDbMatchCommand ( + NATIVE_CHAR *UserCommand); + +void +AcpiDbSingleThread ( + void); + /* * dbstats - Generation and display of ACPI table statistics @@ -415,6 +504,21 @@ ACPI_STATUS AcpiDbDisplayStatistics ( NATIVE_CHAR *TypeArg); + +ACPI_STATUS +AcpiDbClassifyOneObject ( + ACPI_HANDLE ObjHandle, + UINT32 NestingLevel, + void *Context, + void **ReturnValue); + +void +AcpiDbCountNamespaceObjects ( + void); + +void +AcpiDbEnumerateObject ( + ACPI_OPERAND_OBJECT *ObjDesc); /* Index: acdispat.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acdispat.h,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 acdispat.h --- acdispat.h 30 Jun 2002 17:50:42 -0000 1.1.1.11 +++ acdispat.h 1 Jul 2002 21:39:53 -0000 @@ -149,6 +149,13 @@ /* dsopcode - support for late evaluation */ ACPI_STATUS +AcpiDsExecuteArguments ( + ACPI_NAMESPACE_NODE *Node, + ACPI_NAMESPACE_NODE *ScopeNode, + UINT32 AmlLength, + UINT8 *AmlStart); + +ACPI_STATUS AcpiDsGetBufferFieldArguments ( ACPI_OPERAND_OBJECT *ObjDesc); @@ -164,6 +171,35 @@ AcpiDsGetPackageArguments ( ACPI_OPERAND_OBJECT *ObjDesc); +ACPI_STATUS +AcpiDsInitBufferField ( + UINT16 AmlOpcode, + ACPI_OPERAND_OBJECT *ObjDesc, + ACPI_OPERAND_OBJECT *BufferDesc, + ACPI_OPERAND_OBJECT *OffsetDesc, + ACPI_OPERAND_OBJECT *LengthDesc, + ACPI_OPERAND_OBJECT *ResultDesc); + +ACPI_STATUS +AcpiDsEvalBufferFieldOperands ( + ACPI_WALK_STATE *WalkState, + ACPI_PARSE_OBJECT *Op); + +ACPI_STATUS +AcpiDsEvalRegionOperands ( + ACPI_WALK_STATE *WalkState, + ACPI_PARSE_OBJECT *Op); + +ACPI_STATUS +AcpiDsEvalDataObjectOperands ( + ACPI_WALK_STATE *WalkState, + ACPI_PARSE_OBJECT *Op, + ACPI_OPERAND_OBJECT *ObjDesc); + +ACPI_STATUS +AcpiDsInitializeRegion ( + ACPI_HANDLE ObjHandle); + /* dsctrl - Parser/Interpreter interface, control stack routines */ @@ -200,6 +236,12 @@ /* dsfield - Parser/Interpreter interface for AML fields */ ACPI_STATUS +AcpiDsGetFieldNames ( + ACPI_CREATE_FIELD_INFO *Info, + ACPI_WALK_STATE *WalkState, + ACPI_PARSE_OBJECT *Arg); + +ACPI_STATUS AcpiDsCreateField ( ACPI_PARSE_OBJECT *Op, ACPI_NAMESPACE_NODE *RegionNode, @@ -271,7 +313,7 @@ ACPI_WALK_STATE *WalkState, ACPI_OPERAND_OBJECT ***Node); -ACPI_STATUS +void AcpiDsMethodDataDeleteAll ( ACPI_WALK_STATE *WalkState); @@ -292,7 +334,7 @@ ACPI_WALK_STATE *WalkState, ACPI_OPERAND_OBJECT **DestDesc); -ACPI_STATUS +void AcpiDsMethodDataDeleteValue ( UINT16 Opcode, UINT32 Index, @@ -311,7 +353,7 @@ ACPI_WALK_STATE *WalkState, ACPI_NAMESPACE_NODE **Node); -ACPI_STATUS +void AcpiDsMethodDataInit ( ACPI_WALK_STATE *WalkState); @@ -397,29 +439,6 @@ ACPI_WALK_STATE *WalkState, ACPI_NAMESPACE_NODE *Node, ACPI_PARSE_OBJECT *Op); - - -/* dsregn - Parser/Interpreter interface - Op Region parsing */ - -ACPI_STATUS -AcpiDsEvalBufferFieldOperands ( - ACPI_WALK_STATE *WalkState, - ACPI_PARSE_OBJECT *Op); - -ACPI_STATUS -AcpiDsEvalRegionOperands ( - ACPI_WALK_STATE *WalkState, - ACPI_PARSE_OBJECT *Op); - -ACPI_STATUS -AcpiDsEvalDataObjectOperands ( - ACPI_WALK_STATE *WalkState, - ACPI_PARSE_OBJECT *Op, - ACPI_OPERAND_OBJECT *ObjDesc); - -ACPI_STATUS -AcpiDsInitializeRegion ( - ACPI_HANDLE ObjHandle); /* dsutils - Parser/Interpreter interface utility routines */ Index: acenv.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acenv.h,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 acenv.h --- acenv.h 30 Jun 2002 17:50:43 -0000 1.1.1.10 +++ acenv.h 1 Jul 2002 21:39:53 -0000 @@ -142,22 +142,11 @@ #ifdef _ACPI_ASL_COMPILER #define ACPI_DEBUG #define ACPI_APPLICATION -#define ENABLE_DEBUGGER +/* #define ENABLE_DEBUGGER */ #define ACPI_USE_SYSTEM_CLIBRARY #endif /* - * Memory allocation tracking. Used only if - * 1) This is the debug version - * 2) This is NOT a 16-bit version of the code (not enough real-mode memory) - */ -#ifdef ACPI_DEBUG -#ifndef _IA16 -#define ACPI_DBG_TRACK_ALLOCATIONS -#endif -#endif - -/* * Environment configuration. The purpose of this file is to interface to the * local generation environment. * @@ -202,15 +191,15 @@ #elif defined(_AED_EFI) #include "acefi.h" -#elif defined(MSDOS) -#include "acdos16.h" - #elif defined(WIN32) #include "acwin.h" #elif defined(WIN64) #include "acwin64.h" +#elif defined(MSDOS) /* Must appear after WIN32 and WIN64 check */ +#include "acdos16.h" + #elif defined(__FreeBSD__) #include "acfreebsd.h" @@ -226,6 +215,10 @@ #define ACPI_USE_STANDARD_HEADERS +#define COMPILER_DEPENDENT_INT64 long long +#define COMPILER_DEPENDENT_UINT64 unsigned long long + + /* Name of host operating system (returned by the _OS_ namespace object) */ #define ACPI_OS_NAME "Intel ACPI/CA Core Subsystem" @@ -238,8 +231,41 @@ #endif +/* + * Memory allocation tracking. Used only if + * 1) This is the debug version + * 2) This is NOT a 16-bit version of the code (not enough real-mode memory) + */ +#ifdef ACPI_DEBUG +#if ACPI_MACHINE_WIDTH != 16 +#define ACPI_DBG_TRACK_ALLOCATIONS +#endif +#endif + /*! [End] no source code translation !*/ + +/* + * Debugger threading model + * Use single threaded if the entire subsystem is contained in an application + * Use multiple threaded when the subsystem is running in the kernel. + * + * By default the model is single threaded if ACPI_APPLICATION is set, + * multi-threaded if ACPI_APPLICATION is not set. + */ +#define DEBUGGER_SINGLE_THREADED 0 +#define DEBUGGER_MULTI_THREADED 1 + +#ifndef DEBUGGER_THREADING +#ifdef ACPI_APPLICATION +#define DEBUGGER_THREADING DEBUGGER_SINGLE_THREADED + +#else +#define DEBUGGER_THREADING DEBUGGER_MULTI_THREADED +#endif +#endif + + /****************************************************************************** * * C library configuration @@ -269,20 +295,23 @@ */ #define ACPI_STRSTR(s1,s2) strstr((s1), (s2)) -#define ACPI_STRUPR(s) AcpiUtStrupr ((s)) -#define ACPI_STRLEN(s) (UINT32) strlen((s)) -#define ACPI_STRCPY(d,s) strcpy((d), (s)) -#define ACPI_STRNCPY(d,s,n) strncpy((d), (s), (NATIVE_INT)(n)) -#define ACPI_STRNCMP(d,s,n) strncmp((d), (s), (NATIVE_INT)(n)) +#define ACPI_STRUPR(s) (void) AcpiUtStrupr ((s)) +#define ACPI_STRLEN(s) (ACPI_SIZE) strlen((s)) +#define ACPI_STRCPY(d,s) (void) strcpy((d), (s)) +#define ACPI_STRNCPY(d,s,n) (void) strncpy((d), (s), (ACPI_SIZE)(n)) +#define ACPI_STRNCMP(d,s,n) strncmp((d), (s), (ACPI_SIZE)(n)) #define ACPI_STRCMP(d,s) strcmp((d), (s)) -#define ACPI_STRCAT(d,s) strcat((d), (s)) -#define ACPI_STRNCAT(d,s,n) strncat((d), (s), (NATIVE_INT)(n)) -#define ACPI_STRTOUL(d,s,n) strtoul((d), (s), (NATIVE_INT)(n)) -#define ACPI_MEMCPY(d,s,n) (void) memcpy((d), (s), (NATIVE_INT)(n)) -#define ACPI_MEMSET(d,s,n) (void) memset((d), (s), (NATIVE_INT)(n)) +#define ACPI_STRCAT(d,s) (void) strcat((d), (s)) +#define ACPI_STRNCAT(d,s,n) strncat((d), (s), (ACPI_SIZE)(n)) +#define ACPI_STRTOUL(d,s,n) strtoul((d), (s), (ACPI_SIZE)(n)) +#define ACPI_MEMCPY(d,s,n) (void) memcpy((d), (s), (ACPI_SIZE)(n)) +#define ACPI_MEMSET(d,s,n) (void) memset((d), (s), (ACPI_SIZE)(n)) #define ACPI_TOUPPER toupper #define ACPI_TOLOWER tolower #define ACPI_IS_XDIGIT isxdigit +#define ACPI_IS_DIGIT isdigit +#define ACPI_IS_SPACE isspace +#define ACPI_IS_UPPER isupper /****************************************************************************** * @@ -325,17 +354,17 @@ #define ACPI_STRSTR(s1,s2) AcpiUtStrstr ((s1), (s2)) -#define ACPI_STRUPR(s) AcpiUtStrupr ((s)) -#define ACPI_STRLEN(s) AcpiUtStrlen ((s)) -#define ACPI_STRCPY(d,s) AcpiUtStrcpy ((d), (s)) -#define ACPI_STRNCPY(d,s,n) AcpiUtStrncpy ((d), (s), (n)) -#define ACPI_STRNCMP(d,s,n) AcpiUtStrncmp ((d), (s), (n)) +#define ACPI_STRUPR(s) (void) AcpiUtStrupr ((s)) +#define ACPI_STRLEN(s) (ACPI_SIZE) AcpiUtStrlen ((s)) +#define ACPI_STRCPY(d,s) (void) AcpiUtStrcpy ((d), (s)) +#define ACPI_STRNCPY(d,s,n) (void) AcpiUtStrncpy ((d), (s), (ACPI_SIZE)(n)) +#define ACPI_STRNCMP(d,s,n) AcpiUtStrncmp ((d), (s), (ACPI_SIZE)(n)) #define ACPI_STRCMP(d,s) AcpiUtStrcmp ((d), (s)) -#define ACPI_STRCAT(d,s) AcpiUtStrcat ((d), (s)) -#define ACPI_STRNCAT(d,s,n) AcpiUtStrncat ((d), (s), (n)) -#define ACPI_STRTOUL(d,s,n) AcpiUtStrtoul ((d), (s),(n)) -#define ACPI_MEMCPY(d,s,n) (void) AcpiUtMemcpy ((d), (s), (n)) -#define ACPI_MEMSET(d,v,n) (void) AcpiUtMemset ((d), (v), (n)) +#define ACPI_STRCAT(d,s) (void) AcpiUtStrcat ((d), (s)) +#define ACPI_STRNCAT(d,s,n) AcpiUtStrncat ((d), (s), (ACPI_SIZE)(n)) +#define ACPI_STRTOUL(d,s,n) AcpiUtStrtoul ((d), (s), (ACPI_SIZE)(n)) +#define ACPI_MEMCPY(d,s,n) (void) AcpiUtMemcpy ((d), (s), (ACPI_SIZE)(n)) +#define ACPI_MEMSET(d,v,n) (void) AcpiUtMemset ((d), (v), (ACPI_SIZE)(n)) #define ACPI_TOUPPER AcpiUtToUpper #define ACPI_TOLOWER AcpiUtToLower Index: acevents.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acevents.h,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 acevents.h --- acevents.h 30 Jun 2002 17:50:42 -0000 1.1.1.10 +++ acevents.h 1 Jul 2002 21:39:53 -0000 @@ -156,7 +156,7 @@ AcpiEvAcquireGlobalLock( UINT32 Timeout); -void +ACPI_STATUS AcpiEvReleaseGlobalLock( void); @@ -207,7 +207,7 @@ */ ACPI_STATUS -AcpiEvInstallDefaultAddressSpaceHandlers ( +AcpiEvInitAddressSpaces ( void); ACPI_STATUS @@ -216,7 +216,7 @@ UINT32 Function, ACPI_PHYSICAL_ADDRESS Address, UINT32 BitWidth, - ACPI_INTEGER *Value); + void *Value); ACPI_STATUS AcpiEvAddrHandlerHelper ( @@ -225,15 +225,15 @@ void *Context, void **ReturnValue); -void -AcpiEvDisassociateRegionFromHandler( - ACPI_OPERAND_OBJECT *RegionObj, - BOOLEAN AcpiNsIsLocked); - ACPI_STATUS -AcpiEvAssociateRegionAndHandler ( +AcpiEvAttachRegion ( ACPI_OPERAND_OBJECT *HandlerObj, ACPI_OPERAND_OBJECT *RegionObj, + BOOLEAN AcpiNsIsLocked); + +void +AcpiEvDetachRegion ( + ACPI_OPERAND_OBJECT *RegionObj, BOOLEAN AcpiNsIsLocked); Index: acexcep.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acexcep.h,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 acexcep.h --- acexcep.h 30 Jun 2002 17:50:42 -0000 1.1.1.10 +++ acexcep.h 1 Jul 2002 21:39:53 -0000 @@ -193,8 +193,9 @@ #define AE_BAD_CHECKSUM (ACPI_STATUS) (0x0003 | AE_CODE_ACPI_TABLES) #define AE_BAD_VALUE (ACPI_STATUS) (0x0004 | AE_CODE_ACPI_TABLES) #define AE_TABLE_NOT_SUPPORTED (ACPI_STATUS) (0x0005 | AE_CODE_ACPI_TABLES) +#define AE_INVALID_TABLE_LENGTH (ACPI_STATUS) (0x0006 | AE_CODE_ACPI_TABLES) -#define AE_CODE_TBL_MAX 0x0005 +#define AE_CODE_TBL_MAX 0x0006 /* @@ -229,8 +230,11 @@ #define AE_AML_INVALID_INDEX (ACPI_STATUS) (0x001A | AE_CODE_AML) #define AE_AML_REGISTER_LIMIT (ACPI_STATUS) (0x001B | AE_CODE_AML) #define AE_AML_NO_WHILE (ACPI_STATUS) (0x001C | AE_CODE_AML) +#define AE_AML_ALIGNMENT (ACPI_STATUS) (0x001D | AE_CODE_AML) +#define AE_AML_NO_RESOURCE_END_TAG (ACPI_STATUS) (0x001E | AE_CODE_AML) +#define AE_AML_BAD_RESOURCE_VALUE (ACPI_STATUS) (0x001F | AE_CODE_AML) -#define AE_CODE_AML_MAX 0x001C +#define AE_CODE_AML_MAX 0x001F /* * Internal exceptions used for control @@ -306,7 +310,8 @@ "AE_BAD_HEADER", "AE_BAD_CHECKSUM", "AE_BAD_VALUE", - "AE_TABLE_NOT_SUPPORTED" + "AE_TABLE_NOT_SUPPORTED", + "AE_INVALID_TABLE_LENGTH" }; NATIVE_CHAR const *AcpiGbl_ExceptionNames_Aml[] = @@ -338,7 +343,10 @@ "AE_AML_INVALID_RESOURCE_TYPE", "AE_AML_INVALID_INDEX", "AE_AML_REGISTER_LIMIT", - "AE_AML_NO_WHILE" + "AE_AML_NO_WHILE", + "AE_AML_ALIGNMENT", + "AE_AML_NO_RESOURCE_END_TAG", + "AE_AML_BAD_RESOURCE_VALUE" }; NATIVE_CHAR const *AcpiGbl_ExceptionNames_Ctrl[] = Index: acfreebsd.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acfreebsd.h,v retrieving revision 1.9 diff -u -r1.9 acfreebsd.h --- acfreebsd.h 30 Jun 2002 17:53:04 -0000 1.9 +++ acfreebsd.h 1 Jul 2002 21:39:53 -0000 @@ -145,11 +145,11 @@ #define ACPI_FLUSH_CPU_CACHE() /* XXX ia64_fc()? */ #endif -#ifdef ACPI_DEBUG #ifdef DEBUGGER_THREADING #undef DEBUGGER_THREADING #endif /* DEBUGGER_THREADING */ #define DEBUGGER_THREADING 0 /* integrated with DDB */ +#ifdef ACPI_DEBUG #include "opt_ddb.h" #ifdef DDB #define ENABLE_DEBUGGER @@ -203,5 +203,16 @@ return ((char *)s); } #endif /* _KERNEL */ + +#if defined(__ia64__) || defined(__x86_64__) +#define ACPI_MACHINE_WIDTH 64 +#define COMPILER_DEPENDENT_INT64 long +#define COMPILER_DEPENDENT_UINT64 unsigned long +#else +#define ACPI_MACHINE_WIDTH 32 +#define COMPILER_DEPENDENT_INT64 long long +#define COMPILER_DEPENDENT_UINT64 unsigned long long +#define ACPI_USE_NATIVE_DIVIDE +#endif #endif /* __ACFREEBSD_H__ */ Index: acgcc.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acgcc.h,v retrieving revision 1.16 diff -u -r1.16 acgcc.h --- acgcc.h 30 Jun 2002 17:53:04 -0000 1.16 +++ acgcc.h 1 Jul 2002 21:39:53 -0000 @@ -116,168 +116,6 @@ #ifndef __ACGCC_H__ #define __ACGCC_H__ - - -#ifdef __ia64__ -#define _IA64 - -#define COMPILER_DEPENDENT_INT64 long -#define COMPILER_DEPENDENT_UINT64 unsigned long - -/* - * Calling conventions: - * - * ACPI_SYSTEM_XFACE - Interfaces to host OS (handlers, threads) - * ACPI_EXTERNAL_XFACE - External ACPI interfaces - * ACPI_INTERNAL_XFACE - Internal ACPI interfaces - * ACPI_INTERNAL_VAR_XFACE - Internal variable-parameter list interfaces - */ -#define ACPI_SYSTEM_XFACE -#define ACPI_EXTERNAL_XFACE -#define ACPI_INTERNAL_XFACE -#define ACPI_INTERNAL_VAR_XFACE - -/* Single threaded */ - -#ifndef __FreeBSD__ -#define ACPI_APPLICATION -#endif - -/* Asm macros */ - -#define ACPI_ASM_MACROS -#define BREAKPOINT3 -#define ACPI_DISABLE_IRQS() __cli() -#define ACPI_ENABLE_IRQS() __sti() - -/*! [Begin] no source code translation */ - -#define ACPI_ACQUIRE_GLOBAL_LOCK(GLptr, Acq) \ - do { \ - __asm__ volatile ("1: ld4 r29=%1\n" \ - ";;\n" \ - "mov ar.ccv=r29\n" \ - "mov r2=r29\n" \ - "shr.u r30=r29,1\n" \ - "and r29=-4,r29\n" \ - ";;\n" \ - "add r29=2,r29\n" \ - "and r30=1,r30\n" \ - ";;\n" \ - "add r29=r29,r30\n" \ - ";;\n" \ - "cmpxchg4.acq r30=%1,r29,ar.ccv\n" \ - ";;\n" \ - "cmp.eq p6,p7=r2,r30\n" \ - "(p7) br.dpnt.few 1b\n" \ - "cmp.gt p8,p9=3,r29\n" \ - ";;\n" \ - "(p8) mov %0=-1\n" \ - "(p9) mov %0=r0\n" \ - :"=r"(Acq):"m"(GLptr):"r2","r29","r30","memory"); \ - } while (0) - -#define ACPI_RELEASE_GLOBAL_LOCK(GLptr, Acq) \ - do { \ - __asm__ volatile ("1: ld4 r29=%1\n" \ - ";;\n" \ - "mov ar.ccv=r29\n" \ - "mov r2=r29\n" \ - "and r29=-4,r29\n" \ - ";;\n" \ - "cmpxchg4.acq r30=%1,r29,ar.ccv\n" \ - ";;\n" \ - "cmp.eq p6,p7=r2,r30\n" \ - "(p7) br.dpnt.few 1b\n" \ - "and %0=1,r2\n" \ - ";;\n" \ - :"=r"(Acq):"m"(GLptr):"r2","r29","r30","memory"); \ - } while (0) -/*! [End] no source code translation !*/ - - -#else /* DO IA32 */ - -#define COMPILER_DEPENDENT_INT64 long long -#define COMPILER_DEPENDENT_UINT64 unsigned long long - -/* - * Calling conventions: - * - * ACPI_SYSTEM_XFACE - Interfaces to host OS (handlers, threads) - * ACPI_EXTERNAL_XFACE - External ACPI interfaces - * ACPI_INTERNAL_XFACE - Internal ACPI interfaces - * ACPI_INTERNAL_VAR_XFACE - Internal variable-parameter list interfaces - */ -#define ACPI_SYSTEM_XFACE -#define ACPI_EXTERNAL_XFACE -#define ACPI_INTERNAL_XFACE -#define ACPI_INTERNAL_VAR_XFACE - -/* Asm macros */ - -#define ACPI_ASM_MACROS -#define BREAKPOINT3 -#define ACPI_DISABLE_IRQS() __cli() -#define ACPI_ENABLE_IRQS() __sti() - -/*! [Begin] no source code translation - * - * A brief explanation as GNU inline assembly is a bit hairy - * %0 is the output parameter in EAX ("=a") - * %1 and %2 are the input parameters in ECX ("c") - * and an immediate value ("i") respectively - * All actual register references are preceded with "%%" as in "%%edx" - * Immediate values in the assembly are preceded by "$" as in "$0x1" - * The final asm parameter are the operation altered non-output registers. - */ -#define ACPI_ACQUIRE_GLOBAL_LOCK(GLptr, Acq) \ - do { \ - int dummy; \ - asm("1: movl (%1),%%eax;" \ - "movl %%eax,%%edx;" \ - "andl %2,%%edx;" \ - "btsl $0x1,%%edx;" \ - "adcl $0x0,%%edx;" \ - "lock; cmpxchgl %%edx,(%1);" \ - "jnz 1b;" \ - "cmpb $0x3,%%dl;" \ - "sbbl %%eax,%%eax" \ - :"=a"(Acq),"=c"(dummy):"c"(GLptr),"i"(~1L):"dx"); \ - } while(0) - -#define ACPI_RELEASE_GLOBAL_LOCK(GLptr, Acq) \ - do { \ - int dummy; \ - asm("1: movl (%1),%%eax;" \ - "movl %%eax,%%edx;" \ - "andl %2,%%edx;" \ - "lock; cmpxchgl %%edx,(%1);" \ - "jnz 1b;" \ - "andl $0x1,%%eax" \ - :"=a"(Acq),"=c"(dummy):"c"(GLptr),"i"(~3L):"dx"); \ - } while(0) - - -/* - * Math helper asm macros - */ -#define ACPI_DIV_64_BY_32(n_hi, n_lo, d32, q32, r32) \ - asm("divl %2;" \ - :"=a"(q32), "=d"(r32) \ - :"r"(d32), \ - "0"(n_lo), "1"(n_hi)) - - -#define ACPI_SHIFT_RIGHT_64(n_hi, n_lo) \ - asm("shrl $1,%2;" \ - "rcrl $1,%3;" \ - :"=r"(n_hi), "=r"(n_lo) \ - :"0"(n_hi), "1"(n_lo)) - -/*! [End] no source code translation !*/ - -#endif /* IA 32 */ /* This macro is used to tag functions as "printf-like" because * some compilers (like GCC) can catch printf format string problems. Index: acglobal.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acglobal.h,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 acglobal.h --- acglobal.h 30 Jun 2002 17:50:42 -0000 1.1.1.11 +++ acglobal.h 1 Jul 2002 21:39:53 -0000 @@ -171,6 +171,14 @@ ACPI_EXTERN ACPI_COMMON_FACS AcpiGbl_CommonFACS; /* + * Handle both ACPI 1.0 and ACPI 2.0 Integer widths + * If we are running a method that exists in a 32-bit ACPI table. + * Use only 32 bits of the Integer for conversion. + */ +ACPI_EXTERN UINT8 AcpiGbl_IntegerBitWidth; +ACPI_EXTERN UINT8 AcpiGbl_IntegerByteWidth; + +/* * Since there may be multiple SSDTs and PSDTS, a single pointer is not * sufficient; Therefore, there isn't one! */ @@ -200,6 +208,7 @@ ACPI_EXTERN ACPI_MEMORY_LIST AcpiGbl_MemoryLists[ACPI_NUM_MEM_LISTS]; ACPI_EXTERN ACPI_OBJECT_NOTIFY_HANDLER AcpiGbl_DrvNotify; ACPI_EXTERN ACPI_OBJECT_NOTIFY_HANDLER AcpiGbl_SysNotify; +ACPI_EXTERN ACPI_INIT_HANDLER AcpiGbl_InitHandler; ACPI_EXTERN ACPI_WALK_STATE *AcpiGbl_BreakpointWalk; ACPI_EXTERN ACPI_HANDLE AcpiGbl_GlobalLockSemaphore; @@ -222,6 +231,7 @@ extern UINT32 AcpiGbl_StartupFlags; extern const UINT8 AcpiGbl_DecodeTo8bit[8]; extern const NATIVE_CHAR *AcpiGbl_DbSleepStates[ACPI_NUM_SLEEP_STATES]; +extern const ACPI_OPCODE_INFO AcpiGbl_AmlOpInfo[AML_NUM_OPCODES]; /***************************************************************************** @@ -277,7 +287,7 @@ * ****************************************************************************/ -ACPI_EXTERN ACPI_BIT_REGISTER_INFO AcpiGbl_BitRegisterInfo[ACPI_NUM_BITREG]; +extern ACPI_BIT_REGISTER_INFO AcpiGbl_BitRegisterInfo[ACPI_NUM_BITREG]; ACPI_EXTERN UINT8 AcpiGbl_SleepTypeA; ACPI_EXTERN UINT8 AcpiGbl_SleepTypeB; @@ -320,13 +330,11 @@ #ifdef ENABLE_DEBUGGER -ACPI_EXTERN BOOLEAN AcpiGbl_MethodExecuting; -ACPI_EXTERN BOOLEAN AcpiGbl_DbTerminateThreads; +extern BOOLEAN AcpiGbl_MethodExecuting; +extern BOOLEAN AcpiGbl_DbTerminateThreads; ACPI_EXTERN int optind; ACPI_EXTERN NATIVE_CHAR *optarg; -ACPI_EXTERN UINT8 *AmlStart; -ACPI_EXTERN UINT32 AmlLength; ACPI_EXTERN BOOLEAN AcpiGbl_DbOpt_tables; ACPI_EXTERN BOOLEAN AcpiGbl_DbOpt_disasm; Index: achware.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/achware.h,v retrieving revision 1.1.1.7 diff -u -r1.1.1.7 achware.h --- achware.h 23 Feb 2002 05:10:34 -0000 1.1.1.7 +++ achware.h 1 Jul 2002 21:39:53 -0000 @@ -155,49 +155,44 @@ AcpiHwGetBitRegisterInfo ( UINT32 RegisterId); -UINT32 -AcpiHwBitRegisterRead ( - UINT32 RegisterId, - UINT32 Flags); - -UINT32 -AcpiHwBitRegisterWrite ( - UINT32 RegisterId, - UINT32 Value, - UINT32 Flags); - -UINT32 +ACPI_STATUS AcpiHwRegisterRead ( BOOLEAN UseLock, - UINT32 RegisterId); + UINT32 RegisterId, + UINT32 *ReturnValue); -void +ACPI_STATUS AcpiHwRegisterWrite ( BOOLEAN UseLock, UINT32 RegisterId, UINT32 Value); -UINT32 +ACPI_STATUS AcpiHwLowLevelRead ( UINT32 Width, + UINT32 *Value, ACPI_GENERIC_ADDRESS *Reg, UINT32 Offset); -void +ACPI_STATUS AcpiHwLowLevelWrite ( UINT32 Width, UINT32 Value, ACPI_GENERIC_ADDRESS *Reg, UINT32 Offset); -void +ACPI_STATUS AcpiHwClearAcpiStatus ( void); /* GPE support */ -void +UINT8 +AcpiHwGetGpeBitMask ( + UINT32 GpeNumber); + +ACPI_STATUS AcpiHwEnableGpe ( UINT32 GpeNumber); @@ -205,7 +200,7 @@ AcpiHwEnableGpeForWakeup ( UINT32 GpeNumber); -void +ACPI_STATUS AcpiHwDisableGpe ( UINT32 GpeNumber); @@ -213,31 +208,22 @@ AcpiHwDisableGpeForWakeup ( UINT32 GpeNumber); -void +ACPI_STATUS AcpiHwClearGpe ( UINT32 GpeNumber); -void +ACPI_STATUS AcpiHwGetGpeStatus ( UINT32 GpeNumber, ACPI_EVENT_STATUS *EventStatus); -void +ACPI_STATUS AcpiHwDisableNonWakeupGpes ( void); -void +ACPI_STATUS AcpiHwEnableNonWakeupGpes ( void); - - -/* Sleep Prototypes */ - -ACPI_STATUS -AcpiHwGetSleepTypeData ( - UINT8 SleepState, - UINT8 *Slp_TypA, - UINT8 *Slp_TypB); /* ACPI Timer prototypes */ Index: acinterp.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acinterp.h,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 acinterp.h --- acinterp.h 30 Jun 2002 17:50:42 -0000 1.1.1.14 +++ acinterp.h 1 Jul 2002 21:39:53 -0000 @@ -127,6 +127,11 @@ ACPI_OPERAND_OBJECT **StackPtr, ACPI_WALK_STATE *WalkState); +ACPI_STATUS +AcpiExCheckObjectType ( + ACPI_OBJECT_TYPE TypeNeeded, + ACPI_OBJECT_TYPE ThisType, + void *Object); /* * exxface - External interpreter interfaces @@ -174,6 +179,11 @@ ACPI_OPERAND_OBJECT **ResultDesc, ACPI_WALK_STATE *WalkState); +UINT32 +AcpiExConvertToAscii ( + ACPI_INTEGER Integer, + UINT32 Base, + UINT8 *String); /* * exfield - ACPI AML (p-code) execution - field manipulation @@ -263,6 +273,12 @@ AcpiExOpcode_6A_0T_1R ( ACPI_WALK_STATE *WalkState); +BOOLEAN +AcpiExDoMatch ( + UINT32 MatchOp, + ACPI_INTEGER PackageValue, + ACPI_INTEGER MatchValue); + ACPI_STATUS AcpiExGetObjectReference ( ACPI_OPERAND_OBJECT *ObjDesc, @@ -374,7 +390,7 @@ ACPI_OPERAND_OBJECT *ObjDesc, ACPI_WALK_STATE *WalkState); -ACPI_STATUS +void AcpiExReleaseAllMutexes ( ACPI_THREAD_STATE *Thread); @@ -514,13 +530,6 @@ */ void -AcpiExShowHexValue ( - UINT32 ByteCount, - UINT8 *AmlStart, - UINT32 LeadSpace); - - -ACPI_STATUS AcpiExDumpOperand ( ACPI_OPERAND_OBJECT *EntryDesc); @@ -539,12 +548,31 @@ ACPI_OPERAND_OBJECT *Object, UINT32 Flags); - void AcpiExDumpNode ( ACPI_NAMESPACE_NODE *Node, UINT32 Flags); +void +AcpiExOutString ( + char *Title, + char *Value); + +void +AcpiExOutPointer ( + char *Title, + void *Value); + +void +AcpiExOutInteger ( + char *Title, + UINT32 Value); + +void +AcpiExOutAddress ( + char *Title, + ACPI_PHYSICAL_ADDRESS Value); + /* * exnames - interpreter/scanner name load/execute @@ -666,8 +694,7 @@ void AcpiExTruncateFor32bitTable ( - ACPI_OPERAND_OBJECT *ObjDesc, - ACPI_WALK_STATE *WalkState); + ACPI_OPERAND_OBJECT *ObjDesc); BOOLEAN AcpiExValidateObjectType ( @@ -677,7 +704,7 @@ AcpiExAcquireGlobalLock ( UINT32 Rule); -ACPI_STATUS +void AcpiExReleaseGlobalLock ( BOOLEAN Locked); @@ -686,12 +713,12 @@ ACPI_INTEGER Value, UINT32 Base); -ACPI_STATUS +void AcpiExEisaIdToString ( UINT32 NumericId, NATIVE_CHAR *OutString); -ACPI_STATUS +void AcpiExUnsignedIntegerToString ( ACPI_INTEGER Value, NATIVE_CHAR *OutString); Index: aclocal.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/aclocal.h,v retrieving revision 1.1.1.16 diff -u -r1.1.1.16 aclocal.h --- aclocal.h 30 Jun 2002 17:50:42 -0000 1.1.1.16 +++ aclocal.h 1 Jul 2002 21:39:53 -0000 @@ -128,23 +128,9 @@ #define ACPI_LOGICAL_ADDRESSING 0x00 #define ACPI_PHYSICAL_ADDRESSING 0x01 -/* Object descriptor types */ +/* Total number of aml opcodes defined */ -#define ACPI_CACHED_OBJECT 0x11 /* ORed in when object is cached */ -#define ACPI_DESC_TYPE_STATE 0x20 -#define ACPI_DESC_TYPE_STATE_UPDATE 0x21 -#define ACPI_DESC_TYPE_STATE_PACKAGE 0x22 -#define ACPI_DESC_TYPE_STATE_CONTROL 0x23 -#define ACPI_DESC_TYPE_STATE_RPSCOPE 0x24 -#define ACPI_DESC_TYPE_STATE_PSCOPE 0x25 -#define ACPI_DESC_TYPE_STATE_WSCOPE 0x26 -#define ACPI_DESC_TYPE_STATE_RESULT 0x27 -#define ACPI_DESC_TYPE_STATE_NOTIFY 0x28 -#define ACPI_DESC_TYPE_STATE_THREAD 0x29 -#define ACPI_DESC_TYPE_WALK 0x44 -#define ACPI_DESC_TYPE_PARSER 0x66 -#define ACPI_DESC_TYPE_INTERNAL 0x88 -#define ACPI_DESC_TYPE_NAMED 0xAA +#define AML_NUM_OPCODES 0x7E @@ -326,7 +312,7 @@ UINT8 *AmlStart; UINT64 PhysicalAddress; UINT32 AmlLength; - UINT32 Length; + ACPI_SIZE Length; UINT32 Count; ACPI_OWNER_ID TableId; UINT8 Type; @@ -503,8 +489,8 @@ /* Forward declarations */ struct acpi_walk_state; -struct acpi_parse_obj; struct acpi_obj_mutex; +union acpi_parse_obj; #define ACPI_STATE_COMMON /* Two 32-bit fields and a pointer */\ @@ -555,7 +541,7 @@ typedef struct acpi_control_state { ACPI_STATE_COMMON - struct acpi_parse_obj *PredicateOp; + union acpi_parse_obj *PredicateOp; UINT8 *AmlPredicateStart; /* Start of if/while predicate */ UINT8 *PackageEnd; /* End of if/while block */ UINT16 Opcode; @@ -577,7 +563,7 @@ typedef struct acpi_pscope_state { ACPI_STATE_COMMON - struct acpi_parse_obj *Op; /* current op being parsed */ + union acpi_parse_obj *Op; /* current op being parsed */ UINT8 *ArgEnd; /* current argument end */ UINT8 *PkgEnd; /* current package end */ UINT32 ArgList; /* next argument to parse */ @@ -618,7 +604,7 @@ typedef ACPI_STATUS (*ACPI_PARSE_DOWNWARDS) ( struct acpi_walk_state *WalkState, - struct acpi_parse_obj **OutOp); + union acpi_parse_obj **OutOp); typedef ACPI_STATUS (*ACPI_PARSE_UPWARDS) ( @@ -701,7 +687,7 @@ NATIVE_CHAR *String; /* NULL terminated string */ UINT8 *Buffer; /* buffer or string */ NATIVE_CHAR *Name; /* NULL terminated string */ - struct acpi_parse_obj *Arg; /* arguments and contained ops */ + union acpi_parse_obj *Arg; /* arguments and contained ops */ } ACPI_PARSE_VALUE; @@ -709,12 +695,12 @@ #define ACPI_PARSE_COMMON \ UINT8 DataType; /* To differentiate various internal objs */\ UINT8 Flags; /* Type of Op */\ - UINT16 Opcode; /* AML opcode */\ + UINT16 AmlOpcode; /* AML opcode */\ UINT32 AmlOffset; /* offset of declaration in AML */\ - struct acpi_parse_obj *Parent; /* parent op */\ - struct acpi_parse_obj *Next; /* next op */\ + union acpi_parse_obj *Parent; /* parent op */\ + union acpi_parse_obj *Next; /* next op */\ ACPI_DEBUG_ONLY_MEMBERS (\ - NATIVE_CHAR OpName[16]) /* op name (debug only) */\ + NATIVE_CHAR AmlOpName[16]) /* op name (debug only) */\ /* NON-DEBUG members below: */\ ACPI_NAMESPACE_NODE *Node; /* for use by interpreter */\ ACPI_PARSE_VALUE Value; /* Value or args associated with the opcode */\ @@ -723,24 +709,69 @@ /* * generic operation (eg. If, While, Store) */ -typedef struct acpi_parse_obj +typedef struct acpi_parseobj_common { ACPI_PARSE_COMMON -} ACPI_PARSE_OBJECT; +} ACPI_PARSE_OBJ_COMMON; /* * Extended Op for named ops (Scope, Method, etc.), deferred ops (Methods and OpRegions), * and bytelists. */ -typedef struct acpi_parse2_obj +typedef struct acpi_parseobj_named { ACPI_PARSE_COMMON UINT8 *Data; /* AML body or bytelist data */ UINT32 Length; /* AML length */ UINT32 Name; /* 4-byte name or zero if no name */ -} ACPI_PARSE2_OBJECT; +} ACPI_PARSE_OBJ_NAMED; + + +/* The parse node is the fundamental element of the parse tree */ + +typedef struct acpi_parseobj_asl +{ + ACPI_PARSE_COMMON + + union acpi_parse_obj *Child; + + + union acpi_parse_obj *ParentMethod; + char *Filename; + char *ExternalName; + char *Namepath; + UINT32 ExtraValue; + UINT32 Column; + UINT32 LineNumber; + UINT32 LogicalLineNumber; + UINT32 LogicalByteOffset; + UINT32 EndLine; + UINT32 EndLogicalLine; + UINT16 ParseOpcode; + UINT32 AcpiBtype; + UINT32 AmlLength; + UINT32 AmlSubtreeLength; + UINT32 FinalAmlLength; + UINT32 FinalAmlOffset; + UINT8 AmlOpcodeLength; + UINT8 AmlPkgLenBytes; + UINT16 CompileFlags; + UINT8 Extra; + char ParseOpName[12]; + +} ACPI_PARSE_OBJ_ASL; + + +typedef union acpi_parse_obj +{ + ACPI_PARSE_OBJ_COMMON Common; + ACPI_PARSE_OBJ_NAMED Named; + ACPI_PARSE_OBJ_ASL Asl; + +} ACPI_PARSE_OBJECT; + /* @@ -755,10 +786,10 @@ UINT8 *AmlEnd; /* (last + 1) AML byte */ UINT8 *PkgStart; /* current package begin */ UINT8 *PkgEnd; /* current package end */ - struct acpi_parse_obj *StartOp; /* root of parse tree */ + union acpi_parse_obj *StartOp; /* root of parse tree */ struct acpi_node *StartNode; union acpi_gen_state *Scope; /* current scope */ - struct acpi_parse_obj *StartScope; + union acpi_parse_obj *StartScope; } ACPI_PARSE_STATE; @@ -804,38 +835,6 @@ #define ACPI_REGISTER_SMI_COMMAND_BLOCK 0x09 -/* - * BitRegister IDs - * These are bitfields defined within the full ACPI registers - */ -#define ACPI_BITREG_TIMER_STATUS 0x00 -#define ACPI_BITREG_BUS_MASTER_STATUS 0x01 -#define ACPI_BITREG_GLOBAL_LOCK_STATUS 0x02 -#define ACPI_BITREG_POWER_BUTTON_STATUS 0x03 -#define ACPI_BITREG_SLEEP_BUTTON_STATUS 0x04 -#define ACPI_BITREG_RT_CLOCK_STATUS 0x05 -#define ACPI_BITREG_WAKE_STATUS 0x06 - -#define ACPI_BITREG_TIMER_ENABLE 0x07 -#define ACPI_BITREG_GLOBAL_LOCK_ENABLE 0x08 -#define ACPI_BITREG_POWER_BUTTON_ENABLE 0x09 -#define ACPI_BITREG_SLEEP_BUTTON_ENABLE 0x0A -#define ACPI_BITREG_RT_CLOCK_ENABLE 0x0B -#define ACPI_BITREG_WAKE_ENABLE 0x0C - -#define ACPI_BITREG_SCI_ENABLE 0x0D -#define ACPI_BITREG_BUS_MASTER_RLD 0x0E -#define ACPI_BITREG_GLOBAL_LOCK_RELEASE 0x0F -#define ACPI_BITREG_SLEEP_TYPE_A 0x10 -#define ACPI_BITREG_SLEEP_TYPE_B 0x11 -#define ACPI_BITREG_SLEEP_ENABLE 0x12 - -#define ACPI_BITREG_ARB_DISABLE 0x13 - -#define ACPI_BITREG_MAX 0x13 -#define ACPI_NUM_BITREG ACPI_BITREG_MAX + 1 - - /* Masks used to access the BitRegisters */ #define ACPI_BITMASK_TIMER_STATUS 0x0001 @@ -962,6 +961,7 @@ ****************************************************************************/ #define ACPI_ASCII_ZERO 0x30 + /***************************************************************************** * Index: acmacros.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acmacros.h,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 acmacros.h --- acmacros.h 23 Feb 2002 05:10:34 -0000 1.1.1.12 +++ acmacros.h 1 Jul 2002 21:39:53 -0000 @@ -122,22 +122,23 @@ * Data manipulation macros */ -#define ACPI_LOWORD(l) ((UINT16)(NATIVE_UINT)(l)) -#define ACPI_HIWORD(l) ((UINT16)((((NATIVE_UINT)(l)) >> 16) & 0xFFFF)) +#define ACPI_LOWORD(l) ((UINT16)(UINT32)(l)) +#define ACPI_HIWORD(l) ((UINT16)((((UINT32)(l)) >> 16) & 0xFFFF)) #define ACPI_LOBYTE(l) ((UINT8)(UINT16)(l)) #define ACPI_HIBYTE(l) ((UINT8)((((UINT16)(l)) >> 8) & 0xFF)) -#ifdef _IA16 +#if ACPI_MACHINE_WIDTH == 16 + /* * For 16-bit addresses, we have to assume that the upper 32 bits * are zero. */ -#define ACPI_LODWORD(l) (l) -#define ACPI_HIDWORD(l) (0) +#define ACPI_LODWORD(l) ((UINT32)(l)) +#define ACPI_HIDWORD(l) ((UINT32)(0)) #define ACPI_GET_ADDRESS(a) ((a).Lo) -#define ACPI_STORE_ADDRESS(a,b) {(a).Hi=0;(a).Lo=(b);} +#define ACPI_STORE_ADDRESS(a,b) {(a).Hi=0;(a).Lo=(UINT32)(b);} #define ACPI_VALID_ADDRESS(a) ((a).Hi | (a).Lo) #else @@ -146,7 +147,7 @@ * ACPI_INTEGER is 32-bits, no 64-bit support on this platform */ #define ACPI_LODWORD(l) ((UINT32)(l)) -#define ACPI_HIDWORD(l) (0) +#define ACPI_HIDWORD(l) ((UINT32)(0)) #define ACPI_GET_ADDRESS(a) (a) #define ACPI_STORE_ADDRESS(a,b) ((a)=(b)) @@ -158,10 +159,10 @@ * Full 64-bit address/integer on both 32-bit and 64-bit platforms */ #define ACPI_LODWORD(l) ((UINT32)(UINT64)(l)) -#define ACPI_HIDWORD(l) ((UINT32)(((*(UINT64_STRUCT *)(&l))).Hi)) +#define ACPI_HIDWORD(l) ((UINT32)(((*(UINT64_STRUCT *)(void *)(&l))).Hi)) #define ACPI_GET_ADDRESS(a) (a) -#define ACPI_STORE_ADDRESS(a,b) ((a)=(b)) +#define ACPI_STORE_ADDRESS(a,b) ((a)=(ACPI_PHYSICAL_ADDRESS)(b)) #define ACPI_VALID_ADDRESS(a) (a) #endif #endif @@ -174,20 +175,23 @@ /* Pointer arithmetic */ -#define ACPI_PTR_ADD(t,a,b) (t *) ((char *)(a) + (b)) +#define ACPI_PTR_ADD(t,a,b) (t *) (void *)((char *)(a) + (NATIVE_UINT)(b)) #define ACPI_PTR_DIFF(a,b) (NATIVE_UINT) ((char *)(a) - (char *)(b)) /* Pointer/Integer type conversions */ -#define ACPI_TO_POINTER(i) ACPI_PTR_ADD (void,NULL,(NATIVE_UINT)i) -#define ACPI_TO_INTEGER(p) ACPI_PTR_DIFF (p,NULL) -#define ACPI_OFFSET(d,o) ((ACPI_SIZE) ACPI_TO_INTEGER (&(((d *)0)->o))) -#define ACPI_FADT_OFFSET(o) ACPI_OFFSET (FADT_DESCRIPTOR, o) +#define ACPI_TO_POINTER(i) ACPI_PTR_ADD (void, (void *) NULL,(NATIVE_UINT)i) +#define ACPI_TO_INTEGER(p) ACPI_PTR_DIFF (p,(void *) NULL) +#define ACPI_OFFSET(d,f) (ACPI_SIZE) ACPI_PTR_DIFF (&(((d *)0)->f),(void *) NULL) +#define ACPI_FADT_OFFSET(f) ACPI_OFFSET (FADT_DESCRIPTOR, f) +#define ACPI_CAST_PTR(t, p) ((t *)(void *)(p)) +#define ACPI_CAST_INDIRECT_PTR(t, p) ((t **)(void *)(p)) -#ifdef _IA16 +#if ACPI_MACHINE_WIDTH == 16 +#define ACPI_STORE_POINTER(d,s) ACPI_MOVE_UNALIGNED32_TO_32(d,s) #define ACPI_PHYSADDR_TO_PTR(i) (void *)(i) -#define ACPI_PTR_TO_PHYSADDR(i) (char *)(i) +#define ACPI_PTR_TO_PHYSADDR(i) (UINT32) (char *)(i) #else #define ACPI_PHYSADDR_TO_PTR(i) ACPI_TO_POINTER(i) #define ACPI_PTR_TO_PHYSADDR(i) ACPI_TO_INTEGER(i) @@ -203,10 +207,10 @@ /* The hardware supports unaligned transfers, just do the move */ -#define ACPI_MOVE_UNALIGNED16_TO_16(d,s) *(UINT16 *)(d) = *(UINT16 *)(s) -#define ACPI_MOVE_UNALIGNED32_TO_32(d,s) *(UINT32 *)(d) = *(UINT32 *)(s) -#define ACPI_MOVE_UNALIGNED16_TO_32(d,s) *(UINT32 *)(d) = *(UINT16 *)(s) -#define ACPI_MOVE_UNALIGNED64_TO_64(d,s) *(UINT64 *)(d) = *(UINT64 *)(s) +#define ACPI_MOVE_UNALIGNED16_TO_16(d,s) *(UINT16 *)(void *)(d) = *(UINT16 *)(void *)(s) +#define ACPI_MOVE_UNALIGNED32_TO_32(d,s) *(UINT32 *)(void *)(d) = *(UINT32 *)(void *)(s) +#define ACPI_MOVE_UNALIGNED16_TO_32(d,s) *(UINT32 *)(void *)(d) = *(UINT16 *)(void *)(s) +#define ACPI_MOVE_UNALIGNED64_TO_64(d,s) *(UINT64 *)(void *)(d) = *(UINT64 *)(void *)(s) #else /* @@ -215,24 +219,24 @@ * the destination (or both) is/are unaligned. */ -#define ACPI_MOVE_UNALIGNED16_TO_16(d,s) {((UINT8 *)(d))[0] = ((UINT8 *)(s))[0];\ - ((UINT8 *)(d))[1] = ((UINT8 *)(s))[1];} +#define ACPI_MOVE_UNALIGNED16_TO_16(d,s) {((UINT8 *)(void *)(d))[0] = ((UINT8 *)(void *)(s))[0];\ + ((UINT8 *)(void *)(d))[1] = ((UINT8 *)(void *)(s))[1];} -#define ACPI_MOVE_UNALIGNED32_TO_32(d,s) {((UINT8 *)(d))[0] = ((UINT8 *)(s))[0];\ - ((UINT8 *)(d))[1] = ((UINT8 *)(s))[1];\ - ((UINT8 *)(d))[2] = ((UINT8 *)(s))[2];\ - ((UINT8 *)(d))[3] = ((UINT8 *)(s))[3];} - -#define ACPI_MOVE_UNALIGNED16_TO_32(d,s) {(*(UINT32*)(d)) = 0; ACPI_MOVE_UNALIGNED16_TO_16(d,s);} - -#define ACPI_MOVE_UNALIGNED64_TO_64(d,s) {((UINT8 *)(d))[0] = ((UINT8 *)(s))[0];\ - ((UINT8 *)(d))[1] = ((UINT8 *)(s))[1];\ - ((UINT8 *)(d))[2] = ((UINT8 *)(s))[2];\ - ((UINT8 *)(d))[3] = ((UINT8 *)(s))[3];\ - ((UINT8 *)(d))[4] = ((UINT8 *)(s))[4];\ - ((UINT8 *)(d))[5] = ((UINT8 *)(s))[5];\ - ((UINT8 *)(d))[6] = ((UINT8 *)(s))[6];\ - ((UINT8 *)(d))[7] = ((UINT8 *)(s))[7];} +#define ACPI_MOVE_UNALIGNED32_TO_32(d,s) {((UINT8 *)(void *)(d))[0] = ((UINT8 *)(void *)(s))[0];\ + ((UINT8 *)(void *)(d))[1] = ((UINT8 *)(void *)(s))[1];\ + ((UINT8 *)(void *)(d))[2] = ((UINT8 *)(void *)(s))[2];\ + ((UINT8 *)(void *)(d))[3] = ((UINT8 *)(void *)(s))[3];} + +#define ACPI_MOVE_UNALIGNED16_TO_32(d,s) {(*(UINT32*)(void *)(d)) = 0; ACPI_MOVE_UNALIGNED16_TO_16(d,s);} + +#define ACPI_MOVE_UNALIGNED64_TO_64(d,s) {((UINT8 *)(void *)(d))[0] = ((UINT8 *)(void *)(s))[0];\ + ((UINT8 *)(void *)(d))[1] = ((UINT8 *)(void *)(s))[1];\ + ((UINT8 *)(void *)(d))[2] = ((UINT8 *)(void *)(s))[2];\ + ((UINT8 *)(void *)(d))[3] = ((UINT8 *)(void *)(s))[3];\ + ((UINT8 *)(void *)(d))[4] = ((UINT8 *)(void *)(s))[4];\ + ((UINT8 *)(void *)(d))[5] = ((UINT8 *)(void *)(s))[5];\ + ((UINT8 *)(void *)(d))[6] = ((UINT8 *)(void *)(s))[6];\ + ((UINT8 *)(void *)(d))[7] = ((UINT8 *)(void *)(s))[7];} #endif @@ -265,8 +269,8 @@ /* * Rounding macros (Power of two boundaries only) */ -#define ACPI_ROUND_DOWN(value,boundary) (((NATIVE_UINT)(value)) & (~((boundary)-1))) -#define ACPI_ROUND_UP(value,boundary) ((((NATIVE_UINT)(value)) + ((boundary)-1)) & (~((boundary)-1))) +#define ACPI_ROUND_DOWN(value,boundary) (((NATIVE_UINT)(value)) & (~(((NATIVE_UINT) boundary)-1))) +#define ACPI_ROUND_UP(value,boundary) ((((NATIVE_UINT)(value)) + (((NATIVE_UINT) boundary)-1)) & (~(((NATIVE_UINT) boundary)-1))) #define ACPI_ROUND_DOWN_TO_32_BITS(a) ACPI_ROUND_DOWN(a,4) #define ACPI_ROUND_DOWN_TO_64_BITS(a) ACPI_ROUND_DOWN(a,8) @@ -292,22 +296,33 @@ * MASK_BITS_ABOVE creates a mask starting AT the position and above * MASK_BITS_BELOW creates a mask starting one bit BELOW the position */ -#define ACPI_MASK_BITS_ABOVE(position) (~(((ACPI_INTEGER)(-1)) << ((UINT32) (position)))) -#define ACPI_MASK_BITS_BELOW(position) (((ACPI_INTEGER)(-1)) << ((UINT32) (position))) +#define ACPI_MASK_BITS_ABOVE(position) (~((ACPI_INTEGER_MAX) << ((UINT32) (position)))) +#define ACPI_MASK_BITS_BELOW(position) ((ACPI_INTEGER_MAX) << ((UINT32) (position))) #define ACPI_IS_OCTAL_DIGIT(d) (((char)(d) >= '0') && ((char)(d) <= '7')) /* Macros for GAS addressing */ -#ifndef _IA16 +#if ACPI_MACHINE_WIDTH != 16 #define ACPI_PCI_DEVICE_MASK (UINT64) 0x0000FFFF00000000 #define ACPI_PCI_FUNCTION_MASK (UINT64) 0x00000000FFFF0000 #define ACPI_PCI_REGISTER_MASK (UINT64) 0x000000000000FFFF -#define ACPI_PCI_FUNCTION(a) (UINT16) ((((a) & ACPI_PCI_FUNCTION_MASK) >> 16)) -#define ACPI_PCI_DEVICE(a) (UINT16) ((((a) & ACPI_PCI_DEVICE_MASK) >> 32)) -#define ACPI_PCI_REGISTER(a) (UINT16) (((a) & ACPI_PCI_REGISTER_MASK)) +/* + * Obsolete + */ + +/* +#define ACPI_PCI_FUNCTION(a) (UINT16) ((((UINT64)((UINT64)(a) & ACPI_PCI_FUNCTION_MASK)) >> 16)) +#define ACPI_PCI_DEVICE(a) (UINT16) ((((UINT64)((UINT64)(a) & ACPI_PCI_DEVICE_MASK)) >> 32)) +#define ACPI_PCI_REGISTER(a) (UINT16) (((UINT64)((UINT64)(a) & ACPI_PCI_REGISTER_MASK))) +*/ + + +#define ACPI_PCI_DEVICE(a) (UINT16) ((ACPI_HIDWORD ((a))) & 0x0000FFFF) +#define ACPI_PCI_FUNCTION(a) (UINT16) ((ACPI_LODWORD ((a))) >> 16) +#define ACPI_PCI_REGISTER(a) (UINT16) ((ACPI_LODWORD ((a))) & 0x0000FFFF) #else @@ -332,13 +347,13 @@ * * The "Descriptor" field is the first field in both structures. */ -#define ACPI_GET_DESCRIPTOR_TYPE(d) (((ACPI_NAMESPACE_NODE *)d)->Descriptor) -#define ACPI_SET_DESCRIPTOR_TYPE(d,t) (((ACPI_NAMESPACE_NODE *)d)->Descriptor = t) +#define ACPI_GET_DESCRIPTOR_TYPE(d) (((ACPI_DESCRIPTOR *)(void *)(d))->DescriptorId) +#define ACPI_SET_DESCRIPTOR_TYPE(d,t) (((ACPI_DESCRIPTOR *)(void *)(d))->DescriptorId = t) /* Macro to test the object type */ -#define ACPI_GET_OBJECT_TYPE(d) (((ACPI_OPERAND_OBJECT *)d)->Common.Type) +#define ACPI_GET_OBJECT_TYPE(d) (((ACPI_OPERAND_OBJECT *)(void *)(d))->Common.Type) /* Macro to check the table flags for SINGLE or MULTIPLE tables are allowed */ @@ -350,7 +365,7 @@ * as a pointer to an ACPI_TABLE_HEADER. (b+1) then points past the header, * and ((UINT8 *)b+b->Length) points one byte past the end of the table. */ -#ifndef _IA16 +#if ACPI_MACHINE_WIDTH != 16 #define ACPI_IS_IN_ACPI_TABLE(a,b) (((UINT8 *)(a) >= (UINT8 *)(b + 1)) &&\ ((UINT8 *)(a) < ((UINT8 *)b + b->Length))) @@ -363,7 +378,7 @@ /* * Macros for the master AML opcode table */ -#ifdef ACPI_DEBUG +#if defined(ACPI_DEBUG) || defined(ENABLE_DEBUGGER) #define ACPI_OP(Name,PArgs,IArgs,ObjType,Class,Type,Flags) {Name,PArgs,IArgs,Flags,ObjType,Class,Type} #else #define ACPI_OP(Name,PArgs,IArgs,ObjType,Class,Type,Flags) {PArgs,IArgs,Flags,ObjType,Class,Type} @@ -408,7 +423,7 @@ a.RegisterBitWidth = (UINT8) ACPI_MUL_8 (b);\ a.RegisterBitOffset = 0;\ a.Reserved = 0;\ - ACPI_STORE_ADDRESS (a.Address,c);} + ACPI_STORE_ADDRESS (a.Address,(ACPI_PHYSICAL_ADDRESS) c);} /* ACPI V1.0 entries -- address space is always I/O */ @@ -493,11 +508,16 @@ * One of the FUNCTION_TRACE macros above must be used in conjunction with these macros * so that "_ProcName" is defined. */ -#define return_VOID {AcpiUtExit(__LINE__,&_Dbg);return;} -#define return_ACPI_STATUS(s) {AcpiUtStatusExit(__LINE__,&_Dbg,s);return(s);} -#define return_VALUE(s) {AcpiUtValueExit(__LINE__,&_Dbg,s);return(s);} -#define return_PTR(s) {AcpiUtPtrExit(__LINE__,&_Dbg,(UINT8 *)s);return(s);} +#ifdef ACPI_USE_DO_WHILE_0 +#define ACPI_DO_WHILE0(a) do a while(0) +#else +#define ACPI_DO_WHILE0(a) a +#endif +#define return_VOID ACPI_DO_WHILE0 ({AcpiUtExit(__LINE__,&_Dbg);return;}) +#define return_ACPI_STATUS(s) ACPI_DO_WHILE0 ({AcpiUtStatusExit(__LINE__,&_Dbg,(s));return((s));}) +#define return_VALUE(s) ACPI_DO_WHILE0 ({AcpiUtValueExit(__LINE__,&_Dbg,(ACPI_INTEGER)(s));return((s));}) +#define return_PTR(s) ACPI_DO_WHILE0 ({AcpiUtPtrExit(__LINE__,&_Dbg,(UINT8 *)(s));return((s));}) /* Conditional execution */ @@ -518,7 +538,7 @@ #define ACPI_DUMP_ENTRY(a,b) AcpiNsDumpEntry (a,b) #define ACPI_DUMP_TABLES(a,b) AcpiNsDumpTables(a,b) -#define ACPI_DUMP_PATHNAME(a,b,c,d) AcpiNsDumpPathname(a,b,c,d) +#define ACPI_DUMP_PATHNAME(a,b,c,d) (void) AcpiNsDumpPathname(a,b,c,d) #define ACPI_DUMP_RESOURCE_LIST(a) AcpiRsDumpResourceList(a) #define ACPI_DUMP_BUFFER(a,b) AcpiUtDumpBuffer((UINT8 *)a,b,DB_BYTE_DISPLAY,_COMPONENT) #define ACPI_BREAK_MSG(a) AcpiOsSignal (ACPI_SIGNAL_BREAKPOINT,(a)) @@ -586,6 +606,10 @@ #define return_VALUE(s) return(s) #define return_PTR(s) return(s) +#ifdef ENABLE_DEBUGGER +#define _OPCODE_NAMES +#endif + #endif /* @@ -604,7 +628,7 @@ * For 16-bit code, we want to shrink some things even though * we are using ACPI_DEBUG to get the debug output */ -#ifdef _IA16 +#if ACPI_MACHINE_WIDTH == 16 #undef ACPI_DEBUG_ONLY_MEMBERS #undef _VERBOSE_STRUCTURES #define ACPI_DEBUG_ONLY_MEMBERS(a) @@ -632,8 +656,8 @@ /* Memory allocation */ -#define ACPI_MEM_ALLOCATE(a) AcpiUtAllocate(a,_COMPONENT,_THIS_MODULE,__LINE__) -#define ACPI_MEM_CALLOCATE(a) AcpiUtCallocate(a, _COMPONENT,_THIS_MODULE,__LINE__) +#define ACPI_MEM_ALLOCATE(a) AcpiUtAllocate((ACPI_SIZE)(a),_COMPONENT,_THIS_MODULE,__LINE__) +#define ACPI_MEM_CALLOCATE(a) AcpiUtCallocate((ACPI_SIZE)(a), _COMPONENT,_THIS_MODULE,__LINE__) #define ACPI_MEM_FREE(a) AcpiOsFree(a) #define ACPI_MEM_TRACKING(a) @@ -642,8 +666,8 @@ /* Memory allocation */ -#define ACPI_MEM_ALLOCATE(a) AcpiUtAllocateAndTrack(a,_COMPONENT,_THIS_MODULE,__LINE__) -#define ACPI_MEM_CALLOCATE(a) AcpiUtCallocateAndTrack(a, _COMPONENT,_THIS_MODULE,__LINE__) +#define ACPI_MEM_ALLOCATE(a) AcpiUtAllocateAndTrack((ACPI_SIZE)(a),_COMPONENT,_THIS_MODULE,__LINE__) +#define ACPI_MEM_CALLOCATE(a) AcpiUtCallocateAndTrack((ACPI_SIZE)(a), _COMPONENT,_THIS_MODULE,__LINE__) #define ACPI_MEM_FREE(a) AcpiUtFreeAndTrack(a,_COMPONENT,_THIS_MODULE,__LINE__) #define ACPI_MEM_TRACKING(a) a Index: acnamesp.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acnamesp.h,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 acnamesp.h --- acnamesp.h 23 Feb 2002 05:10:35 -0000 1.1.1.10 +++ acnamesp.h 1 Jul 2002 21:39:53 -0000 @@ -199,7 +199,7 @@ ACPI_NAMESPACE_NODE *Parent, ACPI_NAMESPACE_NODE *Child); -ACPI_STATUS +void AcpiNsDeleteNamespaceByOwner ( UINT16 TableId); @@ -230,7 +230,6 @@ * Top-level namespace access - nsaccess */ - ACPI_STATUS AcpiNsRootInitialize ( void); @@ -250,7 +249,6 @@ * Named object allocation/deallocation - nsalloc */ - ACPI_NAMESPACE_NODE * AcpiNsCreateNode ( UINT32 Name); @@ -259,7 +257,7 @@ AcpiNsDeleteNode ( ACPI_NAMESPACE_NODE *Node); -ACPI_STATUS +void AcpiNsDeleteNamespaceSubtree ( ACPI_NAMESPACE_NODE *ParentHandle); @@ -311,10 +309,24 @@ UINT32 NumSegments, char *Pathname); +ACPI_STATUS +AcpiNsDumpOneDevice ( + ACPI_HANDLE ObjHandle, + UINT32 Level, + void *Context, + void **ReturnValue); + void AcpiNsDumpRootDevices ( void); +ACPI_STATUS +AcpiNsDumpOneObject ( + ACPI_HANDLE ObjHandle, + UINT32 Level, + void *Context, + void **ReturnValue); + void AcpiNsDumpObjects ( ACPI_OBJECT_TYPE Type, @@ -380,6 +392,12 @@ AcpiNsOpensScope ( ACPI_OBJECT_TYPE Type); +void +AcpiNsBuildExternalPath ( + ACPI_NAMESPACE_NODE *Node, + ACPI_SIZE Size, + NATIVE_CHAR *NameBuffer); + NATIVE_CHAR * AcpiNsGetExternalPathname ( ACPI_NAMESPACE_NODE *Node); @@ -499,7 +517,7 @@ AcpiNsBuildInternalName ( ACPI_NAMESTRING_INFO *Info); -ACPI_STATUS +void AcpiNsGetInternalNameLength ( ACPI_NAMESTRING_INFO *Info); Index: acobject.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acobject.h,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 acobject.h --- acobject.h 30 Jun 2002 17:50:42 -0000 1.1.1.11 +++ acobject.h 1 Jul 2002 21:39:53 -0000 @@ -147,7 +147,7 @@ /* Values for flag byte above */ -#define AOPOBJ_RESERVED 0x01 +#define AOPOBJ_AML_CONSTANT 0x01 #define AOPOBJ_STATIC_POINTER 0x02 #define AOPOBJ_DATA_VALID 0x04 #define AOPOBJ_OBJECT_INITIALIZED 0x08 @@ -579,5 +579,46 @@ ACPI_OBJECT_CACHE_LIST Cache; } ACPI_OPERAND_OBJECT; + + + + + +/****************************************************************************** + * + * ACPI_DESCRIPTOR - objects that share a common descriptor identifier + * + *****************************************************************************/ + + +/* Object descriptor types */ + +#define ACPI_DESC_TYPE_CACHED 0x11 /* Used only when object is cached */ +#define ACPI_DESC_TYPE_STATE 0x20 +#define ACPI_DESC_TYPE_STATE_UPDATE 0x21 +#define ACPI_DESC_TYPE_STATE_PACKAGE 0x22 +#define ACPI_DESC_TYPE_STATE_CONTROL 0x23 +#define ACPI_DESC_TYPE_STATE_RPSCOPE 0x24 +#define ACPI_DESC_TYPE_STATE_PSCOPE 0x25 +#define ACPI_DESC_TYPE_STATE_WSCOPE 0x26 +#define ACPI_DESC_TYPE_STATE_RESULT 0x27 +#define ACPI_DESC_TYPE_STATE_NOTIFY 0x28 +#define ACPI_DESC_TYPE_STATE_THREAD 0x29 +#define ACPI_DESC_TYPE_WALK 0x44 +#define ACPI_DESC_TYPE_PARSER 0x66 +#define ACPI_DESC_TYPE_OPERAND 0x88 +#define ACPI_DESC_TYPE_NAMED 0xAA + + + +typedef union acpi_desc +{ + UINT8 DescriptorId; /* To differentiate various internal objs */\ + ACPI_OPERAND_OBJECT Object; + ACPI_NAMESPACE_NODE Node; + ACPI_PARSE_OBJECT Op; + +} ACPI_DESCRIPTOR; + #endif /* _ACOBJECT_H */ Index: acoutput.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acoutput.h,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 acoutput.h --- acoutput.h 23 Feb 2002 05:10:35 -0000 1.1.1.10 +++ acoutput.h 1 Jul 2002 21:39:53 -0000 @@ -196,6 +196,16 @@ #define ACPI_LV_INTERRUPTS 0x08000000 #define ACPI_LV_VERBOSITY3 0x0F000000 | ACPI_LV_VERBOSITY2 +/* Exceptionally verbose output -- also used in the global "DebugLevel" */ + +#define ACPI_LV_AML_DISASSEMBLE 0x10000000 +#define ACPI_LV_VERBOSE_INFO 0x20000000 +#define ACPI_LV_FULL_TABLES 0x40000000 +#define ACPI_LV_EVENTS 0x80000000 + +#define ACPI_LV_VERBOSE 0xF0000000 + + /* * Debug level macros that are used in the DEBUG_PRINT macros */ @@ -236,17 +246,8 @@ #define ACPI_DB_MUTEX ACPI_DEBUG_LEVEL (ACPI_LV_MUTEX) #define ACPI_DB_INIT ACPI_DEBUG_LEVEL (ACPI_LV_INIT) -#define ACPI_DB_ALL ACPI_DEBUG_LEVEL (0x0FFFFF80) - - -/* Exceptionally verbose output -- also used in the global "DebugLevel" */ - -#define ACPI_DB_AML_DISASSEMBLE 0x10000000 -#define ACPI_DB_VERBOSE_INFO 0x20000000 -#define ACPI_DB_FULL_TABLES 0x40000000 -#define ACPI_DB_EVENTS 0x80000000 +#define ACPI_DB_ALL ACPI_DEBUG_LEVEL (ACPI_LV_ALL) -#define ACPI_DB_VERBOSE 0xF0000000 /* Defaults for DebugLevel, debug and normal */ Index: acparser.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acparser.h,v retrieving revision 1.1.1.7 diff -u -r1.1.1.7 acparser.h --- acparser.h 23 Feb 2002 05:10:35 -0000 1.1.1.7 +++ acparser.h 1 Jul 2002 21:39:53 -0000 @@ -225,7 +225,7 @@ AcpiPsGetOpcodeSize ( UINT32 Opcode); -BOOLEAN +void AcpiPsCompleteThisOp ( ACPI_WALK_STATE *WalkState, ACPI_PARSE_OBJECT *Op); Index: acpixf.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acpixf.h,v retrieving revision 1.14 diff -u -r1.14 acpixf.h --- acpixf.h 30 Jun 2002 17:53:04 -0000 1.14 +++ acpixf.h 1 Jul 2002 21:39:53 -0000 @@ -162,6 +162,10 @@ AcpiPurgeCachedObjects ( void); +ACPI_STATUS +AcpiInstallInitializationHandler ( + ACPI_INIT_HANDLER Handler, + UINT32 Function); /* * ACPI Memory manager @@ -283,6 +287,14 @@ ACPI_BUFFER *ReturnObjectBuffer); ACPI_STATUS +AcpiEvaluateObjectTyped ( + ACPI_HANDLE Object, + ACPI_STRING Pathname, + ACPI_OBJECT_LIST *ExternalParams, + ACPI_BUFFER *ReturnBuffer, + ACPI_OBJECT_TYPE ReturnType); + +ACPI_STATUS AcpiGetObjectInfo ( ACPI_HANDLE Device, ACPI_DEVICE_INFO *Info); @@ -421,6 +433,18 @@ */ ACPI_STATUS +AcpiGetRegister ( + UINT32 RegisterId, + UINT32 *ReturnValue, + UINT32 Flags); + +ACPI_STATUS +AcpiSetRegister ( + UINT32 RegisterId, + UINT32 Value, + UINT32 Flags); + +ACPI_STATUS AcpiSetFirmwareWakingVector ( ACPI_PHYSICAL_ADDRESS PhysicalAddress); @@ -428,17 +452,23 @@ AcpiGetFirmwareWakingVector ( ACPI_PHYSICAL_ADDRESS *PhysicalAddress); +ACPI_STATUS +AcpiGetSleepTypeData ( + UINT8 SleepState, + UINT8 *Slp_TypA, + UINT8 *Slp_TypB); ACPI_STATUS AcpiEnterSleepStatePrep ( - UINT8 SleepState); + UINT8 SleepState); ACPI_STATUS AcpiEnterSleepState ( - UINT8 SleepState); + UINT8 SleepState); ACPI_STATUS AcpiLeaveSleepState ( - UINT8 SleepState); + UINT8 SleepState); + #endif /* __ACXFACE_H__ */ Index: acresrc.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acresrc.h,v retrieving revision 1.1.1.5 diff -u -r1.1.1.5 acresrc.h --- acresrc.h 23 Feb 2002 05:10:35 -0000 1.1.1.5 +++ acresrc.h 1 Jul 2002 21:39:53 -0000 @@ -161,8 +161,59 @@ /* - *Function prototypes called from AcpiRsCreate* + * Function prototypes called from AcpiRsCreate* */ +void +AcpiRsDumpIrq ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpAddress16 ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpAddress32 ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpAddress64 ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpDma ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpIo ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpExtendedIrq ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpFixedIo ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpFixedMemory32 ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpMemory24 ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpMemory32 ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpStartDependFns ( + ACPI_RESOURCE_DATA *Data); + +void +AcpiRsDumpVendorSpecific ( + ACPI_RESOURCE_DATA *Data); void AcpiRsDumpResourceList ( @@ -179,18 +230,18 @@ UINT32 *Size); ACPI_STATUS -AcpiRsCalculateListLength ( +AcpiRsGetListLength ( UINT8 *ByteStreamBuffer, UINT32 ByteStreamBufferLength, ACPI_SIZE *SizeNeeded); ACPI_STATUS -AcpiRsCalculateByteStreamLength ( +AcpiRsGetByteStreamLength ( ACPI_RESOURCE *LinkedListBuffer, ACPI_SIZE *SizeNeeded); ACPI_STATUS -AcpiRsCalculatePciRoutingTableLength ( +AcpiRsGetPciRoutingTableLength ( ACPI_OPERAND_OBJECT *PackageObject, ACPI_SIZE *BufferSizeNeeded); @@ -203,7 +254,7 @@ ACPI_STATUS AcpiRsListToByteStream ( ACPI_RESOURCE *LinkedList, - UINT32 ByteStreamSizeNeeded, + ACPI_SIZE ByteStreamSizeNeeded, UINT8 *OutputBuffer); ACPI_STATUS Index: acstruct.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acstruct.h,v retrieving revision 1.1.1.7 diff -u -r1.1.1.7 acstruct.h --- acstruct.h 30 Jun 2002 17:50:42 -0000 1.1.1.7 +++ acstruct.h 1 Jul 2002 21:39:53 -0000 @@ -130,12 +130,14 @@ * the tree (for whatever reason), and for control method execution. */ -#define ACPI_NEXT_OP_DOWNWARD 1 -#define ACPI_NEXT_OP_UPWARD 2 +#define ACPI_NEXT_OP_DOWNWARD 1 +#define ACPI_NEXT_OP_UPWARD 2 -#define ACPI_WALK_NON_METHOD 0 -#define ACPI_WALK_METHOD 1 -#define ACPI_WALK_METHOD_RESTART 2 +#define ACPI_WALK_NON_METHOD 0 +#define ACPI_WALK_METHOD 1 +#define ACPI_WALK_METHOD_RESTART 2 +#define ACPI_WALK_CONST_REQUIRED 3 +#define ACPI_WALK_CONST_OPTIONAL 4 typedef struct acpi_walk_state { @@ -193,6 +195,7 @@ typedef struct acpi_init_walk_info { UINT16 MethodCount; + UINT16 DeviceCount; UINT16 OpRegionCount; UINT16 FieldCount; UINT16 BufferCount; Index: actables.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/actables.h,v retrieving revision 1.1.1.8 diff -u -r1.1.1.8 actables.h --- actables.h 30 Jun 2002 17:50:42 -0000 1.1.1.8 +++ actables.h 1 Jul 2002 21:39:53 -0000 @@ -154,6 +154,15 @@ * tbget - Table "get" routines */ +void +AcpiTbTableOverride ( + ACPI_TABLE_DESC *TableInfo); + +ACPI_STATUS +AcpiTbGetTableWithOverride ( + ACPI_POINTER *Address, + ACPI_TABLE_DESC *TableInfo); + ACPI_STATUS AcpiTbGetTablePtr ( ACPI_TABLE_TYPE TableType, @@ -181,7 +190,7 @@ AcpiTbGetTablePointer ( ACPI_POINTER *Address, UINT32 Flags, - UINT32 *Size, + ACPI_SIZE *Size, ACPI_TABLE_HEADER **TablePtr); /* @@ -190,8 +199,7 @@ ACPI_STATUS AcpiTbGetAllTables ( - UINT32 NumberOfTables, - ACPI_TABLE_HEADER *BufferPtr); + UINT32 NumberOfTables); /* @@ -200,7 +208,6 @@ ACPI_STATUS AcpiTbInstallTable ( - ACPI_TABLE_HEADER *TablePtr, ACPI_TABLE_DESC *TableInfo); ACPI_STATUS @@ -210,7 +217,6 @@ ACPI_STATUS AcpiTbRecognizeTable ( - ACPI_TABLE_HEADER *TablePtr, ACPI_TABLE_DESC *TableInfo); ACPI_STATUS @@ -277,7 +283,7 @@ ACPI_STATUS AcpiTbMapAcpiTable ( ACPI_PHYSICAL_ADDRESS PhysicalAddress, - UINT32 *Size, + ACPI_SIZE *Size, ACPI_TABLE_HEADER **LogicalAddress); ACPI_STATUS Index: actypes.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/actypes.h,v retrieving revision 1.1.1.17 diff -u -r1.1.1.17 actypes.h --- actypes.h 30 Jun 2002 17:50:42 -0000 1.1.1.17 +++ actypes.h 1 Jul 2002 21:39:53 -0000 @@ -119,13 +119,23 @@ /*! [Begin] no source code translation (keep the typedefs) */ + + +/* + * Data type ranges + */ +#define ACPI_UINT8_MAX (UINT8) 0xFF +#define ACPI_UINT16_MAX (UINT16) 0xFFFF +#define ACPI_UINT32_MAX (UINT32) 0xFFFFFFFF +#define ACPI_UINT64_MAX (UINT64) 0xFFFFFFFFFFFFFFFF +#define ACPI_ASCII_MAX 0x7F + + + /* * Data types - Fixed across all compilation models * * BOOLEAN Logical Boolean. - * 1 byte value containing a 0 for FALSE or a 1 for TRUE. - * Other values are undefined. - * * INT8 8-bit (1 byte) signed value * UINT8 8-bit (1 byte) unsigned value * INT16 16-bit (2 byte) signed value @@ -138,8 +148,11 @@ * NATIVE_UINT 32-bit on IA-32, 64-bit on IA-64 unsigned value */ +#ifndef ACPI_MACHINE_WIDTH +#error ACPI_MACHINE_WIDTH not defined +#endif -#ifdef _IA64 +#if ACPI_MACHINE_WIDTH == 64 /* * 64-bit type definitions */ @@ -151,8 +164,11 @@ typedef COMPILER_DEPENDENT_INT64 INT64; typedef COMPILER_DEPENDENT_UINT64 UINT64; +typedef INT64 NATIVE_INT; typedef UINT64 NATIVE_UINT; -typedef UINT64 NATIVE_INT; + +typedef UINT32 NATIVE_UINT_MAX32; +typedef UINT64 NATIVE_UINT_MIN32; typedef UINT64 ACPI_TBLPTR; typedef UINT64 ACPI_IO_ADDRESS; @@ -161,10 +177,11 @@ #define ALIGNED_ADDRESS_BOUNDARY 0x00000008 /* No hardware alignment support in IA64 */ #define ACPI_USE_NATIVE_DIVIDE /* Native 64-bit integer support */ -#define ACPI_MAX_PTR 0xFFFFFFFFFFFFFFFF +#define ACPI_MAX_PTR ACPI_UINT64_MAX +#define ACPI_SIZE_MAX ACPI_UINT64_MAX -#elif _IA16 +#elif ACPI_MACHINE_WIDTH == 16 /* * 16-bit type definitions */ @@ -185,15 +202,19 @@ typedef UINT16 NATIVE_UINT; typedef INT16 NATIVE_INT; +typedef UINT16 NATIVE_UINT_MAX32; +typedef UINT32 NATIVE_UINT_MIN32; + typedef UINT32 ACPI_TBLPTR; typedef UINT32 ACPI_IO_ADDRESS; typedef char *ACPI_PHYSICAL_ADDRESS; -typedef UINT32 ACPI_SIZE; +typedef UINT16 ACPI_SIZE; #define ALIGNED_ADDRESS_BOUNDARY 0x00000002 #define _HW_ALIGNMENT_SUPPORT #define ACPI_USE_NATIVE_DIVIDE /* No 64-bit integers, ok to use native divide */ -#define ACPI_MAX_PTR 0xFFFF +#define ACPI_MAX_PTR ACPI_UINT16_MAX +#define ACPI_SIZE_MAX ACPI_UINT16_MAX /* * (16-bit only) internal integers must be 32-bits, so @@ -202,7 +223,7 @@ #define ACPI_NO_INTEGER64_SUPPORT -#else +#elif ACPI_MACHINE_WIDTH == 32 /* * 32-bit type definitions (default) */ @@ -214,8 +235,11 @@ typedef COMPILER_DEPENDENT_INT64 INT64; typedef COMPILER_DEPENDENT_UINT64 UINT64; -typedef UINT32 NATIVE_UINT; typedef INT32 NATIVE_INT; +typedef UINT32 NATIVE_UINT; + +typedef UINT32 NATIVE_UINT_MAX32; +typedef UINT32 NATIVE_UINT_MIN32; typedef UINT64 ACPI_TBLPTR; typedef UINT32 ACPI_IO_ADDRESS; @@ -224,9 +248,12 @@ #define ALIGNED_ADDRESS_BOUNDARY 0x00000004 #define _HW_ALIGNMENT_SUPPORT -#define ACPI_MAX_PTR 0xFFFFFFFF -#endif +#define ACPI_MAX_PTR ACPI_UINT32_MAX +#define ACPI_SIZE_MAX ACPI_UINT32_MAX +#else +#error unknown ACPI_MACHINE_WIDTH +#endif /* @@ -238,16 +265,6 @@ typedef char NATIVE_CHAR; -/* - * Data type ranges - */ -#define ACPI_UINT8_MAX (UINT8) 0xFF -#define ACPI_UINT16_MAX (UINT16) 0xFFFF -#define ACPI_UINT32_MAX (UINT32) 0xFFFFFFFF -#define ACPI_UINT64_MAX (UINT64) 0xFFFFFFFFFFFFFFFF -#define ACPI_ASCII_MAX 0x7F - - #ifdef DEFINE_ALTERNATE_TYPES /* * Types used only in translated source, defined here to enable @@ -266,7 +283,7 @@ * Pointer overlays to avoid lots of typecasting for * code that accepts both physical and logical pointers. */ -typedef union AcpiPointers +typedef union acpi_ptrs { ACPI_PHYSICAL_ADDRESS Physical; void *Logical; @@ -277,7 +294,7 @@ typedef struct AcpiPointer { UINT32 PointerType; - ACPI_POINTERS Pointer; + union acpi_ptrs Pointer; } ACPI_POINTER; @@ -329,6 +346,13 @@ } UINT64_OVERLAY; +typedef struct +{ + UINT32 Lo; + UINT32 Hi; + +} UINT32_STRUCT; + /* * Acpi integer width. In ACPI version 1, integers are @@ -362,7 +386,7 @@ #define ACPI_MAX_BCD_DIGITS 16 #define ACPI_MAX_DECIMAL_DIGITS 19 -#ifdef _IA64 +#if ACPI_MACHINE_WIDTH == 64 #define ACPI_USE_NATIVE_DIVIDE /* Use compiler native 64-bit divide */ #endif #endif @@ -372,7 +396,7 @@ * Constants with special meanings */ -#define ACPI_ROOT_OBJECT (ACPI_HANDLE) ACPI_PTR_ADD (char, NULL, ACPI_UINT32_MAX) +#define ACPI_ROOT_OBJECT (ACPI_HANDLE) ACPI_PTR_ADD (char, NULL, ACPI_MAX_PTR) /* @@ -653,6 +677,37 @@ /* + * BitRegister IDs + * These are bitfields defined within the full ACPI registers + */ +#define ACPI_BITREG_TIMER_STATUS 0x00 +#define ACPI_BITREG_BUS_MASTER_STATUS 0x01 +#define ACPI_BITREG_GLOBAL_LOCK_STATUS 0x02 +#define ACPI_BITREG_POWER_BUTTON_STATUS 0x03 +#define ACPI_BITREG_SLEEP_BUTTON_STATUS 0x04 +#define ACPI_BITREG_RT_CLOCK_STATUS 0x05 +#define ACPI_BITREG_WAKE_STATUS 0x06 + +#define ACPI_BITREG_TIMER_ENABLE 0x07 +#define ACPI_BITREG_GLOBAL_LOCK_ENABLE 0x08 +#define ACPI_BITREG_POWER_BUTTON_ENABLE 0x09 +#define ACPI_BITREG_SLEEP_BUTTON_ENABLE 0x0A +#define ACPI_BITREG_RT_CLOCK_ENABLE 0x0B +#define ACPI_BITREG_WAKE_ENABLE 0x0C + +#define ACPI_BITREG_SCI_ENABLE 0x0D +#define ACPI_BITREG_BUS_MASTER_RLD 0x0E +#define ACPI_BITREG_GLOBAL_LOCK_RELEASE 0x0F +#define ACPI_BITREG_SLEEP_TYPE_A 0x10 +#define ACPI_BITREG_SLEEP_TYPE_B 0x11 +#define ACPI_BITREG_SLEEP_ENABLE 0x12 + +#define ACPI_BITREG_ARB_DISABLE 0x13 + +#define ACPI_BITREG_MAX 0x13 +#define ACPI_NUM_BITREG ACPI_BITREG_MAX + 1 + +/* * External ACPI object definition */ @@ -811,6 +866,13 @@ UINT32 Function, void *Data); +typedef +ACPI_STATUS (*ACPI_INIT_HANDLER) ( + ACPI_HANDLE Object, + UINT32 Function); + +#define ACPI_INIT_DEVICE_INI 1 + /* Address Spaces (Operation Regions */ @@ -823,7 +885,7 @@ void *HandlerContext, void *RegionContext); -#define ACPI_DEFAULT_HANDLER ((ACPI_ADR_SPACE_HANDLER) NULL) +#define ACPI_DEFAULT_HANDLER NULL typedef @@ -898,7 +960,7 @@ ACPI_PHYSICAL_ADDRESS Address; ACPI_PHYSICAL_ADDRESS MappedPhysicalAddress; UINT8 *MappedLogicalAddress; - UINT32 MappedLength; + ACPI_SIZE MappedLength; } ACPI_MEM_SPACE_CONTEXT; Index: acutils.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/acutils.h,v retrieving revision 1.1.1.15 diff -u -r1.1.1.15 acutils.h --- acutils.h 16 Mar 2002 02:18:04 -0000 1.1.1.15 +++ acutils.h 1 Jul 2002 21:39:53 -0000 @@ -173,7 +173,7 @@ AcpiUtHardwareInitialize ( void); -ACPI_STATUS +void AcpiUtSubsystemShutdown ( void); @@ -185,18 +185,22 @@ * UtGlobal - Global data structures and procedures */ -#ifdef ACPI_DEBUG +#if defined(ACPI_DEBUG) || defined(ENABLE_DEBUGGER) NATIVE_CHAR * AcpiUtGetMutexName ( UINT32 MutexId); +#endif + + NATIVE_CHAR * AcpiUtGetTypeName ( ACPI_OBJECT_TYPE Type); -#endif - +NATIVE_CHAR * +AcpiUtGetObjectTypeName ( + ACPI_OPERAND_OBJECT *ObjDesc); NATIVE_CHAR * AcpiUtGetRegionName ( @@ -206,7 +210,7 @@ AcpiUtGetEventName ( UINT32 EventId); -UINT8 +char AcpiUtHexToAsciiChar ( ACPI_INTEGER Integer, UINT32 Position); @@ -241,7 +245,7 @@ const NATIVE_CHAR *SrcString, NATIVE_UINT Count); -UINT32 +int AcpiUtStrncmp ( const NATIVE_CHAR *String1, const NATIVE_CHAR *String2, @@ -286,13 +290,32 @@ NATIVE_UINT Value, NATIVE_UINT Count); -UINT32 +int AcpiUtToUpper ( - UINT32 c); + int c); -UINT32 +int AcpiUtToLower ( - UINT32 c); + int c); + +extern const UINT8 _acpi_ctype[]; + +#define _ACPI_XA 0x00 /* extra alphabetic - not supported */ +#define _ACPI_XS 0x40 /* extra space */ +#define _ACPI_BB 0x00 /* BEL, BS, etc. - not supported */ +#define _ACPI_CN 0x20 /* CR, FF, HT, NL, VT */ +#define _ACPI_DI 0x04 /* '0'-'9' */ +#define _ACPI_LO 0x02 /* 'a'-'z' */ +#define _ACPI_PU 0x10 /* punctuation */ +#define _ACPI_SP 0x08 /* space */ +#define _ACPI_UP 0x01 /* 'A'-'Z' */ +#define _ACPI_XD 0x80 /* '0'-'9', 'A'-'F', 'a'-'f' */ + +#define ACPI_IS_DIGIT(c) (_acpi_ctype[(unsigned char)(c)] & (_ACPI_DI)) +#define ACPI_IS_SPACE(c) (_acpi_ctype[(unsigned char)(c)] & (_ACPI_SP)) +#define ACPI_IS_XDIGIT(c) (_acpi_ctype[(unsigned char)(c)] & (_ACPI_XD)) +#define ACPI_IS_UPPER(c) (_acpi_ctype[(unsigned char)(c)] & (_ACPI_UP)) +#define ACPI_IS_LOWER(c) (_acpi_ctype[(unsigned char)(c)] & (_ACPI_LO)) #endif /* ACPI_USE_SYSTEM_CLIBRARY */ @@ -314,6 +337,20 @@ UINT32 *SpaceUsed); ACPI_STATUS +AcpiUtCopyIelementToEelement ( + UINT8 ObjectType, + ACPI_OPERAND_OBJECT *SourceObject, + ACPI_GENERIC_STATE *State, + void *Context); + +ACPI_STATUS +AcpiUtCopyIelementToIelement ( + UINT8 ObjectType, + ACPI_OPERAND_OBJECT *SourceObject, + ACPI_GENERIC_STATE *State, + void *Context); + +ACPI_STATUS AcpiUtCopyIobjectToEobject ( ACPI_OPERAND_OBJECT *Obj, ACPI_BUFFER *RetBuffer); @@ -477,7 +514,7 @@ AcpiUtDeleteInternalSimpleObject ( ACPI_OPERAND_OBJECT *Object); -ACPI_STATUS +void AcpiUtDeleteInternalObjectList ( ACPI_OPERAND_OBJECT **ObjList); @@ -615,6 +652,13 @@ ACPI_OPERAND_OBJECT *Obj, ACPI_SIZE *ObjLength); +ACPI_STATUS +AcpiUtGetElementLength ( + UINT8 ObjectType, + ACPI_OPERAND_OBJECT *SourceObject, + ACPI_GENERIC_STATE *State, + void *Context); + /* * UtState - Generic state creation/cache routines @@ -704,14 +748,16 @@ AcpiUtValidAcpiCharacter ( NATIVE_CHAR Character); +ACPI_STATUS +AcpiUtStrtoul64 ( + NATIVE_CHAR *String, + UINT32 Base, + ACPI_INTEGER *RetInteger); + NATIVE_CHAR * AcpiUtStrupr ( NATIVE_CHAR *SrcString); -ACPI_STATUS -AcpiUtResolvePackageReferences ( - ACPI_OPERAND_OBJECT *ObjDesc); - UINT8 * AcpiUtGetResourceEndTag ( ACPI_OPERAND_OBJECT *ObjDesc); @@ -721,6 +767,14 @@ UINT8 *Buffer, UINT32 Length); +UINT32 +AcpiUtDwordByteSwap ( + UINT32 Value); + +void +AcpiUtSetIntegerWidth ( + UINT8 Revision); + #ifdef ACPI_DEBUG void AcpiUtDisplayInitPathname ( @@ -796,6 +850,12 @@ UINT32 Component, NATIVE_CHAR *Module, UINT32 Line); + +ACPI_DEBUG_MEM_BLOCK * +AcpiUtFindAllocation ( + UINT32 ListId, + void *Allocation); + ACPI_STATUS AcpiUtTrackAllocation ( UINT32 ListId, Index: amlcode.h =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/amlcode.h,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 amlcode.h --- amlcode.h 30 Jun 2002 17:50:43 -0000 1.1.1.10 +++ amlcode.h 1 Jul 2002 21:39:53 -0000 @@ -119,7 +119,6 @@ #ifndef __AMLCODE_H__ #define __AMLCODE_H__ - /* primary opcodes */ #define AML_NULL_CHAR (UINT16) 0x00 @@ -381,6 +380,7 @@ #define AML_CREATE 0x0004 #define AML_MATH 0x0002 #define AML_LOGICAL 0x0001 +#define AML_CONSTANT 0x1000 /* Convenient flag groupings */ Index: dbcmds.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dbcmds.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 dbcmds.c --- dbcmds.c 23 Feb 2002 05:10:35 -0000 1.1.1.11 +++ dbcmds.c 1 Jul 2002 21:39:53 -0000 @@ -116,15 +116,11 @@ #include "acpi.h" -#include "acparser.h" #include "acdispat.h" #include "amlcode.h" #include "acnamesp.h" -#include "acparser.h" #include "acevents.h" -#include "acinterp.h" #include "acdebug.h" -#include "actables.h" #include "acresrc.h" #ifdef ENABLE_DEBUGGER @@ -138,7 +134,7 @@ * These object types map directly to the ACPI_TYPES */ -ARGUMENT_INFO AcpiDbObjectTypes [] = +static ARGUMENT_INFO AcpiDbObjectTypes [] = { {"ANY"}, {"NUMBERS"}, @@ -190,14 +186,14 @@ if (Node == (void *) ObjDesc) { - AcpiOsPrintf ("Object is a Node [%4.4s]\n", &Node->Name); + AcpiOsPrintf ("Object is a Node [%4.4s]\n", Node->Name.Ascii); } /* Check for match against the object attached to the node */ if (AcpiNsGetAttachedObject (Node) == ObjDesc) { - AcpiOsPrintf ("Reference at Node->Object %p [%4.4s]\n", Node, &Node->Name); + AcpiOsPrintf ("Reference at Node->Object %p [%4.4s]\n", Node, Node->Name.Ascii); } return (AE_OK); @@ -229,7 +225,7 @@ /* Search all nodes in namespace */ - AcpiWalkNamespace (ACPI_TYPE_ANY, ACPI_ROOT_OBJECT, ACPI_UINT32_MAX, + (void) AcpiWalkNamespace (ACPI_TYPE_ANY, ACPI_ROOT_OBJECT, ACPI_UINT32_MAX, AcpiDbWalkForReferences, (void *) ObjDesc, NULL); } @@ -377,9 +373,9 @@ /* Get and verify the breakpoint address */ Address = ACPI_STRTOUL (Location, NULL, 16); - if (Address <= Op->AmlOffset) + if (Address <= Op->Common.AmlOffset) { - AcpiOsPrintf ("Breakpoint %X is beyond current address %X\n", Address, Op->AmlOffset); + AcpiOsPrintf ("Breakpoint %X is beyond current address %X\n", Address, Op->Common.AmlOffset); } /* Save breakpoint in current walk */ @@ -596,6 +592,7 @@ UINT32 Value) { ACPI_NAMESPACE_NODE *Node; + ACPI_STATUS Status; /* Translate name to an Named object */ @@ -615,7 +612,11 @@ /* Send the notify */ - AcpiEvQueueNotifyRequest (Node, Value); + Status = AcpiEvQueueNotifyRequest (Node, Value); + if (ACPI_FAILURE (Status)) + { + AcpiOsPrintf ("Could not queue notify\n"); + } break; default: @@ -652,6 +653,7 @@ UINT32 Value; ACPI_WALK_STATE *WalkState; ACPI_OPERAND_OBJECT *ObjDesc; + ACPI_STATUS Status; /* Validate TypeArg */ @@ -698,13 +700,18 @@ /* Set a method argument */ - if (Index > MTH_NUM_ARGS) + if (Index > MTH_MAX_ARG) { AcpiOsPrintf ("Arg%d - Invalid argument name\n", Index); return; } - AcpiDsStoreObjectToLocal (AML_ARG_OP, Index, ObjDesc, WalkState); + Status = AcpiDsStoreObjectToLocal (AML_ARG_OP, Index, ObjDesc, WalkState); + if (ACPI_FAILURE (Status)) + { + return; + } + ObjDesc = WalkState->Arguments[Index].Object; AcpiOsPrintf ("Arg%d: ", Index); @@ -715,13 +722,18 @@ /* Set a method local */ - if (Index > MTH_NUM_LOCALS) + if (Index > MTH_MAX_LOCAL) { AcpiOsPrintf ("Local%d - Invalid local variable name\n", Index); return; } - AcpiDsStoreObjectToLocal (AML_LOCAL_OP, Index, ObjDesc, WalkState); + Status = AcpiDsStoreObjectToLocal (AML_LOCAL_OP, Index, ObjDesc, WalkState); + if (ACPI_FAILURE (Status)) + { + return; + } + ObjDesc = WalkState->LocalVariables[Index].Object; AcpiOsPrintf ("Local%d: ", Index); @@ -778,7 +790,7 @@ if (ObjDesc) { - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_METHOD: AcpiOsPrintf (" #Args %d Concurrency %X", ObjDesc->Method.ParamCount, ObjDesc->Method.Concurrency); @@ -803,6 +815,10 @@ case ACPI_TYPE_BUFFER: AcpiOsPrintf (" Length %X", ObjDesc->Buffer.Length); break; + + default: + /* Ignore other object types */ + break; } } @@ -842,13 +858,14 @@ } AcpiDbSetOutputDestination (ACPI_DB_DUPLICATE_OUTPUT); - AcpiOsPrintf ("Objects of type [%s] defined in the current ACPI Namespace: \n", AcpiUtGetTypeName (Type)); + AcpiOsPrintf ("Objects of type [%s] defined in the current ACPI Namespace: \n", + AcpiUtGetTypeName (Type)); AcpiDbSetOutputDestination (ACPI_DB_REDIRECTABLE_OUTPUT); /* Walk the namespace from the root */ - AcpiWalkNamespace (Type, ACPI_ROOT_OBJECT, ACPI_UINT32_MAX, + (void) AcpiWalkNamespace (Type, ACPI_ROOT_OBJECT, ACPI_UINT32_MAX, AcpiDbWalkForSpecificObjects, (void *) &Type, NULL); AcpiDbSetOutputDestination (ACPI_DB_CONSOLE_OUTPUT); @@ -889,7 +906,7 @@ /* Wildcard support */ if ((RequestedName[i] != '?') && - (RequestedName[i] != ((NATIVE_CHAR *) (&((ACPI_NAMESPACE_NODE *) ObjHandle)->Name))[i])) + (RequestedName[i] != ((ACPI_NAMESPACE_NODE *) ObjHandle)->Name.Ascii[i])) { /* No match, just exit */ @@ -943,7 +960,7 @@ /* Walk the namespace from the root */ - AcpiWalkNamespace (ACPI_TYPE_ANY, ACPI_ROOT_OBJECT, ACPI_UINT32_MAX, + (void) AcpiWalkNamespace (ACPI_TYPE_ANY, ACPI_ROOT_OBJECT, ACPI_UINT32_MAX, AcpiDbWalkAndMatchName, NameArg, NULL); AcpiDbSetOutputDestination (ACPI_DB_CONSOLE_OUTPUT); @@ -1035,7 +1052,8 @@ AcpiDbDisplayResources ( NATIVE_CHAR *ObjectArg) { -#ifndef _IA16 +#if ACPI_MACHINE_WIDTH != 16 + ACPI_OPERAND_OBJECT *ObjDesc; ACPI_STATUS Status; ACPI_BUFFER ReturnObj; @@ -1106,7 +1124,7 @@ else { - AcpiRsDumpResourceList ((ACPI_RESOURCE *) AcpiGbl_DbBuffer); + AcpiRsDumpResourceList (ACPI_CAST_PTR (ACPI_RESOURCE, AcpiGbl_DbBuffer)); } Status = AcpiSetCurrentResources (ObjDesc, &ReturnObj); @@ -1143,7 +1161,7 @@ else { - AcpiRsDumpResourceList ((ACPI_RESOURCE *) AcpiGbl_DbBuffer); + AcpiRsDumpResourceList (ACPI_CAST_PTR (ACPI_RESOURCE, AcpiGbl_DbBuffer)); } @@ -1155,5 +1173,97 @@ } + + + +typedef struct +{ + UINT32 Nodes; + UINT32 Objects; +} ACPI_INTEGRITY_INFO; + +/******************************************************************************* + * + * FUNCTION: AcpiDbIntegrityWalk + * + * PARAMETERS: Callback from WalkNamespace + * + * RETURN: Status + * + * DESCRIPTION: Examine one NS node for valid values. + * + ******************************************************************************/ + +ACPI_STATUS +AcpiDbIntegrityWalk ( + ACPI_HANDLE ObjHandle, + UINT32 NestingLevel, + void *Context, + void **ReturnValue) +{ + ACPI_INTEGRITY_INFO *Info = (ACPI_INTEGRITY_INFO *) Context; + ACPI_NAMESPACE_NODE *Node = (ACPI_NAMESPACE_NODE *) ObjHandle; + ACPI_OPERAND_OBJECT *Object; + + + Info->Nodes++; + if (ACPI_GET_DESCRIPTOR_TYPE (Node) != ACPI_DESC_TYPE_NAMED) + { + AcpiOsPrintf ("Invalid Descriptor Type for Node %p, Type = %X\n", + Node, ACPI_GET_DESCRIPTOR_TYPE (Node)); + } + + if (Node->Type > INTERNAL_TYPE_MAX) + { + AcpiOsPrintf ("Invalid Object Type for Node %p, Type = %X\n", + Node, Node->Type); + } + + if (!AcpiUtValidAcpiName (Node->Name.Integer)) + { + AcpiOsPrintf ("Invalid AcpiName for Node %p\n", Node); + } + + Object = AcpiNsGetAttachedObject (Node); + if (Object) + { + Info->Objects++; + if (ACPI_GET_DESCRIPTOR_TYPE (Object) != ACPI_DESC_TYPE_OPERAND) + { + AcpiOsPrintf ("Invalid Descriptor Type for Object %p, Type = %X\n", + Object, ACPI_GET_DESCRIPTOR_TYPE (Object)); + } + } + + + return (AE_OK); +} + + +/******************************************************************************* + * + * FUNCTION: AcpiDbCheckIntegrity + * + * PARAMETERS: None + * + * RETURN: None + * + * DESCRIPTION: Check entire namespace for data structure integrity + * + ******************************************************************************/ + +void +AcpiDbCheckIntegrity (void) +{ + ACPI_INTEGRITY_INFO Info = {0,0}; + + /* Search all nodes in namespace */ + + (void) AcpiWalkNamespace (ACPI_TYPE_ANY, ACPI_ROOT_OBJECT, ACPI_UINT32_MAX, + AcpiDbIntegrityWalk, (void *) &Info, NULL); + + AcpiOsPrintf ("Verified %d namespace nodes with %d Objects\n", Info.Nodes, Info.Objects); + +} #endif /* ENABLE_DEBUGGER */ Index: dbdisasm.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dbdisasm.c,v retrieving revision 1.2 diff -u -r1.2 dbdisasm.c --- dbdisasm.c 24 Feb 2002 07:51:46 -0000 1.2 +++ dbdisasm.c 1 Jul 2002 21:39:53 -0000 @@ -131,7 +131,7 @@ #define BLOCK_PAREN 1 #define BLOCK_BRACE 2 #define DB_NO_OP_INFO " [%2.2d] " -#define DB_FULL_OP_INFO "%5.5X #%4.4X [%2.2d] " +#define DB_FULL_OP_INFO "%5.5X #%4.4hX [%2.2d] " @@ -152,7 +152,7 @@ ACPI_PARSE_OBJECT *Op) { - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_METHOD_OP: return (BLOCK_BRACE); @@ -191,9 +191,9 @@ char *Name; - if (Op->Flags & ACPI_PARSEOP_GENERIC) + if (Op->Common.Flags & ACPI_PARSEOP_GENERIC) { - Name = Op->Value.Name; + Name = Op->Common.Value.Name; if (Name[0] == '\\') { AcpiOsPrintf (" (Fully Qualified Pathname)"); @@ -202,7 +202,7 @@ } else { - Name = (char *) &((ACPI_PARSE2_OBJECT *) Op)->Name; + Name = (char *) &Op->Named.Name; } /* Search parent tree up to the root if necessary */ @@ -250,12 +250,12 @@ /* Just get the Node out of the Op object */ - Node = Op->Node; + Node = Op->Common.Node; if (!Node) { /* Node not defined in this scope, look it up */ - Status = AcpiNsLookup (WalkState->ScopeInfo, Op->Value.String, ACPI_TYPE_ANY, + Status = AcpiNsLookup (WalkState->ScopeInfo, Op->Common.Value.String, ACPI_TYPE_ANY, ACPI_IMODE_EXECUTE, ACPI_NS_SEARCH_PARENT, WalkState, &(Node)); if (ACPI_FAILURE (Status)) @@ -271,7 +271,7 @@ /* Save it for next time. */ - Op->Node = Node; + Op->Common.Node = Node; } /* Convert NamedDesc/handle to a full pathname */ @@ -345,12 +345,12 @@ /* Determine the nesting depth of this argument */ - for (depth = Op->Parent; depth; depth = depth->Parent) + for (depth = Op->Common.Parent; depth; depth = depth->Common.Parent) { arg = AcpiPsGetArg (depth, 0); while (arg && arg != Origin) { - arg = arg->Next; + arg = arg->Common.Next; } if (arg) @@ -385,10 +385,10 @@ else if (DepthCount < LastDepth) { - for (j = 0; j < (LastDepth - DepthCount); j++) + for (j = LastDepth; j >= (DepthCount + 1); j--) { - VERBOSE_PRINT ((DB_NO_OP_INFO, LastDepth - j)); - for (i = 0; i < (LastDepth - j - 1); i++) + VERBOSE_PRINT ((DB_NO_OP_INFO, (j - 1))); + for (i = 1; i < j; i++) { AcpiOsPrintf ("%s", AcpiGbl_DbDisasmIndent); } @@ -406,7 +406,8 @@ /* In verbose mode, print the AML offset, opcode and depth count */ - VERBOSE_PRINT ((DB_FULL_OP_INFO, (unsigned) Op->AmlOffset, Op->Opcode, DepthCount)); + VERBOSE_PRINT ((DB_FULL_OP_INFO, (UINT32) Op->Common.AmlOffset, + Op->Common.AmlOpcode, DepthCount)); /* Indent the output according to the depth count */ @@ -422,11 +423,11 @@ /* Resolve a name reference */ - if ((Op->Opcode == AML_INT_NAMEPATH_OP && Op->Value.Name) && - (Op->Parent) && + if ((Op->Common.AmlOpcode == AML_INT_NAMEPATH_OP && Op->Common.Value.Name) && + (Op->Common.Parent) && (AcpiGbl_DbOpt_verbose)) { - AcpiPsDisplayObjectPathname (WalkState, Op); + (void) AcpiPsDisplayObjectPathname (WalkState, Op); } AcpiOsPrintf ("\n"); @@ -561,7 +562,7 @@ /* We are only interested in named objects */ - OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); + OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); if (!(OpInfo->Flags & AML_NSNODE)) { return; @@ -571,7 +572,7 @@ { /* Field creation - check for a fully qualified namepath */ - if (Op->Opcode == AML_CREATE_FIELD_OP) + if (Op->Common.AmlOpcode == AML_CREATE_FIELD_OP) { NamePath = AcpiPsGetArg (Op, 3); } @@ -581,10 +582,10 @@ } if ((NamePath) && - (NamePath->Value.String) && - (NamePath->Value.String[0] == '\\')) + (NamePath->Common.Value.String) && + (NamePath->Common.Value.String[0] == '\\')) { - AcpiDbDisplayNamestring (NamePath->Value.String); + AcpiDbDisplayNamestring (NamePath->Common.Value.String); return; } } @@ -598,19 +599,19 @@ Search = Op; for (; ;) { - if (Search->Parent == Prev) + if (Search->Common.Parent == Prev) { break; } /* Go up one level */ - Search = Search->Parent; + Search = Search->Common.Parent; } if (Prev) { - OpInfo = AcpiPsGetOpcodeInfo (Search->Opcode); + OpInfo = AcpiPsGetOpcodeInfo (Search->Common.AmlOpcode); if (!(OpInfo->Flags & AML_FIELD)) { /* below root scope, append scope name */ @@ -624,7 +625,7 @@ if (OpInfo->Flags & AML_CREATE) { - if (Op->Opcode == AML_CREATE_FIELD_OP) + if (Op->Common.AmlOpcode == AML_CREATE_FIELD_OP) { NamePath = AcpiPsGetArg (Op, 3); } @@ -634,9 +635,9 @@ } if ((NamePath) && - (NamePath->Value.String)) + (NamePath->Common.Value.String)) { - AcpiOsPrintf ("%4.4s", NamePath->Value.String); + AcpiOsPrintf ("%4.4s", NamePath->Common.Value.String); } } else @@ -684,21 +685,22 @@ if (!Op) { AcpiOsPrintf (""); + return; } /* op and arguments */ - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_BYTE_OP: if (AcpiGbl_DbOpt_verbose) { - AcpiOsPrintf ("(UINT8) 0x%2.2X", Op->Value.Integer8); + AcpiOsPrintf ("(UINT8) 0x%2.2hX", Op->Common.Value.Integer8); } else { - AcpiOsPrintf ("0x%2.2X", Op->Value.Integer8); + AcpiOsPrintf ("0x%2.2hX", Op->Common.Value.Integer8); } break; @@ -707,11 +709,11 @@ if (AcpiGbl_DbOpt_verbose) { - AcpiOsPrintf ("(UINT16) 0x%4.4X", Op->Value.Integer16); + AcpiOsPrintf ("(UINT16) 0x%4.4hX", Op->Common.Value.Integer16); } else { - AcpiOsPrintf ("0x%4.4X", Op->Value.Integer16); + AcpiOsPrintf ("0x%4.4hX", Op->Common.Value.Integer16); } break; @@ -720,11 +722,11 @@ if (AcpiGbl_DbOpt_verbose) { - AcpiOsPrintf ("(UINT32) 0x%8.8X", Op->Value.Integer32); + AcpiOsPrintf ("(UINT32) 0x%8.8X", Op->Common.Value.Integer32); } else { - AcpiOsPrintf ("0x%8.8X", Op->Value.Integer32); + AcpiOsPrintf ("0x%8.8X", Op->Common.Value.Integer32); } break; @@ -733,22 +735,22 @@ if (AcpiGbl_DbOpt_verbose) { - AcpiOsPrintf ("(UINT64) 0x%8.8X%8.8X", Op->Value.Integer64.Hi, - Op->Value.Integer64.Lo); + AcpiOsPrintf ("(UINT64) 0x%8.8X%8.8X", Op->Common.Value.Integer64.Hi, + Op->Common.Value.Integer64.Lo); } else { - AcpiOsPrintf ("0x%8.8X%8.8X", Op->Value.Integer64.Hi, - Op->Value.Integer64.Lo); + AcpiOsPrintf ("0x%8.8X%8.8X", Op->Common.Value.Integer64.Hi, + Op->Common.Value.Integer64.Lo); } break; case AML_STRING_OP: - if (Op->Value.String) + if (Op->Common.Value.String) { - AcpiOsPrintf ("\"%s\"", Op->Value.String); + AcpiOsPrintf ("\"%s\"", Op->Common.Value.String); } else { @@ -759,9 +761,9 @@ case AML_INT_STATICSTRING_OP: - if (Op->Value.String) + if (Op->Common.Value.String) { - AcpiOsPrintf ("\"%s\"", Op->Value.String); + AcpiOsPrintf ("\"%s\"", Op->Common.Value.String); } else { @@ -772,25 +774,25 @@ case AML_INT_NAMEPATH_OP: - AcpiDbDisplayNamestring (Op->Value.Name); + AcpiDbDisplayNamestring (Op->Common.Value.Name); break; case AML_INT_NAMEDFIELD_OP: - AcpiOsPrintf ("NamedField (Length 0x%8.8X) ", Op->Value.Integer32); + AcpiOsPrintf ("NamedField (Length 0x%8.8X) ", Op->Common.Value.Integer32); break; case AML_INT_RESERVEDFIELD_OP: - AcpiOsPrintf ("ReservedField (Length 0x%8.8X) ", Op->Value.Integer32); + AcpiOsPrintf ("ReservedField (Length 0x%8.8X) ", Op->Common.Value.Integer32); break; case AML_INT_ACCESSFIELD_OP: - AcpiOsPrintf ("AccessField (Length 0x%8.8X) ", Op->Value.Integer32); + AcpiOsPrintf ("AccessField (Length 0x%8.8X) ", Op->Common.Value.Integer32); break; @@ -798,14 +800,14 @@ if (AcpiGbl_DbOpt_verbose) { - AcpiOsPrintf ("ByteList (Length 0x%8.8X) ", Op->Value.Integer32); + AcpiOsPrintf ("ByteList (Length 0x%8.8X) ", Op->Common.Value.Integer32); } else { - AcpiOsPrintf ("0x%2.2X", Op->Value.Integer32); + AcpiOsPrintf ("0x%2.2X", Op->Common.Value.Integer32); - ByteCount = Op->Value.Integer32; - ByteData = ((ACPI_PARSE2_OBJECT *) Op)->Data; + ByteCount = Op->Common.Value.Integer32; + ByteData = Op->Named.Data; for (i = 0; i < ByteCount; i++) { @@ -819,12 +821,13 @@ /* Just get the opcode name and print it */ - OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); + OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); AcpiOsPrintf ("%s", OpInfo->Name); #ifndef PARSER_ONLY - if ((Op->Opcode == AML_INT_RETURN_VALUE_OP) && + if ((Op->Common.AmlOpcode == AML_INT_RETURN_VALUE_OP) && + (WalkState) && (WalkState->Results) && (WalkState->Results->Results.NumResults)) { @@ -838,7 +841,7 @@ { /* If there is another element in the list, add a comma */ - if (Op->Next) + if (Op->Common.Next) { AcpiOsPrintf (","); } @@ -847,15 +850,15 @@ /* * If this is a named opcode, print the associated name value */ - OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); + OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); if (Op && (OpInfo->Flags & AML_NAMED)) { Name = AcpiPsGetName (Op); AcpiOsPrintf (" %4.4s", &Name); - if ((AcpiGbl_DbOpt_verbose) && (Op->Opcode != AML_INT_NAMEDFIELD_OP)) + if ((AcpiGbl_DbOpt_verbose) && (Op->Common.AmlOpcode != AML_INT_NAMEDFIELD_OP)) { - AcpiPsDisplayObjectPathname (WalkState, Op); + (void) AcpiPsDisplayObjectPathname (WalkState, Op); } } } Index: dbdisply.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dbdisply.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 dbdisply.c --- dbdisply.c 30 Jun 2002 17:50:43 -0000 1.1.1.14 +++ dbdisply.c 1 Jul 2002 21:39:53 -0000 @@ -116,12 +116,10 @@ #include "acpi.h" -#include "acparser.h" #include "amlcode.h" #include "acdispat.h" #include "acnamesp.h" #include "acparser.h" -#include "acevents.h" #include "acinterp.h" #include "acdebug.h" @@ -152,7 +150,7 @@ void *ObjPtr; -#ifdef _IA16 +#if ACPI_MACHINE_WIDTH == 16 #include /* Have to handle 16-bit pointers of the form segment:offset */ @@ -193,16 +191,16 @@ const ACPI_OPCODE_INFO *Info; - Info = AcpiPsGetOpcodeInfo (Op->Opcode); + Info = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); AcpiOsPrintf ("Parser Op Descriptor:\n"); - AcpiOsPrintf ("%20.20s : %4.4X\n", "Opcode", Op->Opcode); + AcpiOsPrintf ("%20.20s : %4.4X\n", "Opcode", Op->Common.AmlOpcode); ACPI_DEBUG_ONLY_MEMBERS (AcpiOsPrintf ("%20.20s : %s\n", "Opcode Name", Info->Name)); - AcpiOsPrintf ("%20.20s : %p\n", "Value/ArgList", Op->Value); - AcpiOsPrintf ("%20.20s : %p\n", "Parent", Op->Parent); - AcpiOsPrintf ("%20.20s : %p\n", "NextOp", Op->Next); + AcpiOsPrintf ("%20.20s : %p\n", "Value/ArgList", Op->Common.Value.Arg); + AcpiOsPrintf ("%20.20s : %p\n", "Parent", Op->Common.Parent); + AcpiOsPrintf ("%20.20s : %p\n", "NextOp", Op->Common.Next); } @@ -291,7 +289,7 @@ goto DumpNte; - case ACPI_DESC_TYPE_INTERNAL: + case ACPI_DESC_TYPE_OPERAND: /* This is a ACPI OPERAND OBJECT */ @@ -413,14 +411,14 @@ return; } - AcpiOsPrintf (" %s", AcpiUtGetTypeName (ObjDesc->Common.Type)); + AcpiOsPrintf (" %s", AcpiUtGetObjectTypeName (ObjDesc)); - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_INTEGER: - AcpiOsPrintf (" %.8X%.8X", ACPI_HIDWORD (ObjDesc->Integer.Value), - ACPI_LODWORD (ObjDesc->Integer.Value)); + AcpiOsPrintf (" %8.8X%8.8X", ACPI_HIDWORD (ObjDesc->Integer.Value), + ACPI_LODWORD (ObjDesc->Integer.Value)); break; @@ -448,6 +446,11 @@ AcpiOsPrintf (" %2.2X", ObjDesc->Buffer.Pointer[i]); } break; + + + default: + /* No additional display for other types */ + break; } } @@ -494,7 +497,7 @@ case ACPI_DESC_TYPE_NAMED: AcpiOsPrintf (" Name %4.4s Type-%s", - &((ACPI_NAMESPACE_NODE *)ObjDesc)->Name, + ((ACPI_NAMESPACE_NODE *)ObjDesc)->Name.Ascii, AcpiUtGetTypeName (((ACPI_NAMESPACE_NODE *) ObjDesc)->Type)); if (((ACPI_NAMESPACE_NODE *) ObjDesc)->Flags & ANOBJ_METHOD_ARG) @@ -508,38 +511,22 @@ break; - case ACPI_DESC_TYPE_INTERNAL: + case ACPI_DESC_TYPE_OPERAND: - Type = ObjDesc->Common.Type; + Type = ACPI_GET_OBJECT_TYPE (ObjDesc); if (Type > INTERNAL_TYPE_MAX) { - AcpiOsPrintf (" Type %x [Invalid Type]", Type); + AcpiOsPrintf (" Type %hX [Invalid Type]", Type); return; } /* Decode the ACPI object type */ - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case INTERNAL_TYPE_REFERENCE: switch (ObjDesc->Reference.Opcode) { - case AML_ZERO_OP: - AcpiOsPrintf ("[Const] Zero (0) [Null Target]", 0); - break; - - case AML_ONES_OP: - AcpiOsPrintf ("[Const] Ones (0xFFFFFFFFFFFFFFFF) [No Limit]"); - break; - - case AML_ONE_OP: - AcpiOsPrintf ("[Const] One (1)"); - break; - - case AML_REVISION_OP: - AcpiOsPrintf ("[Const] Revision (%X)", ACPI_CA_SUPPORT_LEVEL); - break; - case AML_LOCAL_OP: AcpiOsPrintf ("[Local%d] ", ObjDesc->Reference.Offset); if (WalkState) @@ -570,6 +557,8 @@ break; default: + AcpiOsPrintf ("Unknown Reference opcode %X\n", + ObjDesc->Reference.Opcode); break; } @@ -640,14 +629,14 @@ NumArgs = ObjDesc->Method.ParamCount; Concurrency = ObjDesc->Method.Concurrency; - AcpiOsPrintf ("Currently executing control method is [%4.4s]\n", &Node->Name); + AcpiOsPrintf ("Currently executing control method is [%4.4s]\n", Node->Name.Ascii); AcpiOsPrintf ("%X arguments, max concurrency = %X\n", NumArgs, Concurrency); RootOp = StartOp; - while (RootOp->Parent) + while (RootOp->Common.Parent) { - RootOp = RootOp->Parent; + RootOp = RootOp->Common.Parent; } Op = RootOp; @@ -667,7 +656,7 @@ /* Decode the opcode */ - OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); + OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); switch (OpInfo->Class) { case AML_CLASS_ARGUMENT: @@ -735,7 +724,7 @@ ObjDesc = WalkState->MethodDesc; Node = WalkState->MethodNode; - AcpiOsPrintf ("Local Variables for method [%4.4s]:\n", &Node->Name); + AcpiOsPrintf ("Local Variables for method [%4.4s]:\n", Node->Name.Ascii); for (i = 0; i < MTH_NUM_LOCALS; i++) { @@ -783,7 +772,7 @@ Concurrency = ObjDesc->Method.Concurrency; AcpiOsPrintf ("Method [%4.4s] has %X arguments, max concurrency = %X\n", - &Node->Name, NumArgs, Concurrency); + Node->Name.Ascii, NumArgs, Concurrency); for (i = 0; i < NumArgs; i++) { @@ -832,7 +821,7 @@ } AcpiOsPrintf ("Method [%4.4s] has %X stacked result objects\n", - &Node->Name, NumResults); + Node->Name.Ascii, NumResults); for (i = 0; i < NumResults; i++) { @@ -858,7 +847,6 @@ void AcpiDbDisplayCallingTree (void) { - UINT32 i; ACPI_WALK_STATE *WalkState; ACPI_NAMESPACE_NODE *Node; @@ -873,11 +861,11 @@ Node = WalkState->MethodNode; AcpiOsPrintf ("Current Control Method Call Tree\n"); - for (i = 0; WalkState; i++) + while (WalkState) { Node = WalkState->MethodNode; - AcpiOsPrintf (" [%4.4s]\n", &Node->Name); + AcpiOsPrintf (" [%4.4s]\n", Node->Name.Ascii); WalkState = WalkState->Next; } Index: dbexec.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dbexec.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 dbexec.c --- dbexec.c 16 Mar 2002 02:18:04 -0000 1.1.1.12 +++ dbexec.c 1 Jul 2002 21:39:53 -0000 @@ -116,15 +116,7 @@ #include "acpi.h" -#include "acparser.h" -#include "acdispat.h" -#include "amlcode.h" -#include "acnamesp.h" -#include "acparser.h" -#include "acevents.h" -#include "acinterp.h" #include "acdebug.h" -#include "actables.h" #ifdef ENABLE_DEBUGGER @@ -132,7 +124,7 @@ ACPI_MODULE_NAME ("dbexec") -ACPI_DB_METHOD_INFO AcpiGbl_DbMethodInfo; +static ACPI_DB_METHOD_INFO AcpiGbl_DbMethodInfo; /******************************************************************************* @@ -222,7 +214,7 @@ void AcpiDbExecuteSetup ( - ACPI_DB_METHOD_INFO *Info) + ACPI_DB_METHOD_INFO *Info) { /* Catenate the current scope to the supplied name */ @@ -270,7 +262,8 @@ ******************************************************************************/ UINT32 -AcpiDbGetOutstandingAllocations (void) +AcpiDbGetOutstandingAllocations ( + void) { UINT32 Outstanding = 0; @@ -415,7 +408,11 @@ /* Signal our completion */ - AcpiOsSignalSemaphore (Info->ThreadGate, 1); + Status = AcpiOsSignalSemaphore (Info->ThreadGate, 1); + if (ACPI_FAILURE (Status)) + { + AcpiOsPrintf ("Could not signal debugger semaphore\n"); + } } @@ -482,7 +479,11 @@ for (i = 0; i < (NumThreads); i++) { - AcpiOsQueueForExecution (OSD_PRIORITY_MED, AcpiDbMethodThread, &AcpiGbl_DbMethodInfo); + Status = AcpiOsQueueForExecution (OSD_PRIORITY_MED, AcpiDbMethodThread, &AcpiGbl_DbMethodInfo); + if (ACPI_FAILURE (Status)) + { + break; + } } /* Wait for all threads to complete */ @@ -496,7 +497,7 @@ /* Cleanup and exit */ - AcpiOsDeleteSemaphore (ThreadGate); + (void) AcpiOsDeleteSemaphore (ThreadGate); AcpiDbSetOutputDestination (ACPI_DB_DUPLICATE_OUTPUT); AcpiOsPrintf ("All threads (%X) have completed\n", NumThreads); Index: dbfileio.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dbfileio.c,v retrieving revision 1.3 diff -u -r1.3 dbfileio.c --- dbfileio.c 30 Jun 2002 17:53:04 -0000 1.3 +++ dbfileio.c 1 Jul 2002 21:39:53 -0000 @@ -119,8 +119,6 @@ #include "acpi.h" #include "acdebug.h" #include "acnamesp.h" -#include "acparser.h" -#include "acevents.h" #include "actables.h" #ifdef ENABLE_DEBUGGER @@ -139,6 +137,8 @@ #endif +ACPI_TABLE_HEADER *AcpiGbl_DbTablePtr = NULL; + /******************************************************************************* * @@ -262,7 +262,7 @@ * ******************************************************************************/ -ACPI_STATUS +static ACPI_STATUS AcpiDbLoadTable( FILE *fp, ACPI_TABLE_HEADER **TablePtr, @@ -387,7 +387,7 @@ TableInfo.Pointer = TablePtr; - Status = AcpiTbInstallTable (NULL, &TableInfo); + Status = AcpiTbInstallTable (&TableInfo); if (ACPI_FAILURE (Status)) { /* Free table allocated by AcpiTbGetTable */ @@ -481,7 +481,7 @@ if (Status == AE_ALREADY_EXISTS) { AcpiOsPrintf ("Table %4.4s is already installed\n", - &AcpiGbl_DbTablePtr->Signature); + AcpiGbl_DbTablePtr->Signature); } else { @@ -493,7 +493,7 @@ } AcpiOsPrintf ("%4.4s at %p successfully installed and loaded\n", - &AcpiGbl_DbTablePtr->Signature, AcpiGbl_DbTablePtr); + AcpiGbl_DbTablePtr->Signature, AcpiGbl_DbTablePtr); AcpiGbl_AcpiHardwarePresent = FALSE; Index: dbhistry.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dbhistry.c,v retrieving revision 1.1.1.6 diff -u -r1.1.1.6 dbhistry.c --- dbhistry.c 23 Feb 2002 05:10:35 -0000 1.1.1.6 +++ dbhistry.c 1 Jul 2002 21:39:53 -0000 @@ -116,15 +116,7 @@ #include "acpi.h" -#include "acparser.h" -#include "acdispat.h" -#include "amlcode.h" -#include "acnamesp.h" -#include "acparser.h" -#include "acevents.h" -#include "acinterp.h" #include "acdebug.h" -#include "actables.h" #ifdef ENABLE_DEBUGGER @@ -145,11 +137,11 @@ } HISTORY_INFO; -HISTORY_INFO AcpiGbl_HistoryBuffer[HISTORY_SIZE]; -UINT16 AcpiGbl_LoHistory = 0; -UINT16 AcpiGbl_NumHistory = 0; -UINT16 AcpiGbl_NextHistoryIndex = 0; -UINT32 AcpiGbl_NextCmdNum = 1; +static HISTORY_INFO AcpiGbl_HistoryBuffer[HISTORY_SIZE]; +static UINT16 AcpiGbl_LoHistory = 0; +static UINT16 AcpiGbl_NumHistory = 0; +static UINT16 AcpiGbl_NextHistoryIndex = 0; +static UINT32 AcpiGbl_NextCmdNum = 1; /******************************************************************************* Index: dbinput.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dbinput.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 dbinput.c --- dbinput.c 16 Mar 2002 02:18:04 -0000 1.1.1.12 +++ dbinput.c 1 Jul 2002 21:39:53 -0000 @@ -116,10 +116,6 @@ #include "acpi.h" -#include "acparser.h" -#include "actables.h" -#include "acnamesp.h" -#include "acinterp.h" #include "acdebug.h" @@ -158,6 +154,7 @@ CMD_HISTORY_EXE, CMD_HISTORY_LAST, CMD_INFORMATION, + CMD_INTEGRITY, CMD_INTO, CMD_LEVEL, CMD_LIST, @@ -188,7 +185,7 @@ #define CMD_FIRST_VALID 2 -const COMMAND_INFO AcpiGbl_DbCommands[] = +static const COMMAND_INFO AcpiGbl_DbCommands[] = { {"", 0}, {"", 0}, @@ -212,6 +209,7 @@ {"!", 1}, {"!!", 0}, {"INFORMATION", 0}, + {"INTEGRITY", 0}, {"INTO", 0}, {"LEVEL", 0}, {"LIST", 0}, @@ -343,7 +341,7 @@ return; default: - AcpiOsPrintf ("Unrecognized Command Class: %x\n", HelpType); + AcpiOsPrintf ("Unrecognized Command Class: %X\n", HelpType); return; } } @@ -618,7 +616,7 @@ break; case CMD_FIND: - AcpiDbFindNameInNamespace (AcpiGbl_DbArgs[1]); + Status = AcpiDbFindNameInNamespace (AcpiGbl_DbArgs[1]); break; case CMD_GO: @@ -666,6 +664,10 @@ AcpiDbDisplayMethodInfo (Op); break; + case CMD_INTEGRITY: + AcpiDbCheckIntegrity (); + break; + case CMD_INTO: if (Op) { @@ -715,7 +717,7 @@ break; case CMD_METHODS: - AcpiDbDisplayObjects ("METHOD", AcpiGbl_DbArgs[1]); + Status = AcpiDbDisplayObjects ("METHOD", AcpiGbl_DbArgs[1]); break; case CMD_NAMESPACE: @@ -728,7 +730,8 @@ break; case CMD_OBJECT: - AcpiDbDisplayObjects (ACPI_STRUPR (AcpiGbl_DbArgs[1]), AcpiGbl_DbArgs[2]); + ACPI_STRUPR (AcpiGbl_DbArgs[1]); + Status = AcpiDbDisplayObjects (AcpiGbl_DbArgs[1], AcpiGbl_DbArgs[2]); break; case CMD_OPEN: @@ -760,11 +763,11 @@ break; case CMD_STATS: - AcpiDbDisplayStatistics (AcpiGbl_DbArgs[1]); + Status = AcpiDbDisplayStatistics (AcpiGbl_DbArgs[1]); break; case CMD_STOP: - return (AE_AML_ERROR); + return (AE_NOT_IMPLEMENTED); case CMD_TABLES: AcpiDbDisplayTableInfo (AcpiGbl_DbArgs[1]); @@ -814,6 +817,7 @@ return (AE_CTRL_TERMINATE); case CMD_NOT_FOUND: + default: AcpiOsPrintf ("Unknown Command\n"); return (AE_CTRL_TRUE); } @@ -886,13 +890,11 @@ AcpiDbSingleThread ( void) { - ACPI_STATUS Status; - AcpiGbl_MethodExecuting = FALSE; AcpiGbl_StepToNextCall = FALSE; - Status = AcpiDbCommandDispatch (AcpiGbl_DbLineBuf, NULL, NULL); + (void) AcpiDbCommandDispatch (AcpiGbl_DbLineBuf, NULL, NULL); } @@ -939,8 +941,7 @@ /* Get the user input line */ - AcpiOsGetLine (AcpiGbl_DbLineBuf); - + (void) AcpiOsGetLine (AcpiGbl_DbLineBuf); /* Check for single or multithreaded debug */ @@ -974,7 +975,7 @@ * Only this thread (the original thread) should actually terminate the subsystem, * because all the semaphores are deleted during termination */ - AcpiTerminate (); + Status = AcpiTerminate (); return (Status); } Index: dbstats.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dbstats.c,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 dbstats.c --- dbstats.c 23 Feb 2002 05:10:35 -0000 1.1.1.10 +++ dbstats.c 1 Jul 2002 21:39:53 -0000 @@ -117,8 +117,6 @@ #include #include -#include -#include #include #ifdef ENABLE_DEBUGGER @@ -129,7 +127,7 @@ /* * Statistics subcommands */ -ARGUMENT_INFO AcpiDbStatTypes [] = +static ARGUMENT_INFO AcpiDbStatTypes [] = { {"ALLOCATIONS"}, {"OBJECTS"}, @@ -141,13 +139,13 @@ {NULL} /* Must be null terminated */ }; -#define CMD_ALLOCATIONS 0 -#define CMD_OBJECTS 1 -#define CMD_MEMORY 2 -#define CMD_MISC 3 -#define CMD_TABLES 4 -#define CMD_SIZES 5 -#define CMD_STACK 6 +#define CMD_STAT_ALLOCATIONS 0 +#define CMD_STAT_OBJECTS 1 +#define CMD_STAT_MEMORY 2 +#define CMD_STAT_MISC 3 +#define CMD_STAT_TABLES 4 +#define CMD_STAT_SIZES 5 +#define CMD_STAT_STACK 6 /******************************************************************************* @@ -181,18 +179,18 @@ AcpiGbl_NumObjects++; - if (ObjDesc->Common.Type > INTERNAL_TYPE_NODE_MAX) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) > INTERNAL_TYPE_NODE_MAX) { AcpiGbl_ObjTypeCountMisc++; } else { - AcpiGbl_ObjTypeCount [ObjDesc->Common.Type]++; + AcpiGbl_ObjTypeCount [ACPI_GET_OBJECT_TYPE (ObjDesc)]++; } /* Count the sub-objects */ - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_PACKAGE: for (i = 0; i < ObjDesc->Package.Count; i++) @@ -235,6 +233,9 @@ AcpiDbEnumerateObject (ObjDesc->ThermalZone.DrvHandler); AcpiDbEnumerateObject (ObjDesc->ThermalZone.AddrHandler); break; + + default: + break; } } @@ -324,7 +325,7 @@ * ******************************************************************************/ -ACPI_STATUS +void AcpiDbCountNamespaceObjects ( void) { @@ -341,10 +342,8 @@ AcpiGbl_NodeTypeCount [i] = 0; } - AcpiNsWalkNamespace (ACPI_TYPE_ANY, ACPI_ROOT_OBJECT, ACPI_UINT32_MAX, + (void) AcpiNsWalkNamespace (ACPI_TYPE_ANY, ACPI_ROOT_OBJECT, ACPI_UINT32_MAX, FALSE, AcpiDbClassifyOneObject, NULL, NULL); - - return (AE_OK); } #endif @@ -397,14 +396,14 @@ switch (Type) { #ifndef PARSER_ONLY - case CMD_ALLOCATIONS: + case CMD_STAT_ALLOCATIONS: #ifdef ACPI_DBG_TRACK_ALLOCATIONS AcpiUtDumpAllocationInfo (); #endif break; #endif - case CMD_TABLES: + case CMD_STAT_TABLES: AcpiOsPrintf ("ACPI Table Information:\n\n"); if (AcpiGbl_DSDT) @@ -413,7 +412,7 @@ } break; - case CMD_OBJECTS: + case CMD_STAT_OBJECTS: #ifndef PARSER_ONLY @@ -437,7 +436,7 @@ #endif break; - case CMD_MEMORY: + case CMD_STAT_MEMORY: #ifdef ACPI_DBG_TRACK_ALLOCATIONS AcpiOsPrintf ("\n----Object and Cache Statistics---------------------------------------------\n"); @@ -483,7 +482,7 @@ break; - case CMD_MISC: + case CMD_STAT_MISC: AcpiOsPrintf ("\nMiscellaneous Statistics:\n\n"); AcpiOsPrintf ("Calls to AcpiPsFind:.. ........% 7ld\n", AcpiGbl_PsFindCount); @@ -499,7 +498,7 @@ break; - case CMD_SIZES: + case CMD_STAT_SIZES: AcpiOsPrintf ("\nInternal object sizes:\n\n"); @@ -528,23 +527,29 @@ AcpiOsPrintf ("\n"); - AcpiOsPrintf ("ParseObject %3d\n", sizeof (ACPI_PARSE_OBJECT)); - AcpiOsPrintf ("Parse2Object %3d\n", sizeof (ACPI_PARSE2_OBJECT)); + AcpiOsPrintf ("ParseObject %3d\n", sizeof (ACPI_PARSE_OBJ_COMMON)); + AcpiOsPrintf ("ParseObjectNamed %3d\n", sizeof (ACPI_PARSE_OBJ_NAMED)); + AcpiOsPrintf ("ParseObjectAsl %3d\n", sizeof (ACPI_PARSE_OBJ_ASL)); AcpiOsPrintf ("OperandObject %3d\n", sizeof (ACPI_OPERAND_OBJECT)); AcpiOsPrintf ("NamespaceNode %3d\n", sizeof (ACPI_NAMESPACE_NODE)); break; - case CMD_STACK: + case CMD_STAT_STACK: +#if defined(ACPI_DEBUG) - Size = AcpiGbl_EntryStackPointer - AcpiGbl_LowestStackPointer; + Size = (UINT32) (AcpiGbl_EntryStackPointer - AcpiGbl_LowestStackPointer); AcpiOsPrintf ("\nSubsystem Stack Usage:\n\n"); AcpiOsPrintf ("Entry Stack Pointer %X\n", AcpiGbl_EntryStackPointer); AcpiOsPrintf ("Lowest Stack Pointer %X\n", AcpiGbl_LowestStackPointer); AcpiOsPrintf ("Stack Use %X (%d)\n", Size, Size); AcpiOsPrintf ("Deepest Procedure Nesting %d\n", AcpiGbl_DeepestNesting); +#endif + break; + + default: break; } Index: dbutils.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dbutils.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 dbutils.c --- dbutils.c 30 Jun 2002 17:50:43 -0000 1.1.1.12 +++ dbutils.c 1 Jul 2002 21:39:53 -0000 @@ -119,9 +119,6 @@ #include "acparser.h" #include "amlcode.h" #include "acnamesp.h" -#include "acparser.h" -#include "acevents.h" -#include "acinterp.h" #include "acdebug.h" #include "acdispat.h" @@ -362,7 +359,7 @@ ACPI_PARSE_OBJECT *Root) { ACPI_PARSE_OBJECT *Op = Root; - ACPI_PARSE2_OBJECT *Method; + ACPI_PARSE_OBJECT *Method; ACPI_PARSE_OBJECT *SearchOp; ACPI_PARSE_OBJECT *StartOp; ACPI_STATUS Status = AE_OK; @@ -375,12 +372,13 @@ AcpiOsPrintf ("Pass two parse ....\n"); - while (Op) { - if (Op->Opcode == AML_METHOD_OP) + if (Op->Common.AmlOpcode == AML_METHOD_OP) { - Method = (ACPI_PARSE2_OBJECT *) Op; + Method = Op; + + /* Create a new walk state for the parse */ WalkState = AcpiDsCreateWalkState (TABLE_ID_DSDT, NULL, NULL, NULL); @@ -389,33 +387,33 @@ return (AE_NO_MEMORY); } + /* Init the Walk State */ WalkState->ParserState.Aml = - WalkState->ParserState.AmlStart = Method->Data; + WalkState->ParserState.AmlStart = Method->Named.Data; WalkState->ParserState.AmlEnd = - WalkState->ParserState.PkgEnd = Method->Data + Method->Length; + WalkState->ParserState.PkgEnd = Method->Named.Data + Method->Named.Length; WalkState->ParserState.StartScope = Op; WalkState->DescendingCallback = AcpiDsLoad1BeginOp; WalkState->AscendingCallback = AcpiDsLoad1EndOp; + /* Perform the AML parse */ Status = AcpiPsParseAml (WalkState); - - BaseAmlOffset = (Method->Value.Arg)->AmlOffset + 1; - StartOp = (Method->Value.Arg)->Next; + BaseAmlOffset = (Method->Common.Value.Arg)->Common.AmlOffset + 1; + StartOp = (Method->Common.Value.Arg)->Common.Next; SearchOp = StartOp; while (SearchOp) { - SearchOp->AmlOffset += BaseAmlOffset; + SearchOp->Common.AmlOffset += BaseAmlOffset; SearchOp = AcpiPsGetDepthNext (StartOp, SearchOp); } - } - if (Op->Opcode == AML_REGION_OP) + if (Op->Common.AmlOpcode == AML_REGION_OP) { /* TBD: [Investigate] this isn't quite the right thing to do! */ /* Index: dbxface.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dbxface.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 dbxface.c --- dbxface.c 23 Feb 2002 05:10:35 -0000 1.1.1.11 +++ dbxface.c 1 Jul 2002 21:39:53 -0000 @@ -116,12 +116,7 @@ #include "acpi.h" -#include "acparser.h" #include "amlcode.h" -#include "acnamesp.h" -#include "acparser.h" -#include "acevents.h" -#include "acinterp.h" #include "acdebug.h" @@ -162,12 +157,13 @@ /* Check for single-step breakpoint */ - if (WalkState->MethodBreakpoint && (WalkState->MethodBreakpoint <= Op->AmlOffset)) + if (WalkState->MethodBreakpoint && + (WalkState->MethodBreakpoint <= Op->Common.AmlOffset)) { /* Check if the breakpoint has been reached or passed */ /* Hit the breakpoint, resume single step, reset breakpoint */ - AcpiOsPrintf ("***Break*** at AML offset %X\n", Op->AmlOffset); + AcpiOsPrintf ("***Break*** at AML offset %X\n", Op->Common.AmlOffset); AcpiGbl_CmSingleStep = TRUE; AcpiGbl_StepToNextCall = FALSE; WalkState->MethodBreakpoint = 0; @@ -175,9 +171,10 @@ /* Check for user breakpoint (Must be on exact Aml offset) */ - else if (WalkState->UserBreakpoint && (WalkState->UserBreakpoint == Op->AmlOffset)) + else if (WalkState->UserBreakpoint && + (WalkState->UserBreakpoint == Op->Common.AmlOffset)) { - AcpiOsPrintf ("***UserBreakpoint*** at AML offset %X\n", Op->AmlOffset); + AcpiOsPrintf ("***UserBreakpoint*** at AML offset %X\n", Op->Common.AmlOffset); AcpiGbl_CmSingleStep = TRUE; AcpiGbl_StepToNextCall = FALSE; WalkState->MethodBreakpoint = 0; @@ -188,7 +185,7 @@ * Check if this is an opcode that we are interested in -- * namely, opcodes that have arguments */ - if (Op->Opcode == AML_INT_NAMEDFIELD_OP) + if (Op->Common.AmlOpcode == AML_INT_NAMEDFIELD_OP) { return (AE_OK); } @@ -198,6 +195,10 @@ case AML_CLASS_UNKNOWN: case AML_CLASS_ARGUMENT: /* constants, literals, etc. do nothing */ return (AE_OK); + + default: + /* All other opcodes -- continue */ + break; } /* @@ -220,12 +221,12 @@ */ OriginalDebugLevel = AcpiDbgLevel; AcpiDbgLevel &= ~(ACPI_LV_PARSE | ACPI_LV_FUNCTIONS); - Next = Op->Next; - Op->Next = NULL; + Next = Op->Common.Next; + Op->Common.Next = NULL; DisplayOp = Op; - ParentOp = Op->Parent; + ParentOp = Op->Common.Parent; if (ParentOp) { if ((WalkState->ControlState) && @@ -238,29 +239,29 @@ */ while (ParentOp) { - if ((ParentOp->Opcode == AML_IF_OP) || - (ParentOp->Opcode == AML_WHILE_OP)) + if ((ParentOp->Common.AmlOpcode == AML_IF_OP) || + (ParentOp->Common.AmlOpcode == AML_WHILE_OP)) { DisplayOp = ParentOp; break; } - ParentOp = ParentOp->Parent; + ParentOp = ParentOp->Common.Parent; } } else { while (ParentOp) { - if ((ParentOp->Opcode == AML_IF_OP) || - (ParentOp->Opcode == AML_ELSE_OP) || - (ParentOp->Opcode == AML_SCOPE_OP) || - (ParentOp->Opcode == AML_METHOD_OP) || - (ParentOp->Opcode == AML_WHILE_OP)) + if ((ParentOp->Common.AmlOpcode == AML_IF_OP) || + (ParentOp->Common.AmlOpcode == AML_ELSE_OP) || + (ParentOp->Common.AmlOpcode == AML_SCOPE_OP) || + (ParentOp->Common.AmlOpcode == AML_METHOD_OP) || + (ParentOp->Common.AmlOpcode == AML_WHILE_OP)) { break; } DisplayOp = ParentOp; - ParentOp = ParentOp->Parent; + ParentOp = ParentOp->Common.Parent; } } } @@ -269,8 +270,8 @@ AcpiDbDisplayOp (WalkState, DisplayOp, ACPI_UINT32_MAX); - if ((Op->Opcode == AML_IF_OP) || - (Op->Opcode == AML_WHILE_OP)) + if ((Op->Common.AmlOpcode == AML_IF_OP) || + (Op->Common.AmlOpcode == AML_WHILE_OP)) { if (WalkState->ControlState->Common.Value) { @@ -282,14 +283,14 @@ } } - else if (Op->Opcode == AML_ELSE_OP) + else if (Op->Common.AmlOpcode == AML_ELSE_OP) { AcpiOsPrintf ("Predicate = [False], ELSE block was executed\n"); } /* Restore everything */ - Op->Next = Next; + Op->Common.Next = Next; AcpiOsPrintf ("\n"); AcpiDbgLevel = OriginalDebugLevel; } @@ -307,7 +308,7 @@ */ if (AcpiGbl_StepToNextCall) { - if (Op->Opcode != AML_INT_METHODCALL_OP) + if (Op->Common.AmlOpcode != AML_INT_METHODCALL_OP) { /* Not a method call, just keep executing */ @@ -323,7 +324,7 @@ * If the next opcode is a method call, we will "step over" it * by default. */ - if (Op->Opcode == AML_INT_METHODCALL_OP) + if (Op->Common.AmlOpcode == AML_INT_METHODCALL_OP) { AcpiGbl_CmSingleStep = FALSE; /* No more single step while executing called method */ @@ -380,7 +381,7 @@ /* Get the user input line */ - AcpiOsGetLine (AcpiGbl_DbLineBuf); + (void) AcpiOsGetLine (AcpiGbl_DbLineBuf); } Status = AcpiDbCommandDispatch (AcpiGbl_DbLineBuf, WalkState, Op); @@ -406,9 +407,11 @@ * ******************************************************************************/ -int +ACPI_STATUS AcpiDbInitialize (void) { + ACPI_STATUS Status; + /* Init globals */ @@ -429,7 +432,7 @@ AcpiGbl_DbBuffer = AcpiOsAllocate (ACPI_DEBUG_BUFFER_SIZE); if (!AcpiGbl_DbBuffer) { - return 0; + return (AE_NO_MEMORY); } ACPI_MEMSET (AcpiGbl_DbBuffer, 0, ACPI_DEBUG_BUFFER_SIZE); @@ -448,12 +451,27 @@ { /* These were created with one unit, grab it */ - AcpiUtAcquireMutex (ACPI_MTX_DEBUG_CMD_COMPLETE); - AcpiUtAcquireMutex (ACPI_MTX_DEBUG_CMD_READY); + Status = AcpiUtAcquireMutex (ACPI_MTX_DEBUG_CMD_COMPLETE); + if (ACPI_FAILURE (Status)) + { + AcpiOsPrintf ("Could not get debugger mutex\n"); + return (Status); + } + Status = AcpiUtAcquireMutex (ACPI_MTX_DEBUG_CMD_READY); + if (ACPI_FAILURE (Status)) + { + AcpiOsPrintf ("Could not get debugger mutex\n"); + return (Status); + } /* Create the debug execution thread to execute commands */ - AcpiOsQueueForExecution (0, AcpiDbExecuteThread, NULL); + Status = AcpiOsQueueForExecution (0, AcpiDbExecuteThread, NULL); + if (ACPI_FAILURE (Status)) + { + AcpiOsPrintf ("Could not start debugger thread\n"); + return (Status); + } } if (!AcpiGbl_DbOpt_verbose) @@ -463,7 +481,7 @@ AcpiGbl_DbOpt_stats = FALSE; } - return (0); + return (AE_OK); } Index: dsfield.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dsfield.c,v retrieving revision 1.1.1.9 diff -u -r1.1.1.9 dsfield.c --- dsfield.c 23 Feb 2002 05:10:35 -0000 1.1.1.9 +++ dsfield.c 1 Jul 2002 21:39:53 -0000 @@ -166,7 +166,7 @@ /* Get the NameString argument */ - if (Op->Opcode == AML_CREATE_FIELD_OP) + if (Op->Common.AmlOpcode == AML_CREATE_FIELD_OP) { Arg = AcpiPsGetArg (Op, 3); } @@ -199,7 +199,7 @@ /* * Enter the NameString into the namespace */ - Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Value.String, + Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Common.Value.String, INTERNAL_TYPE_DEF_ANY, ACPI_IMODE_LOAD_PASS1, Flags, WalkState, &(Node)); if (ACPI_FAILURE (Status)) @@ -211,7 +211,7 @@ * for now, we will put it in the "op" object that the parser uses, so we * can get it again at the end of this scope */ - Op->Node = Node; + Op->Common.Node = Node; /* * If there is no object attached to the node, this node was just created and @@ -244,8 +244,8 @@ * operands must be evaluated. */ SecondDesc = ObjDesc->Common.NextObject; - SecondDesc->Extra.AmlStart = ((ACPI_PARSE2_OBJECT *) Op)->Data; - SecondDesc->Extra.AmlLength = ((ACPI_PARSE2_OBJECT *) Op)->Length; + SecondDesc->Extra.AmlStart = Op->Named.Data; + SecondDesc->Extra.AmlLength = Op->Named.Length; ObjDesc->BufferField.Node = Node; /* Attach constructed field descriptors to parent node */ @@ -288,6 +288,7 @@ ACPI_PARSE_OBJECT *Arg) { ACPI_STATUS Status; + ACPI_INTEGER Position; ACPI_FUNCTION_TRACE_PTR ("DsGetFieldNames", Info); @@ -307,18 +308,20 @@ * 2) AccessAs - changes the access mode * 3) Name - Enters a new named field into the namespace */ - switch (Arg->Opcode) + switch (Arg->Common.AmlOpcode) { case AML_INT_RESERVEDFIELD_OP: - if (((ACPI_INTEGER) Info->FieldBitPosition + Arg->Value.Size) > - ACPI_UINT32_MAX) + Position = (ACPI_INTEGER) Info->FieldBitPosition + + (ACPI_INTEGER) Arg->Common.Value.Size; + + if (Position > ACPI_UINT32_MAX) { ACPI_REPORT_ERROR (("Bit offset within field too large (> 0xFFFFFFFF)\n")); return_ACPI_STATUS (AE_SUPPORT); } - Info->FieldBitPosition += Arg->Value.Size; + Info->FieldBitPosition = (UINT32) Position; break; @@ -331,9 +334,9 @@ * In FieldFlags, preserve the flag bits other than the ACCESS_TYPE bits */ Info->FieldFlags = (UINT8) ((Info->FieldFlags & ~(AML_FIELD_ACCESS_TYPE_MASK)) | - ((UINT8) (Arg->Value.Integer32 >> 8))); + ((UINT8) (Arg->Common.Value.Integer32 >> 8))); - Info->Attribute = (UINT8) (Arg->Value.Integer32); + Info->Attribute = (UINT8) (Arg->Common.Value.Integer32); break; @@ -342,7 +345,7 @@ /* Lookup the name */ Status = AcpiNsLookup (WalkState->ScopeInfo, - (NATIVE_CHAR *) &((ACPI_PARSE2_OBJECT *)Arg)->Name, + (NATIVE_CHAR *) &Arg->Named.Name, Info->FieldType, ACPI_IMODE_EXECUTE, ACPI_NS_DONT_OPEN_SCOPE, WalkState, &Info->FieldNode); if (ACPI_FAILURE (Status)) @@ -353,12 +356,12 @@ } ACPI_REPORT_ERROR (("Field name [%4.4s] already exists in current scope\n", - &((ACPI_PARSE2_OBJECT *)Arg)->Name)); + &Arg->Named.Name)); } else { - Arg->Node = Info->FieldNode; - Info->FieldBitLength = Arg->Value.Size; + Arg->Common.Node = Info->FieldNode; + Info->FieldBitLength = Arg->Common.Value.Size; /* Create and initialize an object for the new Field Node */ @@ -371,8 +374,10 @@ /* Keep track of bit position for the next field */ - if (((ACPI_INTEGER) Info->FieldBitPosition + Arg->Value.Size) > - ACPI_UINT32_MAX) + Position = (ACPI_INTEGER) Info->FieldBitPosition + + (ACPI_INTEGER) Arg->Common.Value.Size; + + if (Position > ACPI_UINT32_MAX) { ACPI_REPORT_ERROR (("Field [%4.4s] bit offset too large (> 0xFFFFFFFF)\n", &Info->FieldNode->Name)); @@ -386,11 +391,11 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Invalid opcode in field list: %X\n", - Arg->Opcode)); - return_ACPI_STATUS (AE_AML_ERROR); + Arg->Common.AmlOpcode)); + return_ACPI_STATUS (AE_AML_BAD_OPCODE); } - Arg = Arg->Next; + Arg = Arg->Common.Next; } return_ACPI_STATUS (AE_OK); @@ -417,7 +422,7 @@ ACPI_NAMESPACE_NODE *RegionNode, ACPI_WALK_STATE *WalkState) { - ACPI_STATUS Status = AE_AML_ERROR; + ACPI_STATUS Status; ACPI_PARSE_OBJECT *Arg; ACPI_CREATE_FIELD_INFO Info; @@ -427,10 +432,10 @@ /* First arg is the name of the parent OpRegion (must already exist) */ - Arg = Op->Value.Arg; + Arg = Op->Common.Value.Arg; if (!RegionNode) { - Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Value.Name, + Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Common.Value.Name, ACPI_TYPE_REGION, ACPI_IMODE_EXECUTE, ACPI_NS_SEARCH_PARENT, WalkState, &RegionNode); if (ACPI_FAILURE (Status)) @@ -441,8 +446,8 @@ /* Second arg is the field flags */ - Arg = Arg->Next; - Info.FieldFlags = Arg->Value.Integer8; + Arg = Arg->Common.Next; + Info.FieldFlags = Arg->Common.Value.Integer8; Info.Attribute = 0; /* Each remaining arg is a Named Field */ @@ -450,7 +455,7 @@ Info.FieldType = INTERNAL_TYPE_REGION_FIELD; Info.RegionNode = RegionNode; - Status = AcpiDsGetFieldNames (&Info, WalkState, Arg->Next); + Status = AcpiDsGetFieldNames (&Info, WalkState, Arg->Common.Next); return_ACPI_STATUS (Status); } @@ -476,7 +481,7 @@ ACPI_PARSE_OBJECT *Op, ACPI_WALK_STATE *WalkState) { - ACPI_STATUS Status = AE_AML_ERROR; + ACPI_STATUS Status; ACPI_PARSE_OBJECT *Arg = NULL; ACPI_NAMESPACE_NODE *Node; UINT8 Type = 0; @@ -501,6 +506,9 @@ Arg = AcpiPsGetArg (Op, 3); Type = INTERNAL_TYPE_INDEX_FIELD; break; + + default: + return_ACPI_STATUS (AE_BAD_PARAMETER); } /* @@ -510,10 +518,10 @@ { /* Ignore OFFSET and ACCESSAS terms here */ - if (Arg->Opcode == AML_INT_NAMEDFIELD_OP) + if (Arg->Common.AmlOpcode == AML_INT_NAMEDFIELD_OP) { Status = AcpiNsLookup (WalkState->ScopeInfo, - (NATIVE_CHAR *) &((ACPI_PARSE2_OBJECT *)Arg)->Name, + (NATIVE_CHAR *) &Arg->Named.Name, Type, ACPI_IMODE_LOAD_PASS1, ACPI_NS_NO_UPSEARCH | ACPI_NS_DONT_OPEN_SCOPE | ACPI_NS_ERROR_IF_FOUND, WalkState, &Node); @@ -525,18 +533,22 @@ } ACPI_REPORT_ERROR (("Field name [%4.4s] already exists in current scope\n", - &((ACPI_PARSE2_OBJECT *)Arg)->Name)); + &Arg->Named.Name)); + + /* Name already exists, just ignore this error */ + + Status = AE_OK; } - Arg->Node = Node; + Arg->Common.Node = Node; } /* Move to next field in the list */ - Arg = Arg->Next; + Arg = Arg->Common.Next; } - return_ACPI_STATUS (Status); + return_ACPI_STATUS (AE_OK); } @@ -560,7 +572,7 @@ ACPI_NAMESPACE_NODE *RegionNode, ACPI_WALK_STATE *WalkState) { - ACPI_STATUS Status = AE_AML_ERROR; + ACPI_STATUS Status; ACPI_PARSE_OBJECT *Arg; ACPI_CREATE_FIELD_INFO Info; @@ -570,10 +582,10 @@ /* First arg is the name of the parent OpRegion (must already exist) */ - Arg = Op->Value.Arg; + Arg = Op->Common.Value.Arg; if (!RegionNode) { - Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Value.Name, + Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Common.Value.Name, ACPI_TYPE_REGION, ACPI_IMODE_EXECUTE, ACPI_NS_SEARCH_PARENT, WalkState, &RegionNode); if (ACPI_FAILURE (Status)) @@ -584,8 +596,8 @@ /* Second arg is the Bank Register (must already exist) */ - Arg = Arg->Next; - Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Value.String, + Arg = Arg->Common.Next; + Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Common.Value.String, INTERNAL_TYPE_BANK_FIELD_DEFN, ACPI_IMODE_EXECUTE, ACPI_NS_SEARCH_PARENT, WalkState, &Info.RegisterNode); if (ACPI_FAILURE (Status)) @@ -595,20 +607,20 @@ /* Third arg is the BankValue */ - Arg = Arg->Next; - Info.BankValue = Arg->Value.Integer32; + Arg = Arg->Common.Next; + Info.BankValue = Arg->Common.Value.Integer32; /* Fourth arg is the field flags */ - Arg = Arg->Next; - Info.FieldFlags = Arg->Value.Integer8; + Arg = Arg->Common.Next; + Info.FieldFlags = Arg->Common.Value.Integer8; /* Each remaining arg is a Named Field */ Info.FieldType = INTERNAL_TYPE_BANK_FIELD; Info.RegionNode = RegionNode; - Status = AcpiDsGetFieldNames (&Info, WalkState, Arg->Next); + Status = AcpiDsGetFieldNames (&Info, WalkState, Arg->Common.Next); return_ACPI_STATUS (Status); } @@ -644,8 +656,8 @@ /* First arg is the name of the Index register (must already exist) */ - Arg = Op->Value.Arg; - Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Value.String, + Arg = Op->Common.Value.Arg; + Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Common.Value.String, ACPI_TYPE_ANY, ACPI_IMODE_EXECUTE, ACPI_NS_SEARCH_PARENT, WalkState, &Info.RegisterNode); if (ACPI_FAILURE (Status)) @@ -655,8 +667,8 @@ /* Second arg is the data register (must already exist) */ - Arg = Arg->Next; - Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Value.String, + Arg = Arg->Common.Next; + Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Common.Value.String, INTERNAL_TYPE_INDEX_FIELD_DEFN, ACPI_IMODE_EXECUTE, ACPI_NS_SEARCH_PARENT, WalkState, &Info.DataRegisterNode); if (ACPI_FAILURE (Status)) @@ -666,8 +678,8 @@ /* Next arg is the field flags */ - Arg = Arg->Next; - Info.FieldFlags = Arg->Value.Integer8; + Arg = Arg->Common.Next; + Info.FieldFlags = Arg->Common.Value.Integer8; /* Each remaining arg is a Named Field */ @@ -675,7 +687,7 @@ Info.FieldType = INTERNAL_TYPE_INDEX_FIELD; Info.RegionNode = RegionNode; - Status = AcpiDsGetFieldNames (&Info, WalkState, Arg->Next); + Status = AcpiDsGetFieldNames (&Info, WalkState, Arg->Common.Next); return_ACPI_STATUS (Status); } Index: dsmethod.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dsmethod.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 dsmethod.c --- dsmethod.c 30 Jun 2002 17:50:43 -0000 1.1.1.12 +++ dsmethod.c 1 Jul 2002 21:39:53 -0000 @@ -122,8 +122,6 @@ #include "acdispat.h" #include "acinterp.h" #include "acnamesp.h" -#include "actables.h" -#include "acdebug.h" #define _COMPONENT ACPI_DISPATCHER @@ -171,7 +169,7 @@ } ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, "**** Parsing [%4.4s] **** NamedObj=%p\n", - (char *) &((ACPI_NAMESPACE_NODE *) ObjHandle)->Name, ObjHandle)); + ((ACPI_NAMESPACE_NODE *) ObjHandle)->Name.Ascii, ObjHandle)); /* Extract the method object from the method Node */ @@ -209,7 +207,7 @@ /* Init new op with the method name and pointer back to the Node */ AcpiPsSetName (Op, Node->Name.Integer); - Op->Node = Node; + Op->Common.Node = Node; /* * Get a new OwnerId for objects created by this method. Namespace @@ -221,8 +219,7 @@ /* Create and initialize a new walk state */ - WalkState = AcpiDsCreateWalkState (OwnerId, - NULL, NULL, NULL); + WalkState = AcpiDsCreateWalkState (OwnerId, NULL, NULL, NULL); if (!WalkState) { return_ACPI_STATUS (AE_NO_MEMORY); @@ -252,8 +249,9 @@ return_ACPI_STATUS (Status); } - ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, "**** [%4.4s] Parsed **** NamedObj=%p Op=%p\n", - (char *) &((ACPI_NAMESPACE_NODE *) ObjHandle)->Name, ObjHandle, Op)); + ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, + "**** [%4.4s] Parsed **** NamedObj=%p Op=%p\n", + ((ACPI_NAMESPACE_NODE *) ObjHandle)->Name.Ascii, ObjHandle, Op)); AcpiPsDeleteParseTree (Op); return_ACPI_STATUS (Status); @@ -461,8 +459,8 @@ ThisWalkState->NumOperands = 0; - ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Starting nested execution, newstate=%p\n", - NextWalkState)); + ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, + "Starting nested execution, newstate=%p\n", NextWalkState)); return_ACPI_STATUS (AE_OK); @@ -470,7 +468,7 @@ /* On error, we must delete the new walk state */ Cleanup: - AcpiDsTerminateControlMethod (NextWalkState); + (void) AcpiDsTerminateControlMethod (NextWalkState); AcpiDsDeleteWalkState (NextWalkState); return_ACPI_STATUS (Status); @@ -561,6 +559,11 @@ ACPI_FUNCTION_TRACE_PTR ("DsTerminateControlMethod", WalkState); + if (!WalkState) + { + return (AE_BAD_PARAMETER); + } + /* The current method object was saved in the walk state */ ObjDesc = WalkState->MethodDesc; @@ -588,8 +591,15 @@ if (WalkState->MethodDesc->Method.Semaphore) { - AcpiOsSignalSemaphore ( - WalkState->MethodDesc->Method.Semaphore, 1); + Status = AcpiOsSignalSemaphore ( + WalkState->MethodDesc->Method.Semaphore, 1); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("Could not signal method semaphore\n")); + Status = AE_OK; + + /* Ignore error and continue cleanup */ + } } /* Decrement the thread count on the method parse tree */ Index: dsmthdat.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dsmthdat.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 dsmthdat.c --- dsmthdat.c 30 Jun 2002 17:50:43 -0000 1.1.1.11 +++ dsmthdat.c 1 Jul 2002 21:39:53 -0000 @@ -117,9 +117,7 @@ #define __DSMTHDAT_C__ #include "acpi.h" -#include "acparser.h" #include "acdispat.h" -#include "acinterp.h" #include "amlcode.h" #include "acnamesp.h" @@ -149,7 +147,7 @@ * ******************************************************************************/ -ACPI_STATUS +void AcpiDsMethodDataInit ( ACPI_WALK_STATE *WalkState) { @@ -184,7 +182,7 @@ WalkState->LocalVariables[i].Flags = ANOBJ_END_OF_PEER_LIST | ANOBJ_METHOD_LOCAL; } - return_ACPI_STATUS (AE_OK); + return_VOID; } @@ -194,14 +192,14 @@ * * PARAMETERS: WalkState - Current walk state object * - * RETURN: Status + * RETURN: None * * DESCRIPTION: Delete method locals and arguments. Arguments are only * deleted if this method was called from another method. * ******************************************************************************/ -ACPI_STATUS +void AcpiDsMethodDataDeleteAll ( ACPI_WALK_STATE *WalkState) { @@ -223,7 +221,7 @@ /* Detach object (if present) and remove a reference */ AcpiNsDetachObject (&WalkState->LocalVariables[Index]); - } + } } /* Detach the arguments */ @@ -241,7 +239,7 @@ } } - return_ACPI_STATUS (AE_OK); + return_VOID; } @@ -463,7 +461,7 @@ /* Get the object type */ - return_VALUE (Object->Common.Type); + return_VALUE (ACPI_GET_OBJECT_TYPE (Object)); } @@ -546,6 +544,9 @@ Index, Node)); return_ACPI_STATUS (AE_AML_UNINITIALIZED_LOCAL); + + default: + return_ACPI_STATUS (AE_AML_INTERNAL); } } @@ -568,14 +569,14 @@ * Index - Which localVar or argument to delete * WalkState - Current walk state object * - * RETURN: Status + * RETURN: None * * DESCRIPTION: Delete the entry at Opcode:Index on the method stack. Inserts * a null into the stack slot after the object is deleted. * ******************************************************************************/ -ACPI_STATUS +void AcpiDsMethodDataDeleteValue ( UINT16 Opcode, UINT32 Index, @@ -594,7 +595,7 @@ Status = AcpiDsMethodDataGetNode (Opcode, Index, WalkState, &Node); if (ACPI_FAILURE (Status)) { - return_ACPI_STATUS (Status); + return_VOID; } /* Get the associated object */ @@ -609,7 +610,7 @@ Node->Object = NULL; if ((Object) && - (ACPI_GET_DESCRIPTOR_TYPE (Object) == ACPI_DESC_TYPE_INTERNAL)) + (ACPI_GET_DESCRIPTOR_TYPE (Object) == ACPI_DESC_TYPE_OPERAND)) { /* * There is a valid object. @@ -619,7 +620,7 @@ AcpiUtRemoveReference (Object); } - return_ACPI_STATUS (AE_OK); + return_VOID; } @@ -719,7 +720,7 @@ * (perform the indirect store) */ Status = AcpiNsAttachObject ((ACPI_NAMESPACE_NODE *) CurrentObjDesc, - ObjDesc, ObjDesc->Common.Type); + ObjDesc, ACPI_GET_OBJECT_TYPE (ObjDesc)); return_ACPI_STATUS (Status); } Index: dsobject.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dsobject.c,v retrieving revision 1.1.1.15 diff -u -r1.1.1.15 dsobject.c --- dsobject.c 30 Jun 2002 17:50:43 -0000 1.1.1.15 +++ dsobject.c 1 Jul 2002 21:39:53 -0000 @@ -120,8 +120,8 @@ #include "acparser.h" #include "amlcode.h" #include "acdispat.h" -#include "acinterp.h" #include "acnamesp.h" +#include "acinterp.h" #define _COMPONENT ACPI_DISPATCHER ACPI_MODULE_NAME ("dsobject") @@ -157,15 +157,11 @@ ACPI_OBJECT_TYPE Type; ACPI_STATUS Status; ACPI_INIT_WALK_INFO *Info = (ACPI_INIT_WALK_INFO *) Context; - UINT8 TableRevision; ACPI_FUNCTION_NAME ("DsInitOneObject"); - Info->ObjectCount++; - TableRevision = Info->TableDesc->Pointer->Revision; - /* * We are only interested in objects owned by the table that * was just loaded @@ -176,6 +172,8 @@ return (AE_OK); } + Info->ObjectCount++; + /* And even then, we are only interested in a few object types */ Type = AcpiNsGetType (ObjHandle); @@ -184,7 +182,13 @@ { case ACPI_TYPE_REGION: - AcpiDsInitializeRegion (ObjHandle); + Status = AcpiDsInitializeRegion (ObjHandle); + if (ACPI_FAILURE (Status)) + { + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Region %p [%4.4s] - Init failure, %s\n", + ObjHandle, ((ACPI_NAMESPACE_NODE *) ObjHandle)->Name.Ascii, + AcpiFormatException (Status))); + } Info->OpRegionCount++; break; @@ -202,10 +206,12 @@ /* * Set the execution data width (32 or 64) based upon the * revision number of the parent ACPI table. + * TBD: This is really for possible future support of integer width + * on a per-table basis. Currently, we just use a global for the width. */ - if (TableRevision == 1) + if (Info->TableDesc->Pointer->Revision == 1) { - ((ACPI_NAMESPACE_NODE *)ObjHandle)->Flags |= ANOBJ_DATA_WIDTH_32; + ((ACPI_NAMESPACE_NODE *) ObjHandle)->Flags |= ANOBJ_DATA_WIDTH_32; } /* @@ -216,7 +222,7 @@ if (ACPI_FAILURE (Status)) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Method %p [%4.4s] - parse failure, %s\n", - ObjHandle, (char *) &((ACPI_NAMESPACE_NODE *) ObjHandle)->Name, + ObjHandle, ((ACPI_NAMESPACE_NODE *) ObjHandle)->Name.Ascii, AcpiFormatException (Status))); /* This parse failed, but we will continue parsing more methods */ @@ -232,6 +238,13 @@ AcpiNsDeleteNamespaceByOwner (((ACPI_NAMESPACE_NODE *) ObjHandle)->Object->Method.OwningId); break; + + case ACPI_TYPE_DEVICE: + + Info->DeviceCount++; + break; + + default: break; } @@ -274,10 +287,10 @@ "**** Starting initialization of namespace objects ****\n")); ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OK, "Parsing Methods:")); - Info.MethodCount = 0; Info.OpRegionCount = 0; Info.ObjectCount = 0; + Info.DeviceCount = 0; Info.TableDesc = TableDesc; /* Walk entire namespace from the supplied root */ @@ -286,16 +299,17 @@ AcpiDsInitOneObject, &Info, NULL); if (ACPI_FAILURE (Status)) { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "WalkNamespace failed! %x\n", Status)); + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "WalkNamespace failed, %s\n", + AcpiFormatException (Status))); } ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OK, - "\n%d Control Methods found and parsed (%d nodes total)\n", - Info.MethodCount, Info.ObjectCount)); - ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, - "%d Control Methods found\n", Info.MethodCount)); + "\nTable [%4.4s] - %hd Objects with %hd Devices %hd Methods %hd Regions\n", + TableDesc->Pointer->Signature, Info.ObjectCount, + Info.DeviceCount, Info.MethodCount, Info.OpRegionCount)); + ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, - "%d Op Regions found\n", Info.OpRegionCount)); + "%hd Methods, %hd Regions\n", Info.MethodCount, Info.OpRegionCount)); return_ACPI_STATUS (AE_OK); } @@ -327,9 +341,10 @@ { const ACPI_OPCODE_INFO *OpInfo; ACPI_OPERAND_OBJECT *ObjDesc; + ACPI_STATUS Status = AE_OK; - ACPI_FUNCTION_NAME ("DsInitObjectFromOp"); + ACPI_FUNCTION_TRACE ("DsInitObjectFromOp"); ObjDesc = *RetObjDesc; @@ -338,12 +353,12 @@ { /* Unknown opcode */ - return (AE_TYPE); + return_ACPI_STATUS (AE_TYPE); } /* Perform per-object initialization */ - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_BUFFER: @@ -351,8 +366,8 @@ * Defer evaluation of Buffer TermArg operand */ ObjDesc->Buffer.Node = (ACPI_NAMESPACE_NODE *) WalkState->Operands[0]; - ObjDesc->Buffer.AmlStart = ((ACPI_PARSE2_OBJECT *) Op)->Data; - ObjDesc->Buffer.AmlLength = ((ACPI_PARSE2_OBJECT *) Op)->Length; + ObjDesc->Buffer.AmlStart = Op->Named.Data; + ObjDesc->Buffer.AmlLength = Op->Named.Length; break; @@ -362,21 +377,78 @@ * Defer evaluation of Package TermArg operand */ ObjDesc->Package.Node = (ACPI_NAMESPACE_NODE *) WalkState->Operands[0]; - ObjDesc->Package.AmlStart = ((ACPI_PARSE2_OBJECT *) Op)->Data; - ObjDesc->Package.AmlLength = ((ACPI_PARSE2_OBJECT *) Op)->Length; + ObjDesc->Package.AmlStart = Op->Named.Data; + ObjDesc->Package.AmlLength = Op->Named.Length; break; case ACPI_TYPE_INTEGER: - ObjDesc->Integer.Value = Op->Value.Integer; + switch (OpInfo->Type) + { + case AML_TYPE_CONSTANT: + /* + * Resolve AML Constants here - AND ONLY HERE! + * All constants are integers. + * We mark the integer with a flag that indicates that it started life + * as a constant -- so that stores to constants will perform as expected (noop). + * (ZeroOp is used as a placeholder for optional target operands.) + */ + ObjDesc->Common.Flags = AOPOBJ_AML_CONSTANT; + + switch (Opcode) + { + case AML_ZERO_OP: + + ObjDesc->Integer.Value = 0; + break; + + case AML_ONE_OP: + + ObjDesc->Integer.Value = 1; + break; + + case AML_ONES_OP: + + ObjDesc->Integer.Value = ACPI_INTEGER_MAX; + + /* Truncate value if we are executing from a 32-bit ACPI table */ + + AcpiExTruncateFor32bitTable (ObjDesc); + break; + + case AML_REVISION_OP: + + ObjDesc->Integer.Value = ACPI_CA_SUPPORT_LEVEL; + break; + + default: + + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown constant opcode %X\n", Opcode)); + Status = AE_AML_OPERAND_TYPE; + break; + } + break; + + + case AML_TYPE_LITERAL: + + ObjDesc->Integer.Value = Op->Common.Value.Integer; + break; + + + default: + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown Integer type %X\n", OpInfo->Type)); + Status = AE_AML_OPERAND_TYPE; + break; + } break; case ACPI_TYPE_STRING: - ObjDesc->String.Pointer = Op->Value.String; - ObjDesc->String.Length = ACPI_STRLEN (Op->Value.String); + ObjDesc->String.Pointer = Op->Common.Value.String; + ObjDesc->String.Length = ACPI_STRLEN (Op->Common.Value.String); /* * The string is contained in the ACPI table, don't ever try @@ -412,13 +484,13 @@ break; - default: /* Constants, Literals, etc.. */ + default: /* Other literals, etc.. */ - if (Op->Opcode == AML_INT_NAMEPATH_OP) + if (Op->Common.AmlOpcode == AML_INT_NAMEPATH_OP) { /* Node was saved in Op */ - ObjDesc->Reference.Node = Op->Node; + ObjDesc->Reference.Node = Op->Common.Node; } ObjDesc->Reference.Opcode = Opcode; @@ -429,13 +501,14 @@ default: - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unimplemented data type: %x\n", - ObjDesc->Common.Type)); + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unimplemented data type: %X\n", + ACPI_GET_OBJECT_TYPE (ObjDesc))); + Status = AE_AML_OPERAND_TYPE; break; } - return (AE_OK); + return_ACPI_STATUS (Status); } @@ -468,37 +541,36 @@ ACPI_FUNCTION_TRACE ("DsBuildInternalObject"); - if (Op->Opcode == AML_INT_NAMEPATH_OP) + if (Op->Common.AmlOpcode == AML_INT_NAMEPATH_OP) { /* - * This is an object reference. If this name was + * This is an named object reference. If this name was * previously looked up in the namespace, it was stored in this op. * Otherwise, go ahead and look it up now */ - if (!Op->Node) + if (!Op->Common.Node) { - Status = AcpiNsLookup (WalkState->ScopeInfo, Op->Value.String, + Status = AcpiNsLookup (WalkState->ScopeInfo, Op->Common.Value.String, ACPI_TYPE_ANY, ACPI_IMODE_EXECUTE, ACPI_NS_SEARCH_PARENT | ACPI_NS_DONT_OPEN_SCOPE, NULL, - (ACPI_NAMESPACE_NODE **) &(Op->Node)); + (ACPI_NAMESPACE_NODE **) &(Op->Common.Node)); if (ACPI_FAILURE (Status)) { if (Status == AE_NOT_FOUND) { Name = NULL; - AcpiNsExternalizeName (ACPI_UINT32_MAX, Op->Value.String, NULL, &Name); - - if (Name) + Status = AcpiNsExternalizeName (ACPI_UINT32_MAX, Op->Common.Value.String, NULL, &Name); + if (ACPI_SUCCESS (Status)) { ACPI_REPORT_WARNING (("Reference %s at AML %X not found\n", - Name, Op->AmlOffset)); + Name, Op->Common.AmlOffset)); ACPI_MEM_FREE (Name); } else { ACPI_REPORT_WARNING (("Reference %s at AML %X not found\n", - Op->Value.String, Op->AmlOffset)); + Op->Common.Value.String, Op->Common.AmlOffset)); } *ObjDescPtr = NULL; @@ -513,13 +585,13 @@ /* Create and init the internal ACPI object */ - ObjDesc = AcpiUtCreateInternalObject ((AcpiPsGetOpcodeInfo (Op->Opcode))->ObjectType); + ObjDesc = AcpiUtCreateInternalObject ((AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode))->ObjectType); if (!ObjDesc) { return_ACPI_STATUS (AE_NO_MEMORY); } - Status = AcpiDsInitObjectFromOp (WalkState, Op, Op->Opcode, &ObjDesc); + Status = AcpiDsInitObjectFromOp (WalkState, Op, Op->Common.AmlOpcode, &ObjDesc); if (ACPI_FAILURE (Status)) { AcpiUtRemoveReference (ObjDesc); @@ -535,7 +607,9 @@ * * FUNCTION: AcpiDsBuildInternalBufferObj * - * PARAMETERS: Op - Parser object to be translated + * PARAMETERS: WalkState - Current walk state + * Op - Parser object to be translated + * BufferLength - Length of the buffer * ObjDescPtr - Where the ACPI internal object is returned * * RETURN: Status @@ -554,7 +628,7 @@ { ACPI_PARSE_OBJECT *Arg; ACPI_OPERAND_OBJECT *ObjDesc; - ACPI_PARSE2_OBJECT *ByteList; + ACPI_PARSE_OBJECT *ByteList; UINT32 ByteListLength = 0; @@ -586,22 +660,22 @@ * individual bytes or a string initializer. In either case, a * ByteList appears in the AML. */ - Arg = Op->Value.Arg; /* skip first arg */ + Arg = Op->Common.Value.Arg; /* skip first arg */ - ByteList = (ACPI_PARSE2_OBJECT *) Arg->Next; + ByteList = Arg->Named.Next; if (ByteList) { - if (ByteList->Opcode != AML_INT_BYTELIST_OP) + if (ByteList->Common.AmlOpcode != AML_INT_BYTELIST_OP) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Expecting bytelist, got AML opcode %X in op %p\n", - ByteList->Opcode, ByteList)); + ByteList->Common.AmlOpcode, ByteList)); AcpiUtRemoveReference (ObjDesc); return (AE_TYPE); } - ByteListLength = ByteList->Value.Integer32; + ByteListLength = ByteList->Common.Value.Integer32; } /* @@ -636,12 +710,12 @@ if (ByteList) { - ACPI_MEMCPY (ObjDesc->Buffer.Pointer, ByteList->Data, + ACPI_MEMCPY (ObjDesc->Buffer.Pointer, ByteList->Named.Data, ByteListLength); } ObjDesc->Buffer.Flags |= AOPOBJ_DATA_VALID; - Op->Node = (ACPI_NAMESPACE_NODE *) ObjDesc; + Op->Common.Node = (ACPI_NAMESPACE_NODE *) ObjDesc; return_ACPI_STATUS (AE_OK); } @@ -650,7 +724,9 @@ * * FUNCTION: AcpiDsBuildInternalPackageObj * - * PARAMETERS: Op - Parser object to be translated + * PARAMETERS: WalkState - Current walk state + * Op - Parser object to be translated + * PackageLength - Number of elements in the package * ObjDescPtr - Where the ACPI internal object is returned * * RETURN: Status @@ -680,12 +756,11 @@ /* Find the parent of a possibly nested package */ - - Parent = Op->Parent; - while ((Parent->Opcode == AML_PACKAGE_OP) || - (Parent->Opcode == AML_VAR_PACKAGE_OP)) + Parent = Op->Common.Parent; + while ((Parent->Common.AmlOpcode == AML_PACKAGE_OP) || + (Parent->Common.AmlOpcode == AML_VAR_PACKAGE_OP)) { - Parent = Parent->Parent; + Parent = Parent->Common.Parent; } ObjDesc = *ObjDescPtr; @@ -705,7 +780,7 @@ return_ACPI_STATUS (AE_NO_MEMORY); } - ObjDesc->Package.Node = Parent->Node; + ObjDesc->Package.Node = Parent->Common.Node; } ObjDesc->Package.Count = PackageLength; @@ -713,12 +788,12 @@ /* Count the number of items in the package list */ PackageListLength = 0; - Arg = Op->Value.Arg; - Arg = Arg->Next; + Arg = Op->Common.Value.Arg; + Arg = Arg->Common.Next; while (Arg) { PackageListLength++; - Arg = Arg->Next; + Arg = Arg->Common.Next; } /* @@ -736,7 +811,7 @@ * that the list is always null terminated. */ ObjDesc->Package.Elements = ACPI_MEM_CALLOCATE ( - (ObjDesc->Package.Count + 1) * sizeof (void *)); + ((ACPI_SIZE) ObjDesc->Package.Count + 1) * sizeof (void *)); if (!ObjDesc->Package.Elements) { @@ -748,15 +823,15 @@ * Now init the elements of the package */ i = 0; - Arg = Op->Value.Arg; - Arg = Arg->Next; + Arg = Op->Common.Value.Arg; + Arg = Arg->Common.Next; while (Arg) { - if (Arg->Opcode == AML_INT_RETURN_VALUE_OP) + if (Arg->Common.AmlOpcode == AML_INT_RETURN_VALUE_OP) { /* Object (package or buffer) is already built */ - ObjDesc->Package.Elements[i] = (ACPI_OPERAND_OBJECT *) Arg->Node; + ObjDesc->Package.Elements[i] = ACPI_CAST_PTR (ACPI_OPERAND_OBJECT, Arg->Common.Node); } else { @@ -765,11 +840,11 @@ } i++; - Arg = Arg->Next; + Arg = Arg->Common.Next; } ObjDesc->Package.Flags |= AOPOBJ_DATA_VALID; - Op->Node = (ACPI_NAMESPACE_NODE *) ObjDesc; + Op->Common.Node = (ACPI_NAMESPACE_NODE *) ObjDesc; return_ACPI_STATUS (Status); } @@ -778,12 +853,13 @@ * * FUNCTION: AcpiDsCreateNode * - * PARAMETERS: Op - Parser object to be translated - * ObjDescPtr - Where the ACPI internal object is returned + * PARAMETERS: WalkState - Current walk state + * Node - NS Node to be initialized + * Op - Parser object to be translated * * RETURN: Status * - * DESCRIPTION: + * DESCRIPTION: Create the object to be associated with a namespace node * ****************************************************************************/ @@ -810,7 +886,7 @@ return_ACPI_STATUS (AE_OK); } - if (!Op->Value.Arg) + if (!Op->Common.Value.Arg) { /* No arguments, there is nothing to do */ @@ -819,7 +895,7 @@ /* Build an internal object for the argument(s) */ - Status = AcpiDsBuildInternalObject (WalkState, Op->Value.Arg, &ObjDesc); + Status = AcpiDsBuildInternalObject (WalkState, Op->Common.Value.Arg, &ObjDesc); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); @@ -827,7 +903,7 @@ /* Re-type the object according to it's argument */ - Node->Type = ObjDesc->Common.Type; + Node->Type = ACPI_GET_OBJECT_TYPE (ObjDesc); /* Attach obj to node */ Index: dsopcode.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dsopcode.c,v retrieving revision 1.1.1.15 diff -u -r1.1.1.15 dsopcode.c --- dsopcode.c 30 Jun 2002 17:50:43 -0000 1.1.1.15 +++ dsopcode.c 1 Jul 2002 21:39:53 -0000 @@ -124,7 +124,6 @@ #include "acinterp.h" #include "acnamesp.h" #include "acevents.h" -#include "actables.h" #define _COMPONENT ACPI_DISPATCHER ACPI_MODULE_NAME ("dsopcode") @@ -135,7 +134,8 @@ * FUNCTION: AcpiDsExecuteArguments * * PARAMETERS: Node - Parent NS node - * ExtraDesc - Has AML pointer and length + * AmlLength - Length of executable AML + * AmlStart - Pointer to the AML * * RETURN: Status. * @@ -170,7 +170,7 @@ /* Save the Node for use in AcpiPsParseAml */ - Op->Node = ScopeNode; + Op->Common.Node = ScopeNode; /* Create and initialize a new parser state */ @@ -201,9 +201,9 @@ /* Get and init the Op created above */ - Arg = Op->Value.Arg; - Op->Node = Node; - Arg->Node = Node; + Arg = Op->Common.Value.Arg; + Op->Common.Node = Node; + Arg->Common.Node = Node; AcpiPsDeleteParseTree (Op); /* Evaluate the address and length arguments for the Buffer Field */ @@ -214,7 +214,7 @@ return_ACPI_STATUS (AE_NO_MEMORY); } - Op->Node = ScopeNode; + Op->Common.Node = ScopeNode; /* Create and initialize a new parser state */ @@ -275,7 +275,7 @@ ACPI_DEBUG_EXEC(AcpiUtDisplayInitPathname (Node, " [Field]")); ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "[%4.4s] BufferField JIT Init\n", - (char *) &Node->Name)); + Node->Name.Ascii)); /* Execute the AML code for the TermArg arguments */ @@ -426,7 +426,7 @@ ACPI_DEBUG_EXEC(AcpiUtDisplayInitPathname (Node, " [Operation Region]")); ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "[%4.4s] OpRegion Init at AML %p\n", - (char *) &Node->Name, ExtraDesc->Extra.AmlStart)); + Node->Name.Ascii, ExtraDesc->Extra.AmlStart)); Status = AcpiDsExecuteArguments (Node, AcpiNsGetParentNode (Node), @@ -443,7 +443,7 @@ * * RETURN: Status * - * DESCRIPTION: + * DESCRIPTION: Front end to EvInitializeRegion * ****************************************************************************/ @@ -466,268 +466,283 @@ /***************************************************************************** * - * FUNCTION: AcpiDsEvalBufferFieldOperands + * FUNCTION: AcpiDsInitBufferField * - * PARAMETERS: Op - A valid BufferField Op object + * PARAMETERS: AmlOpcode - CreateXxxField + * ObjDesc - BufferField object + * BufferDesc - Host Buffer + * OffsetDesc - Offset into buffer + * Length - Length of field (CREATE_FIELD_OP only) + * Result - Where to store the result * * RETURN: Status * - * DESCRIPTION: Get BufferField Buffer and Index - * Called from AcpiDsExecEndOp during BufferField parse tree walk + * DESCRIPTION: Perform actual initialization of a buffer field * ****************************************************************************/ ACPI_STATUS -AcpiDsEvalBufferFieldOperands ( - ACPI_WALK_STATE *WalkState, - ACPI_PARSE_OBJECT *Op) +AcpiDsInitBufferField ( + UINT16 AmlOpcode, + ACPI_OPERAND_OBJECT *ObjDesc, + ACPI_OPERAND_OBJECT *BufferDesc, + ACPI_OPERAND_OBJECT *OffsetDesc, + ACPI_OPERAND_OBJECT *LengthDesc, + ACPI_OPERAND_OBJECT *ResultDesc) { - ACPI_STATUS Status; - ACPI_OPERAND_OBJECT *ObjDesc; - ACPI_NAMESPACE_NODE *Node; - ACPI_PARSE_OBJECT *NextOp; UINT32 Offset; UINT32 BitOffset; UINT32 BitCount; UINT8 FieldFlags; - ACPI_OPERAND_OBJECT *ResDesc = NULL; - ACPI_OPERAND_OBJECT *CntDesc = NULL; - ACPI_OPERAND_OBJECT *OffDesc = NULL; - ACPI_OPERAND_OBJECT *SrcDesc = NULL; - - - ACPI_FUNCTION_TRACE_PTR ("DsEvalBufferFieldOperands", Op); - - - /* - * This is where we evaluate the address and length fields of the - * CreateXxxField declaration - */ - Node = Op->Node; - - /* NextOp points to the op that holds the Buffer */ + ACPI_STATUS Status; - NextOp = Op->Value.Arg; - /* Evaluate/create the address and length operands */ + ACPI_FUNCTION_TRACE_PTR ("DsInitBufferField", ObjDesc); - Status = AcpiDsCreateOperands (WalkState, NextOp); - if (ACPI_FAILURE (Status)) - { - return_ACPI_STATUS (Status); - } - ObjDesc = AcpiNsGetAttachedObject (Node); - if (!ObjDesc) - { - return_ACPI_STATUS (AE_NOT_EXIST); - } - - /* Resolve the operands */ + /* Host object must be a Buffer */ - Status = AcpiExResolveOperands (Op->Opcode, ACPI_WALK_OPERANDS, WalkState); - ACPI_DUMP_OPERANDS (ACPI_WALK_OPERANDS, ACPI_IMODE_EXECUTE, AcpiPsGetOpcodeName (Op->Opcode), - WalkState->NumOperands, "after AcpiExResolveOperands"); - - if (ACPI_FAILURE (Status)) + if (ACPI_GET_OBJECT_TYPE (BufferDesc) != ACPI_TYPE_BUFFER) { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "(%s) bad operand(s) (%X)\n", - AcpiPsGetOpcodeName (Op->Opcode), Status)); + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, + "Target of Create Field is not a Buffer object - %s\n", + AcpiUtGetObjectTypeName (BufferDesc))); + Status = AE_AML_OPERAND_TYPE; goto Cleanup; } - /* Get the operands */ - - if (AML_CREATE_FIELD_OP == Op->Opcode) - { - ResDesc = WalkState->Operands[3]; - CntDesc = WalkState->Operands[2]; - } - else - { - ResDesc = WalkState->Operands[2]; - } - - OffDesc = WalkState->Operands[1]; - SrcDesc = WalkState->Operands[0]; - Offset = (UINT32) OffDesc->Integer.Value; - /* - * If ResDesc is a Name, it will be a direct name pointer after - * AcpiExResolveOperands() + * The last parameter to all of these opcodes (ResultDesc) started + * out as a NameString, and should therefore now be a NS node + * after resolution in AcpiExResolveOperands(). */ - if (ACPI_GET_DESCRIPTOR_TYPE (ResDesc) != ACPI_DESC_TYPE_NAMED) + if (ACPI_GET_DESCRIPTOR_TYPE (ResultDesc) != ACPI_DESC_TYPE_NAMED) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "(%s) destination must be a NS Node\n", - AcpiPsGetOpcodeName (Op->Opcode))); + AcpiPsGetOpcodeName (AmlOpcode))); Status = AE_AML_OPERAND_TYPE; goto Cleanup; } + Offset = (UINT32) OffsetDesc->Integer.Value; + /* * Setup the Bit offsets and counts, according to the opcode */ - switch (Op->Opcode) + switch (AmlOpcode) { case AML_CREATE_FIELD_OP: /* Offset is in bits, count is in bits */ - BitOffset = Offset; - BitCount = (UINT32) CntDesc->Integer.Value; - FieldFlags = AML_FIELD_ACCESS_BYTE; + BitOffset = Offset; + BitCount = (UINT32) LengthDesc->Integer.Value; + FieldFlags = AML_FIELD_ACCESS_BYTE; break; case AML_CREATE_BIT_FIELD_OP: /* Offset is in bits, Field is one bit */ - BitOffset = Offset; - BitCount = 1; - FieldFlags = AML_FIELD_ACCESS_BYTE; + BitOffset = Offset; + BitCount = 1; + FieldFlags = AML_FIELD_ACCESS_BYTE; break; case AML_CREATE_BYTE_FIELD_OP: /* Offset is in bytes, field is one byte */ - BitOffset = 8 * Offset; - BitCount = 8; - FieldFlags = AML_FIELD_ACCESS_BYTE; + BitOffset = 8 * Offset; + BitCount = 8; + FieldFlags = AML_FIELD_ACCESS_BYTE; break; case AML_CREATE_WORD_FIELD_OP: /* Offset is in bytes, field is one word */ - BitOffset = 8 * Offset; - BitCount = 16; - FieldFlags = AML_FIELD_ACCESS_WORD; + BitOffset = 8 * Offset; + BitCount = 16; + FieldFlags = AML_FIELD_ACCESS_WORD; break; case AML_CREATE_DWORD_FIELD_OP: /* Offset is in bytes, field is one dword */ - BitOffset = 8 * Offset; - BitCount = 32; - FieldFlags = AML_FIELD_ACCESS_DWORD; + BitOffset = 8 * Offset; + BitCount = 32; + FieldFlags = AML_FIELD_ACCESS_DWORD; break; case AML_CREATE_QWORD_FIELD_OP: /* Offset is in bytes, field is one qword */ - BitOffset = 8 * Offset; - BitCount = 64; - FieldFlags = AML_FIELD_ACCESS_QWORD; + BitOffset = 8 * Offset; + BitCount = 64; + FieldFlags = AML_FIELD_ACCESS_QWORD; break; default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, - "Internal error - unknown field creation opcode %02x\n", - Op->Opcode)); + "Unknown field creation opcode %02x\n", + AmlOpcode)); Status = AE_AML_BAD_OPCODE; goto Cleanup; } + + /* Entire field must fit within the current length of the buffer */ + + if ((BitOffset + BitCount) > + (8 * (UINT32) BufferDesc->Buffer.Length)) + { + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, + "Field size %d exceeds Buffer size %d (bits)\n", + BitOffset + BitCount, 8 * (UINT32) BufferDesc->Buffer.Length)); + Status = AE_AML_BUFFER_LIMIT; + goto Cleanup; + } + /* - * Setup field according to the object type + * Initialize areas of the field object that are common to all fields + * For FieldFlags, use LOCK_RULE = 0 (NO_LOCK), UPDATE_RULE = 0 (UPDATE_PRESERVE) */ - switch (SrcDesc->Common.Type) + Status = AcpiExPrepCommonFieldObject (ObjDesc, FieldFlags, 0, + BitOffset, BitCount); + if (ACPI_FAILURE (Status)) { + goto Cleanup; + } - /* SourceBuff := TermArg=>Buffer */ - - case ACPI_TYPE_BUFFER: + ObjDesc->BufferField.BufferObj = BufferDesc; - if ((BitOffset + BitCount) > - (8 * (UINT32) SrcDesc->Buffer.Length)) - { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, - "Field size %d exceeds Buffer size %d (bits)\n", - BitOffset + BitCount, 8 * (UINT32) SrcDesc->Buffer.Length)); - Status = AE_AML_BUFFER_LIMIT; - goto Cleanup; - } + /* Reference count for BufferDesc inherits ObjDesc count */ - /* - * Initialize areas of the field object that are common to all fields - * For FieldFlags, use LOCK_RULE = 0 (NO_LOCK), UPDATE_RULE = 0 (UPDATE_PRESERVE) - */ - Status = AcpiExPrepCommonFieldObject (ObjDesc, FieldFlags, 0, - BitOffset, BitCount); - if (ACPI_FAILURE (Status)) - { - return_ACPI_STATUS (Status); - } + BufferDesc->Common.ReferenceCount = (UINT16) (BufferDesc->Common.ReferenceCount + + ObjDesc->Common.ReferenceCount); - ObjDesc->BufferField.BufferObj = SrcDesc; - /* Reference count for SrcDesc inherits ObjDesc count */ +Cleanup: - SrcDesc->Common.ReferenceCount = (UINT16) (SrcDesc->Common.ReferenceCount + - ObjDesc->Common.ReferenceCount); - break; + /* Always delete the operands */ + AcpiUtRemoveReference (OffsetDesc); + AcpiUtRemoveReference (BufferDesc); - /* Improper object type */ + if (AmlOpcode == AML_CREATE_FIELD_OP) + { + AcpiUtRemoveReference (LengthDesc); + } - default: + /* On failure, delete the result descriptor */ - if ((SrcDesc->Common.Type > (UINT8) INTERNAL_TYPE_REFERENCE) || !AcpiUtValidObjectType (SrcDesc->Common.Type)) /* This line MUST be a single line until AcpiSrc can handle it (block deletion) */ - { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, - "Tried to create field in invalid object type %X\n", - SrcDesc->Common.Type)); - } - else - { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, - "Tried to create field in improper object type - %s\n", - AcpiUtGetTypeName (SrcDesc->Common.Type))); - } + if (ACPI_FAILURE (Status)) + { + AcpiUtRemoveReference (ResultDesc); /* Result descriptor */ + } + else + { + /* Now the address and length are valid for this BufferField */ - Status = AE_AML_OPERAND_TYPE; - goto Cleanup; + ObjDesc->BufferField.Flags |= AOPOBJ_DATA_VALID; } + return_ACPI_STATUS (Status); +} - if (AML_CREATE_FIELD_OP == Op->Opcode) - { - /* Delete object descriptor unique to CreateField */ - AcpiUtRemoveReference (CntDesc); - CntDesc = NULL; - } +/***************************************************************************** + * + * FUNCTION: AcpiDsEvalBufferFieldOperands + * + * PARAMETERS: WalkState - Current walk + * Op - A valid BufferField Op object + * + * RETURN: Status + * + * DESCRIPTION: Get BufferField Buffer and Index + * Called from AcpiDsExecEndOp during BufferField parse tree walk + * + ****************************************************************************/ +ACPI_STATUS +AcpiDsEvalBufferFieldOperands ( + ACPI_WALK_STATE *WalkState, + ACPI_PARSE_OBJECT *Op) +{ + ACPI_STATUS Status; + ACPI_OPERAND_OBJECT *ObjDesc; + ACPI_NAMESPACE_NODE *Node; + ACPI_PARSE_OBJECT *NextOp; -Cleanup: - /* Always delete the operands */ + ACPI_FUNCTION_TRACE_PTR ("DsEvalBufferFieldOperands", Op); - AcpiUtRemoveReference (OffDesc); - AcpiUtRemoveReference (SrcDesc); - if (AML_CREATE_FIELD_OP == Op->Opcode) + /* + * This is where we evaluate the address and length fields of the + * CreateXxxField declaration + */ + Node = Op->Common.Node; + + /* NextOp points to the op that holds the Buffer */ + + NextOp = Op->Common.Value.Arg; + + /* Evaluate/create the address and length operands */ + + Status = AcpiDsCreateOperands (WalkState, NextOp); + if (ACPI_FAILURE (Status)) { - AcpiUtRemoveReference (CntDesc); + return_ACPI_STATUS (Status); } - /* On failure, delete the result descriptor */ + ObjDesc = AcpiNsGetAttachedObject (Node); + if (!ObjDesc) + { + return_ACPI_STATUS (AE_NOT_EXIST); + } + + /* Resolve the operands */ + + Status = AcpiExResolveOperands (Op->Common.AmlOpcode, + ACPI_WALK_OPERANDS, WalkState); + + ACPI_DUMP_OPERANDS (ACPI_WALK_OPERANDS, ACPI_IMODE_EXECUTE, + AcpiPsGetOpcodeName (Op->Common.AmlOpcode), + WalkState->NumOperands, "after AcpiExResolveOperands"); if (ACPI_FAILURE (Status)) { - AcpiUtRemoveReference (ResDesc); /* Result descriptor */ + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "(%s) bad operand(s) (%X)\n", + AcpiPsGetOpcodeName (Op->Common.AmlOpcode), Status)); + + return_ACPI_STATUS (Status); + } + + /* Initialize the Buffer Field */ + + if (Op->Common.AmlOpcode == AML_CREATE_FIELD_OP) + { + /* NOTE: Slightly different operands for this opcode */ + + Status = AcpiDsInitBufferField (Op->Common.AmlOpcode, ObjDesc, + WalkState->Operands[0], WalkState->Operands[1], + WalkState->Operands[2], WalkState->Operands[3]); } else { - /* Now the address and length are valid for this BufferField */ + /* All other, CreateXxxField opcodes */ - ObjDesc->BufferField.Flags |= AOPOBJ_DATA_VALID; + Status = AcpiDsInitBufferField (Op->Common.AmlOpcode, ObjDesc, + WalkState->Operands[0], WalkState->Operands[1], + NULL, WalkState->Operands[2]); } return_ACPI_STATUS (Status); @@ -738,7 +753,8 @@ * * FUNCTION: AcpiDsEvalRegionOperands * - * PARAMETERS: Op - A valid region Op object + * PARAMETERS: WalkState - Current walk + * Op - A valid region Op object * * RETURN: Status * @@ -765,15 +781,15 @@ /* * This is where we evaluate the address and length fields of the OpRegion declaration */ - Node = Op->Node; + Node = Op->Common.Node; /* NextOp points to the op that holds the SpaceID */ - NextOp = Op->Value.Arg; + NextOp = Op->Common.Value.Arg; /* NextOp points to address op */ - NextOp = NextOp->Next; + NextOp = NextOp->Common.Next; /* Evaluate/create the address and length operands */ @@ -785,14 +801,14 @@ /* Resolve the length and address operands to numbers */ - Status = AcpiExResolveOperands (Op->Opcode, ACPI_WALK_OPERANDS, WalkState); + Status = AcpiExResolveOperands (Op->Common.AmlOpcode, ACPI_WALK_OPERANDS, WalkState); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); } ACPI_DUMP_OPERANDS (ACPI_WALK_OPERANDS, ACPI_IMODE_EXECUTE, - AcpiPsGetOpcodeName (Op->Opcode), + AcpiPsGetOpcodeName (Op->Common.AmlOpcode), 1, "after AcpiExResolveOperands"); ObjDesc = AcpiNsGetAttachedObject (Node); @@ -837,7 +853,9 @@ * * FUNCTION: AcpiDsEvalDataObjectOperands * - * PARAMETERS: Op - A valid DataObject Op object + * PARAMETERS: WalkState - Current walk + * Op - A valid DataObject Op object + * ObjDesc - DataObject * * RETURN: Status * @@ -863,7 +881,7 @@ /* The first operand (for all of these data objects) is the length */ - Status = AcpiDsCreateOperand (WalkState, Op->Value.Arg, 1); + Status = AcpiDsCreateOperand (WalkState, Op->Common.Value.Arg, 1); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); @@ -884,13 +902,18 @@ /* Cleanup for length operand */ - AcpiDsObjStackPop (1, WalkState); + Status = AcpiDsObjStackPop (1, WalkState); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + AcpiUtRemoveReference (ArgDesc); /* * Create the actual data object */ - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_BUFFER_OP: @@ -914,10 +937,10 @@ * in this case, the return object will be stored in the parse tree * for the package. */ - if ((!Op->Parent) || - ((Op->Parent->Opcode != AML_PACKAGE_OP) && - (Op->Parent->Opcode != AML_VAR_PACKAGE_OP) && - (Op->Parent->Opcode != AML_NAME_OP))) + if ((!Op->Common.Parent) || + ((Op->Common.Parent->Common.AmlOpcode != AML_PACKAGE_OP) && + (Op->Common.Parent->Common.AmlOpcode != AML_VAR_PACKAGE_OP) && + (Op->Common.Parent->Common.AmlOpcode != AML_NAME_OP))) { WalkState->ResultObj = ObjDesc; } @@ -955,9 +978,9 @@ ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Op=%p Opcode=%2.2X State=%p\n", Op, - Op->Opcode, WalkState)); + Op->Common.AmlOpcode, WalkState)); - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_IF_OP: case AML_WHILE_OP: @@ -979,7 +1002,7 @@ */ ControlState->Control.AmlPredicateStart = WalkState->ParserState.Aml - 1; ControlState->Control.PackageEnd = WalkState->ParserState.PkgEnd; - ControlState->Control.Opcode = Op->Opcode; + ControlState->Control.Opcode = Op->Common.AmlOpcode; /* Push the control state on this walk's control stack */ @@ -1037,7 +1060,7 @@ ACPI_FUNCTION_NAME ("DsExecEndControlOp"); - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_IF_OP: @@ -1089,18 +1112,18 @@ case AML_RETURN_OP: ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, - "[RETURN_OP] Op=%p Arg=%p\n",Op, Op->Value.Arg)); + "[RETURN_OP] Op=%p Arg=%p\n",Op, Op->Common.Value.Arg)); /* * One optional operand -- the return value * It can be either an immediate operand or a result that * has been bubbled up the tree */ - if (Op->Value.Arg) + if (Op->Common.Value.Arg) { /* Return statement has an immediate operand */ - Status = AcpiDsCreateOperands (WalkState, Op->Value.Arg); + Status = AcpiDsCreateOperands (WalkState, Op->Common.Value.Arg); if (ACPI_FAILURE (Status)) { return (Status); @@ -1136,8 +1159,8 @@ * * Allow references created by the Index operator to return unchanged. */ - if ((ACPI_GET_DESCRIPTOR_TYPE (WalkState->Results->Results.ObjDesc[0]) == ACPI_DESC_TYPE_INTERNAL) && - ((WalkState->Results->Results.ObjDesc [0])->Common.Type == INTERNAL_TYPE_REFERENCE) && + if ((ACPI_GET_DESCRIPTOR_TYPE (WalkState->Results->Results.ObjDesc[0]) == ACPI_DESC_TYPE_OPERAND) && + (ACPI_GET_OBJECT_TYPE (WalkState->Results->Results.ObjDesc [0]) == INTERNAL_TYPE_REFERENCE) && ((WalkState->Results->Results.ObjDesc [0])->Reference.Opcode != AML_INDEX_OP)) { Status = AcpiExResolveToValue (&WalkState->Results->Results.ObjDesc [0], WalkState); @@ -1184,7 +1207,7 @@ /* Call up to the OS service layer to handle this */ - AcpiOsSignal (ACPI_SIGNAL_BREAKPOINT, "Executed AML Breakpoint opcode"); + Status = AcpiOsSignal (ACPI_SIGNAL_BREAKPOINT, "Executed AML Breakpoint opcode"); /* If and when it returns, all done. */ @@ -1217,7 +1240,7 @@ /* Return status depending on opcode */ - if (Op->Opcode == AML_BREAK_OP) + if (Op->Common.AmlOpcode == AML_BREAK_OP) { Status = AE_CTRL_BREAK; } @@ -1231,7 +1254,7 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown control opcode=%X Op=%p\n", - Op->Opcode, Op)); + Op->Common.AmlOpcode, Op)); Status = AE_AML_BAD_OPCODE; break; Index: dsutils.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dsutils.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 dsutils.c --- dsutils.c 30 Jun 2002 17:50:43 -0000 1.1.1.14 +++ dsutils.c 1 Jul 2002 21:39:53 -0000 @@ -167,7 +167,7 @@ * method is parsed separately) However, a method that is * invoked from another method has a parent. */ - if (!Op->Parent) + if (!Op->Common.Parent) { return_VALUE (FALSE); } @@ -175,7 +175,7 @@ /* * Get info on the parent. The root Op is AML_SCOPE */ - ParentInfo = AcpiPsGetOpcodeInfo (Op->Parent->Opcode); + ParentInfo = AcpiPsGetOpcodeInfo (Op->Common.Parent->Common.AmlOpcode); if (ParentInfo->Class == AML_CLASS_UNKNOWN) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown parent opcode. Op=%p\n", Op)); @@ -192,7 +192,7 @@ { case AML_CLASS_CONTROL: - switch (Op->Parent->Opcode) + switch (Op->Common.Parent->Common.AmlOpcode) { case AML_RETURN_OP: @@ -212,6 +212,11 @@ { goto ResultUsed; } + break; + + default: + /* Ignore other control opcodes */ + break; } /* The general control opcode returns no result */ @@ -230,12 +235,12 @@ case AML_CLASS_NAMED_OBJECT: - if ((Op->Parent->Opcode == AML_REGION_OP) || - (Op->Parent->Opcode == AML_DATA_REGION_OP) || - (Op->Parent->Opcode == AML_PACKAGE_OP) || - (Op->Parent->Opcode == AML_VAR_PACKAGE_OP) || - (Op->Parent->Opcode == AML_BUFFER_OP) || - (Op->Parent->Opcode == AML_INT_EVAL_SUBTREE_OP)) + if ((Op->Common.Parent->Common.AmlOpcode == AML_REGION_OP) || + (Op->Common.Parent->Common.AmlOpcode == AML_DATA_REGION_OP) || + (Op->Common.Parent->Common.AmlOpcode == AML_PACKAGE_OP) || + (Op->Common.Parent->Common.AmlOpcode == AML_VAR_PACKAGE_OP) || + (Op->Common.Parent->Common.AmlOpcode == AML_BUFFER_OP) || + (Op->Common.Parent->Common.AmlOpcode == AML_INT_EVAL_SUBTREE_OP)) { /* * These opcodes allow TermArg(s) as operands and therefore @@ -259,16 +264,16 @@ ResultUsed: ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Result of [%s] used by Parent [%s] Op=%p\n", - AcpiPsGetOpcodeName (Op->Opcode), - AcpiPsGetOpcodeName (Op->Parent->Opcode), Op)); + AcpiPsGetOpcodeName (Op->Common.AmlOpcode), + AcpiPsGetOpcodeName (Op->Common.Parent->Common.AmlOpcode), Op)); return_VALUE (TRUE); ResultNotUsed: ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Result of [%s] not used by Parent [%s] Op=%p\n", - AcpiPsGetOpcodeName (Op->Opcode), - AcpiPsGetOpcodeName (Op->Parent->Opcode), Op)); + AcpiPsGetOpcodeName (Op->Common.AmlOpcode), + AcpiPsGetOpcodeName (Op->Common.Parent->Common.AmlOpcode), Op)); return_VALUE (FALSE); @@ -356,6 +361,7 @@ UINT32 ArgIndex) { ACPI_STATUS Status = AE_OK; + ACPI_STATUS Status2; NATIVE_CHAR *NameString; UINT32 NameLength; ACPI_OPERAND_OBJECT *ObjDesc; @@ -371,14 +377,14 @@ /* A valid name must be looked up in the namespace */ - if ((Arg->Opcode == AML_INT_NAMEPATH_OP) && - (Arg->Value.String)) + if ((Arg->Common.AmlOpcode == AML_INT_NAMEPATH_OP) && + (Arg->Common.Value.String)) { ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Getting a name: Arg=%p\n", Arg)); /* Get the entire name string from the AML stream */ - Status = AcpiExGetNameString (ACPI_TYPE_ANY, Arg->Value.Buffer, + Status = AcpiExGetNameString (ACPI_TYPE_ANY, Arg->Common.Value.Buffer, &NameString, &NameLength); if (ACPI_FAILURE (Status)) @@ -397,12 +403,12 @@ * IMODE_EXECUTE) in order to support the creation of * namespace objects during the execution of control methods. */ - ParentOp = Arg->Parent; - OpInfo = AcpiPsGetOpcodeInfo (ParentOp->Opcode); + ParentOp = Arg->Common.Parent; + OpInfo = AcpiPsGetOpcodeInfo (ParentOp->Common.AmlOpcode); if ((OpInfo->Flags & AML_NSNODE) && - (ParentOp->Opcode != AML_INT_METHODCALL_OP) && - (ParentOp->Opcode != AML_REGION_OP) && - (ParentOp->Opcode != AML_INT_NAMEPATH_OP)) + (ParentOp->Common.AmlOpcode != AML_INT_METHODCALL_OP) && + (ParentOp->Common.AmlOpcode != AML_REGION_OP) && + (ParentOp->Common.AmlOpcode != AML_INT_NAMEPATH_OP)) { /* Enter name into namespace if not found */ @@ -420,14 +426,14 @@ ACPI_TYPE_ANY, InterpreterMode, ACPI_NS_SEARCH_PARENT | ACPI_NS_DONT_OPEN_SCOPE, WalkState, - (ACPI_NAMESPACE_NODE **) &ObjDesc); + ACPI_CAST_INDIRECT_PTR (ACPI_NAMESPACE_NODE, &ObjDesc)); /* * The only case where we pass through (ignore) a NOT_FOUND * error is for the CondRefOf opcode. */ if (Status == AE_NOT_FOUND) { - if (ParentOp->Opcode == AML_COND_REF_OF_OP) + if (ParentOp->Common.AmlOpcode == AML_COND_REF_OF_OP) { /* * For the Conditional Reference op, it's OK if @@ -435,7 +441,7 @@ * indicate this to the interpreter, set the * object to the root */ - ObjDesc = (ACPI_OPERAND_OBJECT *) AcpiGbl_RootNode; + ObjDesc = ACPI_CAST_PTR (ACPI_OPERAND_OBJECT, AcpiGbl_RootNode); Status = AE_OK; } @@ -448,10 +454,13 @@ Status = AE_AML_NAME_NOT_FOUND; Name = NULL; - AcpiNsExternalizeName (ACPI_UINT32_MAX, NameString, NULL, &Name); - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, - "Object name [%s] was not found in namespace\n", Name)); - ACPI_MEM_FREE (Name); + Status2 = AcpiNsExternalizeName (ACPI_UINT32_MAX, NameString, NULL, &Name); + if (ACPI_SUCCESS (Status2)) + { + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, + "Object name [%s] was not found in namespace\n", Name)); + ACPI_MEM_FREE (Name); + } } } @@ -481,13 +490,13 @@ { /* Check for null name case */ - if (Arg->Opcode == AML_INT_NAMEPATH_OP) + if (Arg->Common.AmlOpcode == AML_INT_NAMEPATH_OP) { /* * If the name is null, this means that this is an * optional result parameter that was not specified - * in the original ASL. Create an Reference for a - * placeholder + * in the original ASL. Create a Zero Constant for a + * placeholder. (Store to a constant is a Noop.) */ Opcode = AML_ZERO_OP; /* Has no arguments! */ @@ -496,7 +505,7 @@ else { - Opcode = Arg->Opcode; + Opcode = Arg->Common.AmlOpcode; } /* Get the object type of the argument */ @@ -531,7 +540,6 @@ return_ACPI_STATUS (Status); } } - else { /* Create an ACPI_INTERNAL_OBJECT for the argument */ @@ -551,7 +559,7 @@ AcpiUtDeleteObjectDesc (ObjDesc); return_ACPI_STATUS (Status); } - } + } /* Put the operand object on the object stack */ @@ -611,7 +619,7 @@ /* Move on to next argument, if any */ - Arg = Arg->Next; + Arg = Arg->Common.Next; ArgCount++; } @@ -624,7 +632,7 @@ * pop everything off of the operand stack and delete those * objects */ - AcpiDsObjStackPopAndDelete (ArgCount, WalkState); + (void) AcpiDsObjStackPopAndDelete (ArgCount, WalkState); ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "While creating Arg %d - %s\n", (ArgCount + 1), AcpiFormatException (Status))); Index: dswexec.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dswexec.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 dswexec.c --- dswexec.c 30 Jun 2002 17:50:43 -0000 1.1.1.14 +++ dswexec.c 1 Jul 2002 21:39:53 -0000 @@ -132,7 +132,7 @@ /* * Dispatch table for opcode classes */ -ACPI_EXECUTE_OP AcpiGbl_OpTypeDispatch [] = { +static ACPI_EXECUTE_OP AcpiGbl_OpTypeDispatch [] = { AcpiExOpcode_1A_0T_0R, AcpiExOpcode_1A_0T_1R, AcpiExOpcode_1A_1T_0R, @@ -212,11 +212,11 @@ * Result of predicate evaluation currently must * be a number */ - if (ObjDesc->Common.Type != ACPI_TYPE_INTEGER) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_INTEGER) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Bad predicate (not a number) ObjDesc=%p State=%p Type=%X\n", - ObjDesc, WalkState, ObjDesc->Common.Type)); + ObjDesc, WalkState, ACPI_GET_OBJECT_TYPE (ObjDesc))); Status = AE_AML_OPERAND_TYPE; goto Cleanup; @@ -224,7 +224,7 @@ /* Truncate the predicate to 32-bits if necessary */ - AcpiExTruncateFor32bitTable (ObjDesc, WalkState); + AcpiExTruncateFor32bitTable (ObjDesc); /* * Save the result of the predicate evaluation on @@ -304,14 +304,19 @@ Op = *OutOp; WalkState->Op = Op; - WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); - WalkState->Opcode = Op->Opcode; + WalkState->Opcode = Op->Common.AmlOpcode; + WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); if (AcpiNsOpensScope (WalkState->OpInfo->ObjectType)) { ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "(%s) Popping scope for Op %p\n", AcpiUtGetTypeName (WalkState->OpInfo->ObjectType), Op)); - AcpiDsScopeStackPop (WalkState); + + Status = AcpiDsScopeStackPop (WalkState); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } } } @@ -349,7 +354,7 @@ /* We want to send namepaths to the load code */ - if (Op->Opcode == AML_INT_NAMEPATH_OP) + if (Op->Common.AmlOpcode == AML_INT_NAMEPATH_OP) { OpcodeClass = AML_CLASS_NAMED_OBJECT; } @@ -385,7 +390,7 @@ Status = AcpiDsLoad2BeginOp (WalkState, NULL); } - if (Op->Opcode == AML_REGION_OP) + if (Op->Common.AmlOpcode == AML_REGION_OP) { Status = AcpiDsResultStackPush (WalkState); } @@ -451,11 +456,11 @@ if (OpClass == AML_CLASS_UNKNOWN) { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown opcode %X\n", Op->Opcode)); + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown opcode %X\n", Op->Common.AmlOpcode)); return_ACPI_STATUS (AE_NOT_IMPLEMENTED); } - FirstArg = Op->Value.Arg; + FirstArg = Op->Common.Value.Arg; /* Init the walk state */ @@ -555,8 +560,12 @@ /* 1 Operand, 0 ExternalResult, 0 InternalResult */ Status = AcpiDsExecEndControlOp (WalkState, Op); + if (ACPI_FAILURE (Status)) + { + break; + } - AcpiDsResultStackPop (WalkState); + Status = AcpiDsResultStackPop (WalkState); break; @@ -574,7 +583,7 @@ /* NextOp points to first argument op */ - NextOp = NextOp->Next; + NextOp = NextOp->Common.Next; /* * Get the method's arguments and put them on the operand stack @@ -629,7 +638,7 @@ ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Executing CreateObject (Buffer/Package) Op=%p\n", Op)); - switch (Op->Parent->Opcode) + switch (Op->Common.Parent->Common.AmlOpcode) { case AML_NAME_OP: @@ -637,20 +646,22 @@ * Put the Node on the object stack (Contains the ACPI Name of * this object) */ - WalkState->Operands[0] = (void *) Op->Parent->Node; + WalkState->Operands[0] = (void *) Op->Common.Parent->Common.Node; WalkState->NumOperands = 1; - Status = AcpiDsCreateNode (WalkState, Op->Parent->Node, Op->Parent); + Status = AcpiDsCreateNode (WalkState, Op->Common.Parent->Common.Node, Op->Common.Parent); if (ACPI_FAILURE (Status)) { break; } /* Fall through */ + /*lint -fallthrough */ case AML_INT_EVAL_SUBTREE_OP: - Status = AcpiDsEvalDataObjectOperands (WalkState, Op, AcpiNsGetAttachedObject (Op->Parent->Node)); + Status = AcpiDsEvalDataObjectOperands (WalkState, Op, + AcpiNsGetAttachedObject (Op->Common.Parent->Common.Node)); break; default: @@ -682,7 +693,7 @@ break; } - if (Op->Opcode == AML_REGION_OP) + if (Op->Common.AmlOpcode == AML_REGION_OP) { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Executing OpRegion Address/Length Op=%p\n", Op)); @@ -717,7 +728,7 @@ ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unimplemented opcode, class=%X type=%X Opcode=%X Op=%p\n", - OpClass, OpType, Op->Opcode, Op)); + OpClass, OpType, Op->Common.AmlOpcode, Op)); Status = AE_NOT_IMPLEMENTED; break; @@ -728,7 +739,7 @@ * ACPI 2.0 support for 64-bit integers: Truncate numeric * result value if we are executing from a 32-bit ACPI table */ - AcpiExTruncateFor32bitTable (WalkState->ResultObj, WalkState); + AcpiExTruncateFor32bitTable (WalkState->ResultObj); /* * Check if we just completed the evaluation of a Index: dswload.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dswload.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 dswload.c --- dswload.c 30 Jun 2002 17:50:43 -0000 1.1.1.13 +++ dswload.c 1 Jul 2002 21:39:53 -0000 @@ -208,16 +208,16 @@ ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Op=%p State=%p\n", Op, WalkState)); - if (Op && (Op->Opcode == AML_INT_NAMEDFIELD_OP)) + if (Op && (Op->Common.AmlOpcode == AML_INT_NAMEDFIELD_OP)) { ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Op=%p State=%p\n", Op, WalkState)); } /* We are only interested in opcodes that have an associated name */ - if (WalkState->Op) + if (Op) { - if (!(WalkState->OpInfo->Flags & AML_NAMED)) + if (!(WalkState->OpInfo->Flags & AML_NAMED)) { *OutOp = Op; return (AE_OK); @@ -225,7 +225,7 @@ /* Check if this object has already been installed in the namespace */ - if (Op->Node) + if (Op->Common.Node) { *OutOp = Op; return (AE_OK); @@ -239,7 +239,7 @@ ObjectType = WalkState->OpInfo->ObjectType; ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, - "State=%p Op=%p Type=%x\n", WalkState, Op, ObjectType)); + "State=%p Op=%p Type=%X\n", WalkState, Op, ObjectType)); /* * Enter the named type into the internal namespace. We enter the name @@ -267,13 +267,13 @@ /* Initialize */ - ((ACPI_PARSE2_OBJECT *)Op)->Name = Node->Name.Integer; + Op->Named.Name = Node->Name.Integer; /* * Put the Node in the "op" object that the parser uses, so we * can get it again quickly when this scope is closed */ - Op->Node = Node; + Op->Common.Node = Node; AcpiPsAppendArg (AcpiPsGetParentScope (&WalkState->ParserState), Op); *OutOp = Op; @@ -302,6 +302,7 @@ { ACPI_PARSE_OBJECT *Op; ACPI_OBJECT_TYPE ObjectType; + ACPI_STATUS Status = AE_OK; ACPI_FUNCTION_NAME ("DsLoad1EndOp"); @@ -327,27 +328,30 @@ WalkState->Opcode == AML_BANK_FIELD_OP || WalkState->Opcode == AML_INDEX_FIELD_OP) { - AcpiDsInitFieldObjects (Op, WalkState); + Status = AcpiDsInitFieldObjects (Op, WalkState); } - return (AE_OK); + return (Status); } - if (Op->Opcode == AML_REGION_OP) + if (Op->Common.AmlOpcode == AML_REGION_OP) { - /*Status = */AcpiExCreateRegion (((ACPI_PARSE2_OBJECT *) Op)->Data, - ((ACPI_PARSE2_OBJECT *) Op)->Length, - (ACPI_ADR_SPACE_TYPE) ((Op->Value.Arg)->Value.Integer), WalkState); + Status = AcpiExCreateRegion (Op->Named.Data, Op->Named.Length, + (ACPI_ADR_SPACE_TYPE) ((Op->Common.Value.Arg)->Common.Value.Integer), WalkState); + if (ACPI_FAILURE (Status)) + { + return (Status); + } } - if (Op->Opcode == AML_NAME_OP) + if (Op->Common.AmlOpcode == AML_NAME_OP) { /* For Name opcode, get the object type from the argument */ - if (Op->Value.Arg) + if (Op->Common.Value.Arg) { - ObjectType = (AcpiPsGetOpcodeInfo ((Op->Value.Arg)->Opcode))->ObjectType; - Op->Node->Type = (UINT8) ObjectType; + ObjectType = (AcpiPsGetOpcodeInfo ((Op->Common.Value.Arg)->Common.AmlOpcode))->ObjectType; + Op->Common.Node->Type = (UINT8) ObjectType; } } @@ -358,10 +362,10 @@ ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "(%s): Popping scope for Op %p\n", AcpiUtGetTypeName (ObjectType), Op)); - AcpiDsScopeStackPop (WalkState); + Status = AcpiDsScopeStackPop (WalkState); } - return (AE_OK); + return (Status); } @@ -389,7 +393,6 @@ ACPI_STATUS Status; ACPI_OBJECT_TYPE ObjectType; NATIVE_CHAR *BufferPtr; - void *Original = NULL; ACPI_FUNCTION_NAME ("DsLoad2BeginOp"); @@ -415,7 +418,7 @@ { /* For Namepath op, get the path string */ - BufferPtr = Op->Value.String; + BufferPtr = Op->Common.Value.String; if (!BufferPtr) { /* No name, just exit */ @@ -427,7 +430,7 @@ { /* Get name from the op */ - BufferPtr = (NATIVE_CHAR *) &((ACPI_PARSE2_OBJECT *)Op)->Name; + BufferPtr = (NATIVE_CHAR *) &Op->Named.Name; } } else @@ -442,7 +445,7 @@ ObjectType = WalkState->OpInfo->ObjectType; ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, - "State=%p Op=%p Type=%x\n", WalkState, Op, ObjectType)); + "State=%p Op=%p Type=%X\n", WalkState, Op, ObjectType)); if (WalkState->Opcode == AML_FIELD_OP || @@ -463,10 +466,13 @@ } else { - if (Op && Op->Node) + /* All other opcodes */ + + if (Op && Op->Common.Node) { - Original = Op->Node; - Node = Op->Node; + /* This op/node was previously entered into the namespace */ + + Node = Op->Common.Node; if (AcpiNsOpensScope (ObjectType)) { @@ -503,26 +509,21 @@ /* Initialize the new op */ - ((ACPI_PARSE2_OBJECT *)Op)->Name = Node->Name.Integer; - *OutOp = Op; + if (Node) + { + Op->Named.Name = Node->Name.Integer; + } + if (OutOp) + { + *OutOp = Op; + } } /* * Put the Node in the "op" object that the parser uses, so we * can get it again quickly when this scope is closed */ - Op->Node = Node; - - if (Original) - { - ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "old %p new %p\n", Original, Node)); - - if (Original != Node) - { - ACPI_DEBUG_PRINT ((ACPI_DB_INFO, - "Lookup match error: old %p new %p\n", Original, Node)); - } - } + Op->Common.Node = Node; } return (Status); @@ -570,12 +571,12 @@ return (AE_OK); } - if (Op->Opcode == AML_SCOPE_OP) + if (Op->Common.AmlOpcode == AML_SCOPE_OP) { ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Ending scope Op=%p State=%p\n", Op, WalkState)); - if (((ACPI_PARSE2_OBJECT *)Op)->Name == ACPI_UINT16_MAX) + if (Op->Named.Name == ACPI_UINT16_MAX) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unnamed scope! Op=%p State=%p\n", Op, WalkState)); @@ -590,7 +591,7 @@ * Get the Node/name from the earlier lookup * (It was saved in the *op structure) */ - Node = Op->Node; + Node = Op->Common.Node; /* * Put the Node on the object stack (Contains the ACPI Name of @@ -605,7 +606,12 @@ { ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "(%s) Popping scope for Op %p\n", AcpiUtGetTypeName (ObjectType), Op)); - AcpiDsScopeStackPop (WalkState); + + Status = AcpiDsScopeStackPop (WalkState); + if (ACPI_FAILURE (Status)) + { + return (Status); + } } /* @@ -638,11 +644,11 @@ ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, "Create-Load [%s] State=%p Op=%p NamedObj=%p\n", - AcpiPsGetOpcodeName (Op->Opcode), WalkState, Op, Node)); + AcpiPsGetOpcodeName (Op->Common.AmlOpcode), WalkState, Op, Node)); /* Decode the opcode */ - Arg = Op->Value.Arg; + Arg = Op->Common.Value.Arg; switch (WalkState->OpInfo->Type) { @@ -658,22 +664,26 @@ case AML_TYPE_NAMED_FIELD: - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_INDEX_FIELD_OP: - Status = AcpiDsCreateIndexField (Op, (ACPI_HANDLE) Arg->Node, + Status = AcpiDsCreateIndexField (Op, (ACPI_HANDLE) Arg->Common.Node, WalkState); break; case AML_BANK_FIELD_OP: - Status = AcpiDsCreateBankField (Op, Arg->Node, WalkState); + Status = AcpiDsCreateBankField (Op, Arg->Common.Node, WalkState); break; case AML_FIELD_OP: - Status = AcpiDsCreateField (Op, Arg->Node, WalkState); + Status = AcpiDsCreateField (Op, Arg->Common.Node, WalkState); + break; + + default: + /* All NAMED_FIELD opcodes must be handled above */ break; } break; @@ -687,7 +697,7 @@ goto Cleanup; } - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_PROCESSOR_OP: @@ -739,7 +749,7 @@ case AML_TYPE_NAMED_COMPLEX: - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_METHOD_OP: /* @@ -757,9 +767,8 @@ goto Cleanup; } - Status = AcpiExCreateMethod (((ACPI_PARSE2_OBJECT *) Op)->Data, - ((ACPI_PARSE2_OBJECT *) Op)->Length, - WalkState); + Status = AcpiExCreateMethod (Op->Named.Data, + Op->Named.Length, WalkState); } break; @@ -793,6 +802,11 @@ Status = AcpiDsCreateNode (WalkState, Node, Op); break; + + + default: + /* All NAMED_COMPLEX opcodes must be handled above */ + break; } break; @@ -812,7 +826,7 @@ /* * Lookup the method name and save the Node */ - Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Value.String, + Status = AcpiNsLookup (WalkState->ScopeInfo, Arg->Common.Value.String, ACPI_TYPE_ANY, ACPI_IMODE_LOAD_PASS2, ACPI_NS_SEARCH_PARENT | ACPI_NS_DONT_OPEN_SCOPE, WalkState, &(NewNode)); @@ -831,7 +845,7 @@ * for now, we will put it in the "op" object that the parser uses, so we * can get it again at the end of this scope */ - Op->Node = NewNode; + Op->Common.Node = NewNode; } break; Index: dswstate.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/dswstate.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 dswstate.c --- dswstate.c 23 Feb 2002 05:10:35 -0000 1.1.1.12 +++ dswstate.c 1 Jul 2002 21:39:53 -0000 @@ -118,11 +118,9 @@ #define __DSWSTATE_C__ #include "acpi.h" -#include "amlcode.h" #include "acparser.h" #include "acdispat.h" #include "acnamesp.h" -#include "acinterp.h" #define _COMPONENT ACPI_DISPATCHER ACPI_MODULE_NAME ("dswstate") @@ -182,7 +180,7 @@ ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Obj=%p [%s] State=%p Num=%X Cur=%X\n", - Object, Object ? AcpiUtGetTypeName (((ACPI_OPERAND_OBJECT *) Object)->Common.Type) : "NULL", + Object, Object ? AcpiUtGetObjectTypeName ((ACPI_OPERAND_OBJECT *) Object) : "NULL", WalkState, State->Results.NumResults, WalkState->CurrentResult)); return (AE_OK); @@ -223,14 +221,13 @@ return (AE_NOT_EXIST); } - if (Index >= OBJ_NUM_OPERANDS) + if (Index >= OBJ_MAX_OPERAND) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Index out of range: %X State=%p Num=%X\n", Index, WalkState, State->Results.NumResults)); } - /* Check for a valid result object */ if (!State->Results.ObjDesc [Index]) @@ -250,7 +247,7 @@ ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Obj=%p [%s] Index=%X State=%p Num=%X\n", - *Object, (*Object) ? AcpiUtGetTypeName ((*Object)->Common.Type) : "NULL", + *Object, (*Object) ? AcpiUtGetObjectTypeName (*Object) : "NULL", Index, WalkState, State->Results.NumResults)); return (AE_OK); @@ -310,7 +307,7 @@ State->Results.ObjDesc [Index -1] = NULL; ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Obj=%p [%s] Index=%X State=%p Num=%X\n", - *Object, (*Object) ? AcpiUtGetTypeName ((*Object)->Common.Type) : "NULL", + *Object, (*Object) ? AcpiUtGetObjectTypeName (*Object) : "NULL", Index -1, WalkState, State->Results.NumResults)); return (AE_OK); @@ -340,7 +337,7 @@ ACPI_OPERAND_OBJECT **Object, ACPI_WALK_STATE *WalkState) { - UINT32 Index; + NATIVE_UINT Index; ACPI_GENERIC_STATE *State; @@ -355,7 +352,6 @@ return (AE_NOT_EXIST); } - if (!State->Results.NumResults) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "No result objects! State=%p\n", WalkState)); @@ -380,12 +376,12 @@ if (!*Object) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Null operand! State=%p #Ops=%X, Index=%X\n", - WalkState, State->Results.NumResults, Index)); + WalkState, State->Results.NumResults, (UINT32) Index)); return (AE_AML_NO_RETURN_VALUE); } ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Obj=%p [%s], Results=%p State=%p\n", - *Object, (*Object) ? AcpiUtGetTypeName ((*Object)->Common.Type) : "NULL", + *Object, (*Object) ? AcpiUtGetObjectTypeName (*Object) : "NULL", State, WalkState)); @@ -439,12 +435,11 @@ return (AE_BAD_PARAMETER); } - State->Results.ObjDesc [State->Results.NumResults] = Object; State->Results.NumResults++; ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Obj=%p [%s] State=%p Num=%X Cur=%X\n", - Object, Object ? AcpiUtGetTypeName (((ACPI_OPERAND_OBJECT *) Object)->Common.Type) : "NULL", + Object, Object ? AcpiUtGetObjectTypeName ((ACPI_OPERAND_OBJECT *) Object) : "NULL", WalkState, State->Results.NumResults, WalkState->CurrentResult)); return (AE_OK); @@ -607,7 +602,7 @@ WalkState->NumOperands++; ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Obj=%p [%s] State=%p #Ops=%X\n", - Object, AcpiUtGetTypeName (((ACPI_OPERAND_OBJECT *) Object)->Common.Type), + Object, AcpiUtGetObjectTypeName ((ACPI_OPERAND_OBJECT *) Object), WalkState, WalkState->NumOperands)); return (AE_OK); @@ -669,7 +664,7 @@ WalkState->Operands [WalkState->NumOperands] = NULL; ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Obj=%p [%s] State=%p #Ops=%X\n", - *Object, AcpiUtGetTypeName ((*Object)->Common.Type), + *Object, AcpiUtGetObjectTypeName (*Object), WalkState, WalkState->NumOperands)); return (AE_OK); @@ -818,7 +813,6 @@ return_PTR (NULL); } - return_PTR (WalkState->Operands[(NATIVE_UINT)(WalkState->NumOperands - 1) - Index]); } @@ -853,7 +847,6 @@ ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, "DsGetCurrentWalkState, =%p\n", Thread->WalkStateList)); - return (Thread->WalkStateList); } @@ -1049,7 +1042,6 @@ WalkState->MethodNode = MethodNode; WalkState->MethodDesc = AcpiNsGetAttachedObject (MethodNode); - /* Push start scope on scope stack and make it current */ Status = AcpiDsScopeStackPush (MethodNode, ACPI_TYPE_METHOD, WalkState); @@ -1060,14 +1052,17 @@ /* Init the method arguments */ - AcpiDsMethodDataInitArgs (Params, MTH_NUM_ARGS, WalkState); + Status = AcpiDsMethodDataInitArgs (Params, MTH_NUM_ARGS, WalkState); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } } - else { /* Setup the current scope */ - ParserState->StartNode = ParserState->StartOp->Node; + ParserState->StartNode = ParserState->StartOp->Common.Node; if (ParserState->StartNode) { /* Push start scope on scope stack and make it current */ @@ -1081,9 +1076,8 @@ } } - AcpiDsInitCallbacks (WalkState, PassNumber); - - return_ACPI_STATUS (AE_OK); + Status = AcpiDsInitCallbacks (WalkState, PassNumber); + return_ACPI_STATUS (Status); } #endif @@ -1120,7 +1114,6 @@ ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "%p is not a valid walk state\n", WalkState)); return; } - if (WalkState->ParserState.Scope) { Index: evevent.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/evevent.c,v retrieving revision 1.1.1.16 diff -u -r1.1.1.16 evevent.c --- evevent.c 30 Jun 2002 17:50:41 -0000 1.1.1.16 +++ evevent.c 1 Jul 2002 21:39:53 -0000 @@ -115,7 +115,6 @@ *****************************************************************************/ #include "acpi.h" -#include "achware.h" #include "acevents.h" #include "acnamesp.h" @@ -256,6 +255,7 @@ void) { NATIVE_UINT i; + ACPI_STATUS Status; /* @@ -271,8 +271,12 @@ if (AcpiGbl_FixedEventInfo[i].EnableRegisterId != 0xFF) { - AcpiHwBitRegisterWrite (AcpiGbl_FixedEventInfo[i].EnableRegisterId, + Status = AcpiSetRegister (AcpiGbl_FixedEventInfo[i].EnableRegisterId, 0, ACPI_MTX_LOCK); + if (ACPI_FAILURE (Status)) + { + return (Status); + } } } @@ -299,7 +303,7 @@ UINT32 IntStatus = ACPI_INTERRUPT_NOT_HANDLED; UINT32 GpeStatus; UINT32 GpeEnable; - NATIVE_UINT i; + NATIVE_UINT_MAX32 i; ACPI_FUNCTION_NAME ("EvFixedEventDetect"); @@ -307,10 +311,10 @@ /* * Read the fixed feature status and enable registers, as all the cases - * depend on their values. + * depend on their values. Ignore errors here. */ - GpeStatus = AcpiHwRegisterRead (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM1_STATUS); - GpeEnable = AcpiHwRegisterRead (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM1_ENABLE); + (void) AcpiHwRegisterRead (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM1_STATUS, &GpeStatus); + (void) AcpiHwRegisterRead (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM1_ENABLE, &GpeEnable); ACPI_DEBUG_PRINT ((ACPI_DB_INTERRUPTS, "Fixed AcpiEvent Block: Enable %08X Status %08X\n", @@ -360,7 +364,7 @@ /* Clear the status bit */ - AcpiHwBitRegisterWrite (AcpiGbl_FixedEventInfo[Event].StatusRegisterId, + (void) AcpiSetRegister (AcpiGbl_FixedEventInfo[Event].StatusRegisterId, 1, ACPI_MTX_DO_NOT_LOCK); /* @@ -369,7 +373,7 @@ */ if (NULL == AcpiGbl_FixedEventHandlers[Event].Handler) { - AcpiHwBitRegisterWrite (AcpiGbl_FixedEventInfo[Event].EnableRegisterId, + (void) AcpiSetRegister (AcpiGbl_FixedEventInfo[Event].EnableRegisterId, 0, ACPI_MTX_DO_NOT_LOCK); ACPI_REPORT_ERROR ( @@ -401,13 +405,14 @@ ACPI_STATUS AcpiEvGpeInitialize (void) { - NATIVE_UINT i; - NATIVE_UINT j; - NATIVE_UINT GpeBlock; + NATIVE_UINT_MAX32 i; + NATIVE_UINT_MAX32 j; + UINT32 GpeBlock; UINT32 GpeRegister; UINT32 GpeNumberIndex; UINT32 GpeNumber; ACPI_GPE_REGISTER_INFO *GpeRegisterInfo; + ACPI_STATUS Status; ACPI_FUNCTION_TRACE ("EvGpeInitialize"); @@ -478,8 +483,9 @@ /* * Allocate the GPE number-to-index translation table */ - AcpiGbl_GpeNumberToIndex = ACPI_MEM_CALLOCATE (sizeof (ACPI_GPE_INDEX_INFO) * - (AcpiGbl_GpeNumberMax + 1)); + AcpiGbl_GpeNumberToIndex = ACPI_MEM_CALLOCATE ( + sizeof (ACPI_GPE_INDEX_INFO) * + ((ACPI_SIZE) AcpiGbl_GpeNumberMax + 1)); if (!AcpiGbl_GpeNumberToIndex) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, @@ -490,12 +496,13 @@ /* Set the Gpe index table to GPE_INVALID */ ACPI_MEMSET (AcpiGbl_GpeNumberToIndex, (int) ACPI_GPE_INVALID, - sizeof (ACPI_GPE_INDEX_INFO) * (AcpiGbl_GpeNumberMax + 1)); + sizeof (ACPI_GPE_INDEX_INFO) * ((ACPI_SIZE) AcpiGbl_GpeNumberMax + 1)); /* * Allocate the GPE register information block */ - AcpiGbl_GpeRegisterInfo = ACPI_MEM_CALLOCATE (AcpiGbl_GpeRegisterCount * + AcpiGbl_GpeRegisterInfo = ACPI_MEM_CALLOCATE ( + (ACPI_SIZE) AcpiGbl_GpeRegisterCount * sizeof (ACPI_GPE_REGISTER_INFO)); if (!AcpiGbl_GpeRegisterInfo) { @@ -508,8 +515,9 @@ * Allocate the GPE dispatch handler block. There are eight distinct GPEs * per register. Initialization to zeros is sufficient. */ - AcpiGbl_GpeNumberInfo = ACPI_MEM_CALLOCATE (ACPI_MUL_8 (AcpiGbl_GpeRegisterCount) * - sizeof (ACPI_GPE_NUMBER_INFO)); + AcpiGbl_GpeNumberInfo = ACPI_MEM_CALLOCATE ( + (ACPI_SIZE) ACPI_MUL_8 (AcpiGbl_GpeRegisterCount) * + sizeof (ACPI_GPE_NUMBER_INFO)); if (!AcpiGbl_GpeNumberInfo) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Could not allocate the GpeNumberInfo table\n")); @@ -534,14 +542,17 @@ /* Init the Register info for this entire GPE register (8 GPEs) */ - GpeRegisterInfo->BaseGpeNumber = (UINT8) (AcpiGbl_GpeBlockInfo[GpeBlock].BlockBaseNumber + (ACPI_MUL_8 (i))); + GpeRegisterInfo->BaseGpeNumber = (UINT8) (AcpiGbl_GpeBlockInfo[GpeBlock].BlockBaseNumber + + (ACPI_MUL_8 (i))); ACPI_STORE_ADDRESS (GpeRegisterInfo->StatusAddress.Address, - (ACPI_GET_ADDRESS (AcpiGbl_GpeBlockInfo[GpeBlock].BlockAddress->Address) + i)); + (ACPI_GET_ADDRESS (AcpiGbl_GpeBlockInfo[GpeBlock].BlockAddress->Address) + + i)); ACPI_STORE_ADDRESS (GpeRegisterInfo->EnableAddress.Address, - (ACPI_GET_ADDRESS (AcpiGbl_GpeBlockInfo[GpeBlock].BlockAddress->Address) + i + - AcpiGbl_GpeBlockInfo[GpeBlock].RegisterCount)); + (ACPI_GET_ADDRESS (AcpiGbl_GpeBlockInfo[GpeBlock].BlockAddress->Address) + + i + + AcpiGbl_GpeBlockInfo[GpeBlock].RegisterCount)); GpeRegisterInfo->StatusAddress.AddressSpaceId = AcpiGbl_GpeBlockInfo[GpeBlock].AddressSpaceId; GpeRegisterInfo->EnableAddress.AddressSpaceId = AcpiGbl_GpeBlockInfo[GpeBlock].AddressSpaceId; @@ -567,19 +578,28 @@ * by writing a '0'. */ - AcpiHwLowLevelWrite (8, 0x00, &GpeRegisterInfo->EnableAddress, 0); - AcpiHwLowLevelWrite (8, 0xFF, &GpeRegisterInfo->StatusAddress, 0); + Status = AcpiHwLowLevelWrite (8, 0x00, &GpeRegisterInfo->EnableAddress, 0); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + + Status = AcpiHwLowLevelWrite (8, 0xFF, &GpeRegisterInfo->StatusAddress, 0); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } GpeRegister++; } ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "GPE Block%d: %X registers at %8.8X%8.8X\n", - GpeBlock, AcpiGbl_GpeBlockInfo[0].RegisterCount, - ACPI_HIDWORD (AcpiGbl_GpeBlockInfo[GpeBlock].BlockAddress->Address), - ACPI_LODWORD (AcpiGbl_GpeBlockInfo[GpeBlock].BlockAddress->Address))); + (INT32) GpeBlock, AcpiGbl_GpeBlockInfo[0].RegisterCount, + ACPI_HIDWORD (ACPI_GET_ADDRESS (AcpiGbl_GpeBlockInfo[GpeBlock].BlockAddress->Address)), + ACPI_LODWORD (ACPI_GET_ADDRESS (AcpiGbl_GpeBlockInfo[GpeBlock].BlockAddress->Address)))); ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "GPE Block%d Range GPE #%2.2X to GPE #%2.2X\n", - GpeBlock, + (INT32) GpeBlock, AcpiGbl_GpeBlockInfo[GpeBlock].BlockBaseNumber, AcpiGbl_GpeBlockInfo[GpeBlock].BlockBaseNumber + ((AcpiGbl_GpeBlockInfo[GpeBlock].RegisterCount * 8) -1))); @@ -632,6 +652,7 @@ UINT32 GpeNumberIndex; NATIVE_CHAR Name[ACPI_NAME_SIZE + 1]; UINT8 Type; + ACPI_STATUS Status; ACPI_FUNCTION_NAME ("EvSaveMethodInfo"); @@ -640,7 +661,7 @@ /* Extract the name from the object and convert to a string */ ACPI_MOVE_UNALIGNED32_TO_32 (Name, - &((ACPI_NAMESPACE_NODE *) ObjHandle)->Name); + &((ACPI_NAMESPACE_NODE *) ObjHandle)->Name.Integer); Name[ACPI_NAME_SIZE] = 0; /* @@ -698,7 +719,11 @@ /* * Enable the GPE (SCIs should be disabled at this point) */ - AcpiHwEnableGpe (GpeNumber); + Status = AcpiHwEnableGpe (GpeNumber); + if (ACPI_FAILURE (Status)) + { + return (Status); + } ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "Registered GPE method %s as GPE number %X\n", Name, GpeNumber)); @@ -768,6 +793,8 @@ UINT8 EnabledStatusByte; UINT8 BitMask; ACPI_GPE_REGISTER_INFO *GpeRegisterInfo; + UINT32 InValue; + ACPI_STATUS Status; ACPI_FUNCTION_NAME ("EvGpeDetect"); @@ -782,16 +809,24 @@ { GpeRegisterInfo = &AcpiGbl_GpeRegisterInfo[i]; - GpeRegisterInfo->Status = (UINT8) AcpiHwLowLevelRead (8, - &GpeRegisterInfo->StatusAddress, 0); + Status = AcpiHwLowLevelRead (8, &InValue, &GpeRegisterInfo->StatusAddress, 0); + GpeRegisterInfo->Status = (UINT8) InValue; + if (ACPI_FAILURE (Status)) + { + return (ACPI_INTERRUPT_NOT_HANDLED); + } - GpeRegisterInfo->Enable = (UINT8) AcpiHwLowLevelRead (8, - &GpeRegisterInfo->EnableAddress, 0); + Status = AcpiHwLowLevelRead (8, &InValue, &GpeRegisterInfo->EnableAddress, 0); + GpeRegisterInfo->Enable = (UINT8) InValue; + if (ACPI_FAILURE (Status)) + { + return (ACPI_INTERRUPT_NOT_HANDLED); + } ACPI_DEBUG_PRINT ((ACPI_DB_INTERRUPTS, - "GPE block at %8.8X%8.8X - Enable %08X Status %08X\n", - ACPI_HIDWORD (GpeRegisterInfo->EnableAddress.Address), - ACPI_LODWORD (GpeRegisterInfo->EnableAddress.Address), + "GPE block at %8.8X%8.8X - Values: Enable %02X Status %02X\n", + ACPI_HIDWORD (ACPI_GET_ADDRESS (GpeRegisterInfo->EnableAddress.Address)), + ACPI_LODWORD (ACPI_GET_ADDRESS (GpeRegisterInfo->EnableAddress.Address)), GpeRegisterInfo->Enable, GpeRegisterInfo->Status)); @@ -851,6 +886,7 @@ UINT32 GpeNumber = (UINT32) ACPI_TO_INTEGER (Context); UINT32 GpeNumberIndex; ACPI_GPE_NUMBER_INFO GpeInfo; + ACPI_STATUS Status; ACPI_FUNCTION_TRACE ("EvAsynchExecuteGpeMethod"); @@ -866,13 +902,15 @@ * Take a snapshot of the GPE info for this level - we copy the * info to prevent a race condition with RemoveHandler. */ - if (ACPI_FAILURE (AcpiUtAcquireMutex (ACPI_MTX_EVENTS))) + Status = AcpiUtAcquireMutex (ACPI_MTX_EVENTS); + if (ACPI_FAILURE (Status)) { return_VOID; } GpeInfo = AcpiGbl_GpeNumberInfo [GpeNumberIndex]; - if (ACPI_FAILURE (AcpiUtReleaseMutex (ACPI_MTX_EVENTS))) + Status = AcpiUtReleaseMutex (ACPI_MTX_EVENTS); + if (ACPI_FAILURE (Status)) { return_VOID; } @@ -883,7 +921,12 @@ * Invoke the GPE Method (_Lxx, _Exx): * (Evaluate the _Lxx/_Exx control method that corresponds to this GPE.) */ - AcpiNsEvaluateByHandle (GpeInfo.MethodHandle, NULL, NULL); + Status = AcpiNsEvaluateByHandle (GpeInfo.MethodHandle, NULL, NULL); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("%s while evaluated GPE%X method\n", + AcpiFormatException (Status), GpeNumber)); + } } if (GpeInfo.Type & ACPI_EVENT_LEVEL_TRIGGERED) @@ -892,13 +935,17 @@ * GPE is level-triggered, we clear the GPE status bit after handling * the event. */ - AcpiHwClearGpe (GpeNumber); + Status = AcpiHwClearGpe (GpeNumber); + if (ACPI_FAILURE (Status)) + { + return_VOID; + } } /* * Enable the GPE. */ - AcpiHwEnableGpe (GpeNumber); + (void) AcpiHwEnableGpe (GpeNumber); return_VOID; } @@ -923,6 +970,7 @@ { UINT32 GpeNumberIndex; ACPI_GPE_NUMBER_INFO *GpeInfo; + ACPI_STATUS Status; ACPI_FUNCTION_TRACE ("EvGpeDispatch"); @@ -947,7 +995,12 @@ */ if (GpeInfo->Type & ACPI_EVENT_EDGE_TRIGGERED) { - AcpiHwClearGpe (GpeNumber); + Status = AcpiHwClearGpe (GpeNumber); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("AcpiEvGpeDispatch: Unable to clear GPE[%X]\n", GpeNumber)); + return_VALUE (ACPI_INTERRUPT_NOT_HANDLED); + } } /* @@ -969,7 +1022,12 @@ * Disable GPE, so it doesn't keep firing before the method has a * chance to run. */ - AcpiHwDisableGpe (GpeNumber); + Status = AcpiHwDisableGpe (GpeNumber); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("AcpiEvGpeDispatch: Unable to disable GPE[%X]\n", GpeNumber)); + return_VALUE (ACPI_INTERRUPT_NOT_HANDLED); + } /* * Execute the method associated with the GPE. @@ -991,7 +1049,12 @@ * Disable the GPE. The GPE will remain disabled until the ACPI * Core Subsystem is restarted, or the handler is reinstalled. */ - AcpiHwDisableGpe (GpeNumber); + Status = AcpiHwDisableGpe (GpeNumber); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("AcpiEvGpeDispatch: Unable to disable GPE[%X]\n", GpeNumber)); + return_VALUE (ACPI_INTERRUPT_NOT_HANDLED); + } } /* @@ -999,7 +1062,12 @@ */ if (GpeInfo->Type & ACPI_EVENT_LEVEL_TRIGGERED) { - AcpiHwClearGpe (GpeNumber); + Status = AcpiHwClearGpe (GpeNumber); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("AcpiEvGpeDispatch: Unable to clear GPE[%X]\n", GpeNumber)); + return_VALUE (ACPI_INTERRUPT_NOT_HANDLED); + } } return_VALUE (ACPI_INTERRUPT_HANDLED); Index: evmisc.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/evmisc.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 evmisc.c --- evmisc.c 30 Jun 2002 17:50:41 -0000 1.1.1.14 +++ evmisc.c 1 Jul 2002 21:39:53 -0000 @@ -118,7 +118,6 @@ #include "acevents.h" #include "acnamesp.h" #include "acinterp.h" -#include "achware.h" #define _COMPONENT ACPI_EVENTS ACPI_MODULE_NAME ("evmisc") @@ -273,7 +272,7 @@ } /* - * Get the notify object attached to the device Node + * Get the notify object attached to the NS Node */ ObjDesc = AcpiNsGetAttachedObject (Node); if (ObjDesc) @@ -283,29 +282,23 @@ switch (Node->Type) { case ACPI_TYPE_DEVICE: - - if (NotifyValue <= ACPI_MAX_SYS_NOTIFY) - { - HandlerObj = ObjDesc->Device.SysHandler; - } - else - { - HandlerObj = ObjDesc->Device.DrvHandler; - } - break; - - case ACPI_TYPE_THERMAL: + case ACPI_TYPE_PROCESSOR: + case ACPI_TYPE_POWER: if (NotifyValue <= ACPI_MAX_SYS_NOTIFY) { - HandlerObj = ObjDesc->ThermalZone.SysHandler; + HandlerObj = ObjDesc->CommonNotify.SysHandler; } else { - HandlerObj = ObjDesc->ThermalZone.DrvHandler; + HandlerObj = ObjDesc->CommonNotify.DrvHandler; } break; + + default: + /* All other types are not supported */ + return (AE_TYPE); } } @@ -434,6 +427,8 @@ AcpiEvGlobalLockThread ( void *Context) { + ACPI_STATUS Status; + /* Signal threads that are waiting for the lock */ @@ -441,8 +436,12 @@ { /* Send sufficient units to the semaphore */ - AcpiOsSignalSemaphore (AcpiGbl_GlobalLockSemaphore, + Status = AcpiOsSignalSemaphore (AcpiGbl_GlobalLockSemaphore, AcpiGbl_GlobalLockThreadCount); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("Could not signal Global Lock semaphore\n")); + } } } @@ -464,6 +463,7 @@ void *Context) { BOOLEAN Acquired = FALSE; + ACPI_STATUS Status; /* @@ -480,8 +480,15 @@ /* Run the Global Lock thread which will signal all waiting threads */ - AcpiOsQueueForExecution (OSD_PRIORITY_HIGH, AcpiEvGlobalLockThread, - Context); + Status = AcpiOsQueueForExecution (OSD_PRIORITY_HIGH, + AcpiEvGlobalLockThread, Context); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("Could not queue Global Lock thread, %s\n", + AcpiFormatException (Status))); + + return (ACPI_INTERRUPT_NOT_HANDLED); + } } return (ACPI_INTERRUPT_HANDLED); @@ -604,10 +611,11 @@ * ******************************************************************************/ -void +ACPI_STATUS AcpiEvReleaseGlobalLock (void) { BOOLEAN Pending = FALSE; + ACPI_STATUS Status = AE_OK; ACPI_FUNCTION_TRACE ("EvReleaseGlobalLock"); @@ -616,7 +624,7 @@ if (!AcpiGbl_GlobalLockThreadCount) { ACPI_REPORT_WARNING(("Cannot release HW Global Lock, it has not been acquired\n")); - return_VOID; + return_ACPI_STATUS (AE_NOT_ACQUIRED); } /* One fewer thread has the global lock */ @@ -626,7 +634,7 @@ { /* There are still some threads holding the lock, cannot release */ - return_VOID; + return_ACPI_STATUS (AE_OK); } /* @@ -642,10 +650,10 @@ */ if (Pending) { - AcpiHwBitRegisterWrite (ACPI_BITREG_GLOBAL_LOCK_RELEASE, 1, ACPI_MTX_LOCK); + Status = AcpiSetRegister (ACPI_BITREG_GLOBAL_LOCK_RELEASE, 1, ACPI_MTX_LOCK); } - return_VOID; + return_ACPI_STATUS (Status); } Index: evregion.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/evregion.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 evregion.c --- evregion.c 23 Feb 2002 05:10:34 -0000 1.1.1.14 +++ evregion.c 1 Jul 2002 21:39:53 -0000 @@ -121,15 +121,15 @@ #include "acevents.h" #include "acnamesp.h" #include "acinterp.h" -#include "amlcode.h" #define _COMPONENT ACPI_EVENTS ACPI_MODULE_NAME ("evregion") + /******************************************************************************* * - * FUNCTION: AcpiEvInstallDefaultAddressSpaceHandlers + * FUNCTION: AcpiEvInitAddressSpaces * * PARAMETERS: * @@ -140,13 +140,13 @@ ******************************************************************************/ ACPI_STATUS -AcpiEvInstallDefaultAddressSpaceHandlers ( +AcpiEvInitAddressSpaces ( void) { ACPI_STATUS Status; - ACPI_FUNCTION_TRACE ("EvInstallDefaultAddressSpaceHandlers"); + ACPI_FUNCTION_TRACE ("EvInitAddressSpaces"); /* @@ -267,7 +267,7 @@ /* * Set up the parameter objects */ - Params[0]->Integer.Value = RegionObj->Region.SpaceId; + Params[0]->Integer.Value = RegionObj->Region.SpaceId; Params[1]->Integer.Value = Function; Params[2] = NULL; @@ -310,9 +310,10 @@ UINT32 Function, ACPI_PHYSICAL_ADDRESS Address, UINT32 BitWidth, - ACPI_INTEGER *Value) + void *Value) { ACPI_STATUS Status; + ACPI_STATUS Status2; ACPI_ADR_SPACE_HANDLER Handler; ACPI_ADR_SPACE_SETUP RegionSetup; ACPI_OPERAND_OBJECT *HandlerDesc; @@ -372,7 +373,11 @@ /* Re-enter the interpreter */ - AcpiExEnterInterpreter (); + Status2 = AcpiExEnterInterpreter (); + if (ACPI_FAILURE (Status2)) + { + return_ACPI_STATUS (Status2); + } /* * Init routine may fail @@ -434,7 +439,11 @@ * We just returned from a non-default handler, we must re-enter the * interpreter */ - AcpiExEnterInterpreter (); + Status2 = AcpiExEnterInterpreter (); + if (ACPI_FAILURE (Status2)) + { + return_ACPI_STATUS (Status2); + } } return_ACPI_STATUS (Status); @@ -442,7 +451,7 @@ /******************************************************************************* * - * FUNCTION: AcpiEvDisassociateRegionFromHandler + * FUNCTION: AcpiEvDetachRegion * * PARAMETERS: RegionObj - Region Object * AcpiNsIsLocked - Namespace Region Already Locked? @@ -455,7 +464,7 @@ ******************************************************************************/ void -AcpiEvDisassociateRegionFromHandler( +AcpiEvDetachRegion( ACPI_OPERAND_OBJECT *RegionObj, BOOLEAN AcpiNsIsLocked) { @@ -468,13 +477,13 @@ ACPI_STATUS Status; - ACPI_FUNCTION_TRACE ("EvDisassociateRegionFromHandler"); + ACPI_FUNCTION_TRACE ("EvDetachRegion"); RegionObj2 = AcpiNsGetSecondaryObject (RegionObj); if (!RegionObj2) { - return; + return_VOID; } RegionContext = RegionObj2->Extra.RegionContext; @@ -525,7 +534,13 @@ /* * Now stop region accesses by executing the _REG method */ - AcpiEvExecuteRegMethod (RegionObj, 0); + Status = AcpiEvExecuteRegMethod (RegionObj, 0); + if (ACPI_FAILURE (Status)) + { + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "%s from region _REG, [%s]\n", + AcpiFormatException (Status), + AcpiUtGetRegionName (RegionObj->Region.SpaceId))); + } if (AcpiNsIsLocked) { @@ -591,7 +606,7 @@ /******************************************************************************* * - * FUNCTION: AcpiEvAssociateRegionAndHandler + * FUNCTION: AcpiEvAttachRegion * * PARAMETERS: HandlerObj - Handler Object * RegionObj - Region Object @@ -605,15 +620,16 @@ ******************************************************************************/ ACPI_STATUS -AcpiEvAssociateRegionAndHandler ( +AcpiEvAttachRegion ( ACPI_OPERAND_OBJECT *HandlerObj, ACPI_OPERAND_OBJECT *RegionObj, BOOLEAN AcpiNsIsLocked) { - ACPI_STATUS Status; + ACPI_STATUS Status; + ACPI_STATUS Status2; - ACPI_FUNCTION_TRACE ("EvAssociateRegionAndHandler"); + ACPI_FUNCTION_TRACE ("EvAttachRegion"); ACPI_DEBUG_PRINT ((ACPI_DB_OPREGION, @@ -638,14 +654,22 @@ */ if (AcpiNsIsLocked) { - AcpiUtReleaseMutex (ACPI_MTX_NAMESPACE); + Status2 = AcpiUtReleaseMutex (ACPI_MTX_NAMESPACE); + if (ACPI_FAILURE (Status2)) + { + return_ACPI_STATUS (Status2); + } } Status = AcpiEvExecuteRegMethod (RegionObj, 1); if (AcpiNsIsLocked) { - (void) AcpiUtAcquireMutex (ACPI_MTX_NAMESPACE); + Status2 = AcpiUtAcquireMutex (ACPI_MTX_NAMESPACE); + if (ACPI_FAILURE (Status2)) + { + return_ACPI_STATUS (Status2); + } } return_ACPI_STATUS (Status); @@ -730,7 +754,7 @@ /* * Devices are handled different than regions */ - if (ObjDesc->Common.Type == ACPI_TYPE_DEVICE) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) == ACPI_TYPE_DEVICE) { /* * See if this guy has any handlers @@ -793,12 +817,12 @@ * * First disconnect region for any previous handler (if any) */ - AcpiEvDisassociateRegionFromHandler (ObjDesc, FALSE); + AcpiEvDetachRegion (ObjDesc, FALSE); /* * Then connect the region to the new handler */ - Status = AcpiEvAssociateRegionAndHandler (HandlerObj, ObjDesc, FALSE); + Status = AcpiEvAttachRegion (HandlerObj, ObjDesc, FALSE); return (Status); } Index: evrgnini.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/evrgnini.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 evrgnini.c --- evrgnini.c 16 Mar 2002 02:17:51 -0000 1.1.1.14 +++ evrgnini.c 1 Jul 2002 21:39:53 -0000 @@ -120,8 +120,6 @@ #include "acpi.h" #include "acevents.h" #include "acnamesp.h" -#include "acinterp.h" -#include "amlcode.h" #define _COMPONENT ACPI_EVENTS ACPI_MODULE_NAME ("evrgnini") @@ -131,8 +129,8 @@ * * FUNCTION: AcpiEvSystemMemoryRegionSetup * - * PARAMETERS: RegionObj - region we are interested in - * Function - start or stop + * PARAMETERS: RegionObj - Region we are interested in + * Function - Start or stop * HandlerContext - Address space handler context * RegionContext - Region specific context * @@ -152,6 +150,7 @@ ACPI_OPERAND_OBJECT *RegionDesc = (ACPI_OPERAND_OBJECT *) Handle; ACPI_MEM_SPACE_CONTEXT *LocalRegionContext; + ACPI_FUNCTION_TRACE ("EvSystemMemoryRegionSetup"); @@ -165,8 +164,7 @@ return_ACPI_STATUS (AE_OK); } - - /* Activate. Create a new context */ + /* Create a new context */ LocalRegionContext = ACPI_MEM_CALLOCATE (sizeof (ACPI_MEM_SPACE_CONTEXT)); if (!(LocalRegionContext)) @@ -188,8 +186,8 @@ * * FUNCTION: AcpiEvIoSpaceRegionSetup * - * PARAMETERS: RegionObj - region we are interested in - * Function - start or stop + * PARAMETERS: RegionObj - Region we are interested in + * Function - Start or stop * HandlerContext - Address space handler context * RegionContext - Region specific context * @@ -226,8 +224,8 @@ * * FUNCTION: AcpiEvPciConfigRegionSetup * - * PARAMETERS: RegionObj - region we are interested in - * Function - start or stop + * PARAMETERS: RegionObj - Region we are interested in + * Function - Start or stop * HandlerContext - Address space handler context * RegionContext - Region specific context * @@ -262,8 +260,8 @@ if (!HandlerObj) { /* - * No installed handler. This shouldn't happen because the dispatch - * routine checks before we get here, but we check again just in case. + * No installed handler. This shouldn't happen because the dispatch + * routine checks before we get here, but we check again just in case. */ ACPI_DEBUG_PRINT ((ACPI_DB_OPREGION, "Attempting to init a region %p, with no handler\n", RegionObj)); @@ -281,7 +279,6 @@ return_ACPI_STATUS (Status); } - /* Create a new context */ PciId = ACPI_MEM_CALLOCATE (sizeof (ACPI_PCI_ID)); @@ -291,43 +288,42 @@ } /* - * For PCI Config space access, we have to pass the segment, bus, - * device and function numbers. This routine must acquire those. + * For PCI Config space access, we have to pass the segment, bus, + * device and function numbers. This routine must acquire those. */ /* - * First get device and function numbers from the _ADR object - * in the parent's scope. + * First get device and function numbers from the _ADR object + * in the parent's scope. */ Node = AcpiNsGetParentNode (RegionObj->Region.Node); - - /* AcpiEvaluate the _ADR object */ + /* Evaluate the _ADR object */ Status = AcpiUtEvaluateNumericObject (METHOD_NAME__ADR, Node, &Temp); /* - * The default is zero, since the allocation above zeroed the data, just - * do nothing on failures. + * The default is zero, and since the allocation above zeroed + * the data, just do nothing on failure. */ if (ACPI_SUCCESS (Status)) { - PciId->Device = ACPI_HIWORD (Temp); - PciId->Function = ACPI_LOWORD (Temp); + PciId->Device = ACPI_HIWORD (ACPI_LODWORD (Temp)); + PciId->Function = ACPI_LOWORD (ACPI_LODWORD (Temp)); } /* - * Get the _SEG and _BBN values from the device upon which the handler - * is installed. + * Get the _SEG and _BBN values from the device upon which the handler + * is installed. * - * We need to get the _SEG and _BBN objects relative to the PCI BUS device. - * This is the device the handler has been registered to handle. + * We need to get the _SEG and _BBN objects relative to the PCI BUS device. + * This is the device the handler has been registered to handle. */ /* - * If the AddrHandler.Node is still pointing to the root, we need - * to scan upward for a PCI Root bridge and re-associate the OpRegion - * handlers with that device. + * If the AddrHandler.Node is still pointing to the root, we need + * to scan upward for a PCI Root bridge and re-associate the OpRegion + * handlers with that device. */ if (HandlerObj->AddrHandler.Node == AcpiGbl_RootNode) { @@ -339,12 +335,21 @@ Status = AcpiUtExecute_HID (Node, &ObjectHID); if (ACPI_SUCCESS (Status)) { + /* Got a valid _HID, check if this is a PCI root */ + if (!(ACPI_STRNCMP (ObjectHID.Buffer, PCI_ROOT_HID_STRING, sizeof (PCI_ROOT_HID_STRING)))) { - AcpiInstallAddressSpaceHandler ((ACPI_HANDLE) Node, + /* Install a handler for this PCI root bridge */ + + Status = AcpiInstallAddressSpaceHandler ((ACPI_HANDLE) Node, ACPI_ADR_SPACE_PCI_CONFIG, ACPI_DEFAULT_HANDLER, NULL, NULL); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("Could not install PciConfig handler for %4.4s, %s\n", + Node->Name.Ascii, AcpiFormatException (Status))); + } break; } } @@ -384,8 +389,8 @@ * * FUNCTION: AcpiEvPciBarRegionSetup * - * PARAMETERS: RegionObj - region we are interested in - * Function - start or stop + * PARAMETERS: RegionObj - Region we are interested in + * Function - Start or stop * HandlerContext - Address space handler context * RegionContext - Region specific context * @@ -404,7 +409,6 @@ void *HandlerContext, void **RegionContext) { - ACPI_FUNCTION_TRACE ("EvPciBarRegionSetup"); @@ -416,8 +420,8 @@ * * FUNCTION: AcpiEvCmosRegionSetup * - * PARAMETERS: RegionObj - region we are interested in - * Function - start or stop + * PARAMETERS: RegionObj - Region we are interested in + * Function - Start or stop * HandlerContext - Address space handler context * RegionContext - Region specific context * @@ -436,7 +440,6 @@ void *HandlerContext, void **RegionContext) { - ACPI_FUNCTION_TRACE ("EvCmosRegionSetup"); @@ -448,8 +451,8 @@ * * FUNCTION: AcpiEvDefaultRegionSetup * - * PARAMETERS: RegionObj - region we are interested in - * Function - start or stop + * PARAMETERS: RegionObj - Region we are interested in + * Function - Start or stop * HandlerContext - Address space handler context * RegionContext - Region specific context * @@ -486,7 +489,8 @@ * * FUNCTION: AcpiEvInitializeRegion * - * PARAMETERS: RegionObj - Region we are initializing + * PARAMETERS: RegionObj - Region we are initializing + * AcpiNsLocked - Is namespace locked? * * RETURN: Status * @@ -536,9 +540,8 @@ { return_ACPI_STATUS (AE_NOT_EXIST); } - Node = AcpiNsGetParentNode (RegionObj->Region.Node); - + Node = AcpiNsGetParentNode (RegionObj->Region.Node); SpaceId = RegionObj->Region.SpaceId; RegionObj->Region.AddrHandler = NULL; @@ -547,35 +550,35 @@ RegionObj->Common.Flags |= AOPOBJ_OBJECT_INITIALIZED; /* - * Find any "_REG" associated with this region definition + * Find any "_REG" method associated with this region definition */ Status = AcpiNsSearchNode (*RegNamePtr, Node, ACPI_TYPE_METHOD, &MethodNode); if (ACPI_SUCCESS (Status)) { /* - * The _REG method is optional and there can be only one per region - * definition. This will be executed when the handler is attached - * or removed + * The _REG method is optional and there can be only one per region + * definition. This will be executed when the handler is attached + * or removed */ RegionObj2->Extra.Method_REG = MethodNode; } /* - * The following loop depends upon the root Node having no parent - * ie: AcpiGbl_RootNode->ParentEntry being set to NULL + * The following loop depends upon the root Node having no parent + * ie: AcpiGbl_RootNode->ParentEntry being set to NULL */ while (Node) { /* - * Check to see if a handler exists + * Check to see if a handler exists */ HandlerObj = NULL; ObjDesc = AcpiNsGetAttachedObject (Node); if (ObjDesc) { /* - * can only be a handler if the object exists + * Can only be a handler if the object exists */ switch (Node->Type) { @@ -593,44 +596,45 @@ HandlerObj = ObjDesc->ThermalZone.AddrHandler; break; + + default: + /* Ignore other objects */ + break; } while (HandlerObj) { - /* - * This guy has at least one address handler - * see if it has the type we want - */ + /* Is this handler of the correct type? */ + if (HandlerObj->AddrHandler.SpaceId == SpaceId) { + /* Found correct handler */ + ACPI_DEBUG_PRINT ((ACPI_DB_OPREGION, "Found handler %p for region %p in obj %p\n", HandlerObj, RegionObj, ObjDesc)); - /* - * Found it! Now update the region and the handler - */ - AcpiEvAssociateRegionAndHandler (HandlerObj, RegionObj, - AcpiNsLocked); + Status = AcpiEvAttachRegion (HandlerObj, RegionObj, + AcpiNsLocked); return_ACPI_STATUS (AE_OK); } - HandlerObj = HandlerObj->AddrHandler.Next; + /* Try next handler in the list */ - } /* while handlerobj */ + HandlerObj = HandlerObj->AddrHandler.Next; + } } /* - * This one does not have the handler we need - * Pop up one level + * This node does not have the handler we need; + * Pop up one level */ Node = AcpiNsGetParentNode (Node); - - } /* while Node != ROOT */ + } /* - * If we get here, there is no handler for this region + * If we get here, there is no handler for this region */ ACPI_DEBUG_PRINT ((ACPI_DB_OPREGION, "No handler for RegionType %s(%X) (RegionObj %p)\n", Index: evsci.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/evsci.c,v retrieving revision 1.1.1.9 diff -u -r1.1.1.9 evsci.c --- evsci.c 16 Mar 2002 02:17:52 -0000 1.1.1.9 +++ evsci.c 1 Jul 2002 21:39:53 -0000 @@ -117,8 +117,6 @@ *****************************************************************************/ #include "acpi.h" -#include "acnamesp.h" -#include "achware.h" #include "acevents.h" @@ -145,6 +143,8 @@ void *Context) { UINT32 InterruptHandled = ACPI_INTERRUPT_NOT_HANDLED; + UINT32 Value; + ACPI_STATUS Status; ACPI_FUNCTION_TRACE("EvSciHandler"); @@ -154,7 +154,13 @@ * Make sure that ACPI is enabled by checking SCI_EN. Note that we are * required to treat the SCI interrupt as sharable, level, active low. */ - if (!AcpiHwBitRegisterRead (ACPI_BITREG_SCI_ENABLE, ACPI_MTX_DO_NOT_LOCK)) + Status = AcpiGetRegister (ACPI_BITREG_SCI_ENABLE, &Value, ACPI_MTX_DO_NOT_LOCK); + if (ACPI_FAILURE (Status)) + { + return (ACPI_INTERRUPT_NOT_HANDLED); + } + + if (!Value) { /* ACPI is not enabled; this interrupt cannot be for us */ @@ -228,15 +234,18 @@ ACPI_STATUS AcpiEvRemoveSciHandler (void) { + ACPI_STATUS Status; + + ACPI_FUNCTION_TRACE ("EvRemoveSciHandler"); /* Just let the OS remove the handler and disable the level */ - AcpiOsRemoveInterruptHandler ((UINT32) AcpiGbl_FADT->SciInt, + Status = AcpiOsRemoveInterruptHandler ((UINT32) AcpiGbl_FADT->SciInt, AcpiEvSciHandler); - return_ACPI_STATUS (AE_OK); + return_ACPI_STATUS (Status); } Index: evxface.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/evxface.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 evxface.c --- evxface.c 30 Jun 2002 17:50:41 -0000 1.1.1.13 +++ evxface.c 1 Jul 2002 21:39:53 -0000 @@ -118,10 +118,8 @@ #define __EVXFACE_C__ #include "acpi.h" -#include "achware.h" #include "acnamesp.h" #include "acevents.h" -#include "amlcode.h" #include "acinterp.h" #define _COMPONENT ACPI_EVENTS @@ -178,7 +176,6 @@ goto Cleanup; } - /* Install the handler before enabling the event */ AcpiGbl_FixedEventHandlers[Event].Handler = Handler; @@ -655,8 +652,13 @@ /* Clear the GPE (of stale events), the enable it */ - AcpiHwClearGpe (GpeNumber); - AcpiHwEnableGpe (GpeNumber); + Status = AcpiHwClearGpe (GpeNumber); + if (ACPI_FAILURE (Status)) + { + goto Cleanup; + } + + Status = AcpiHwEnableGpe (GpeNumber); Cleanup: @@ -707,7 +709,11 @@ /* Disable the GPE before removing the handler */ - AcpiHwDisableGpe (GpeNumber); + Status = AcpiHwDisableGpe (GpeNumber); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } Status = AcpiUtAcquireMutex (ACPI_MTX_EVENTS); if (ACPI_FAILURE (Status)) @@ -719,7 +725,7 @@ if (AcpiGbl_GpeNumberInfo[GpeNumberIndex].Handler != Handler) { - AcpiHwEnableGpe (GpeNumber); + (void) AcpiHwEnableGpe (GpeNumber); Status = AE_BAD_PARAMETER; goto Cleanup; } @@ -797,14 +803,16 @@ AcpiReleaseGlobalLock ( UINT32 Handle) { + ACPI_STATUS Status; + if (Handle != AcpiGbl_GlobalLockHandle) { return (AE_NOT_ACQUIRED); } - AcpiEvReleaseGlobalLock (); - return (AE_OK); + Status = AcpiEvReleaseGlobalLock (); + return (Status); } Index: evxfevnt.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/evxfevnt.c,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 evxfevnt.c --- evxfevnt.c 23 Feb 2002 05:10:34 -0000 1.1.1.10 +++ evxfevnt.c 1 Jul 2002 21:39:53 -0000 @@ -118,11 +118,7 @@ #define __EVXFEVNT_C__ #include "acpi.h" -#include "achware.h" -#include "acnamesp.h" #include "acevents.h" -#include "amlcode.h" -#include "acinterp.h" #define _COMPONENT ACPI_EVENTS ACPI_MODULE_NAME ("evxfevnt") @@ -217,7 +213,7 @@ /* Unload the SCI interrupt handler */ - AcpiEvRemoveSciHandler (); + Status = AcpiEvRemoveSciHandler (); return_ACPI_STATUS (Status); } @@ -243,6 +239,7 @@ UINT32 Flags) { ACPI_STATUS Status = AE_OK; + UINT32 Value; ACPI_FUNCTION_TRACE ("AcpiEnableEvent"); @@ -256,7 +253,7 @@ /* Decode the Fixed Event */ - if (Event > ACPI_NUM_FIXED_EVENTS) + if (Event > ACPI_EVENT_MAX) { return_ACPI_STATUS (AE_BAD_PARAMETER); } @@ -265,13 +262,23 @@ * Enable the requested fixed event (by writing a one to the * enable register bit) */ - AcpiHwBitRegisterWrite (AcpiGbl_FixedEventInfo[Event].EnableRegisterId, - 1, ACPI_MTX_LOCK); + Status = AcpiSetRegister (AcpiGbl_FixedEventInfo[Event].EnableRegisterId, + 1, ACPI_MTX_LOCK); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } /* Make sure that the hardware responded */ - if (1 != AcpiHwBitRegisterRead (AcpiGbl_FixedEventInfo[Event].EnableRegisterId, - ACPI_MTX_LOCK)) + Status = AcpiGetRegister (AcpiGbl_FixedEventInfo[Event].EnableRegisterId, + &Value, ACPI_MTX_LOCK); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + + if (Value != 1) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Could not enable %s event\n", AcpiUtGetEventName (Event))); @@ -291,7 +298,11 @@ /* Enable the requested GPE number */ - AcpiHwEnableGpe (Event); + Status = AcpiHwEnableGpe (Event); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } if (Flags & ACPI_EVENT_WAKE_ENABLE) { @@ -330,6 +341,7 @@ UINT32 Flags) { ACPI_STATUS Status = AE_OK; + UINT32 Value; ACPI_FUNCTION_TRACE ("AcpiDisableEvent"); @@ -343,7 +355,7 @@ /* Decode the Fixed Event */ - if (Event > ACPI_NUM_FIXED_EVENTS) + if (Event > ACPI_EVENT_MAX) { return_ACPI_STATUS (AE_BAD_PARAMETER); } @@ -352,11 +364,21 @@ * Disable the requested fixed event (by writing a zero to the * enable register bit) */ - AcpiHwBitRegisterWrite (AcpiGbl_FixedEventInfo[Event].EnableRegisterId, - 0, ACPI_MTX_LOCK); + Status = AcpiSetRegister (AcpiGbl_FixedEventInfo[Event].EnableRegisterId, + 0, ACPI_MTX_LOCK); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + + Status = AcpiGetRegister (AcpiGbl_FixedEventInfo[Event].EnableRegisterId, + &Value, ACPI_MTX_LOCK); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } - if (0 != AcpiHwBitRegisterRead (AcpiGbl_FixedEventInfo[Event].EnableRegisterId, - ACPI_MTX_LOCK)) + if (Value != 0) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Could not disable %s events\n", AcpiUtGetEventName (Event))); @@ -385,7 +407,7 @@ } else { - AcpiHwDisableGpe (Event); + Status = AcpiHwDisableGpe (Event); } break; @@ -430,7 +452,7 @@ /* Decode the Fixed Event */ - if (Event > ACPI_NUM_FIXED_EVENTS) + if (Event > ACPI_EVENT_MAX) { return_ACPI_STATUS (AE_BAD_PARAMETER); } @@ -439,7 +461,7 @@ * Clear the requested fixed event (By writing a one to the * status register bit) */ - AcpiHwBitRegisterWrite (AcpiGbl_FixedEventInfo[Event].StatusRegisterId, + Status = AcpiSetRegister (AcpiGbl_FixedEventInfo[Event].StatusRegisterId, 1, ACPI_MTX_LOCK); break; @@ -453,7 +475,7 @@ return_ACPI_STATUS (AE_BAD_PARAMETER); } - AcpiHwClearGpe (Event); + Status = AcpiHwClearGpe (Event); break; @@ -508,15 +530,15 @@ /* Decode the Fixed Event */ - if (Event > ACPI_NUM_FIXED_EVENTS) + if (Event > ACPI_EVENT_MAX) { return_ACPI_STATUS (AE_BAD_PARAMETER); } /* Get the status of the requested fixed event */ - *EventStatus = AcpiHwBitRegisterRead (AcpiGbl_FixedEventInfo[Event].StatusRegisterId, - ACPI_MTX_LOCK); + Status = AcpiGetRegister (AcpiGbl_FixedEventInfo[Event].StatusRegisterId, + EventStatus, ACPI_MTX_LOCK); break; @@ -531,7 +553,7 @@ /* Obtain status on the requested GPE number */ - AcpiHwGetGpeStatus (Event, EventStatus); + Status = AcpiHwGetGpeStatus (Event, EventStatus); break; Index: evxfregn.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/evxfregn.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 evxfregn.c --- evxfregn.c 23 Feb 2002 05:10:34 -0000 1.1.1.11 +++ evxfregn.c 1 Jul 2002 21:39:53 -0000 @@ -118,10 +118,8 @@ #define __EVXFREGN_C__ #include "acpi.h" -#include "achware.h" #include "acnamesp.h" #include "acevents.h" -#include "amlcode.h" #include "acinterp.h" #define _COMPONENT ACPI_EVENTS @@ -471,7 +469,7 @@ * The region is just inaccessible as indicated to * the _REG method */ - AcpiEvDisassociateRegionFromHandler(RegionObj, TRUE); + AcpiEvDetachRegion (RegionObj, TRUE); /* * Walk the list, since we took the first region and it Index: exconfig.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exconfig.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 exconfig.c --- exconfig.c 30 Jun 2002 17:50:43 -0000 1.1.1.14 +++ exconfig.c 1 Jul 2002 21:39:53 -0000 @@ -118,13 +118,11 @@ #define __EXCONFIG_C__ #include "acpi.h" -#include "acparser.h" #include "acinterp.h" #include "amlcode.h" #include "acnamesp.h" #include "acevents.h" #include "actables.h" -#include "acdispat.h" #define _COMPONENT ACPI_EXECUTER @@ -171,11 +169,11 @@ /* Install the new table into the local data structures */ TableInfo.Pointer = Table; - TableInfo.Length = Table->Length; + TableInfo.Length = (ACPI_SIZE) Table->Length; TableInfo.Allocation = ACPI_MEM_ALLOCATED; TableInfo.BasePointer = Table; - Status = AcpiTbInstallTable (NULL, &TableInfo); + Status = AcpiTbInstallTable (&TableInfo); if (ACPI_FAILURE (Status)) { goto Cleanup; @@ -188,7 +186,7 @@ { /* Uninstall table on error */ - AcpiTbUninstallTable (TableInfo.InstalledDesc); + (void) AcpiTbUninstallTable (TableInfo.InstalledDesc); goto Cleanup; } @@ -334,11 +332,11 @@ { /* Store the parameter data into the optional parameter object */ - Status = AcpiExStore (Operand[5], (ACPI_OPERAND_OBJECT *) ParameterNode, + Status = AcpiExStore (Operand[5], ACPI_CAST_PTR (ACPI_OPERAND_OBJECT, ParameterNode), WalkState); if (ACPI_FAILURE (Status)) { - AcpiExUnloadTable (DdbHandle); + (void) AcpiExUnloadTable (DdbHandle); } } @@ -375,7 +373,6 @@ ACPI_TABLE_HEADER TableHeader; UINT32 i; - ACPI_FUNCTION_TRACE ("ExLoadOp"); @@ -386,7 +383,7 @@ case ACPI_TYPE_REGION: ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Load from Region %p %s\n", - ObjDesc, AcpiUtGetTypeName (ObjDesc->Common.Type))); + ObjDesc, AcpiUtGetObjectTypeName (ObjDesc))); /* Get the table header */ @@ -395,7 +392,7 @@ { Status = AcpiEvAddressSpaceDispatch (ObjDesc, ACPI_READ, (ACPI_PHYSICAL_ADDRESS) i, 8, - (ACPI_INTEGER *) ((UINT8 *) &TableHeader + i)); + ((UINT8 *) &TableHeader) + i); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); @@ -421,7 +418,7 @@ { Status = AcpiEvAddressSpaceDispatch (ObjDesc, ACPI_READ, (ACPI_PHYSICAL_ADDRESS) i, 8, - (ACPI_INTEGER *) (TableDataPtr + i)); + ((UINT8 *) TableDataPtr + i)); if (ACPI_FAILURE (Status)) { goto Cleanup; @@ -436,7 +433,7 @@ case INTERNAL_TYPE_INDEX_FIELD: ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Load from Field %p %s\n", - ObjDesc, AcpiUtGetTypeName (ObjDesc->Common.Type))); + ObjDesc, AcpiUtGetObjectTypeName (ObjDesc))); /* * The length of the field must be at least as large as the table. @@ -449,7 +446,7 @@ goto Cleanup; } - TablePtr = (ACPI_TABLE_HEADER *) BufferDesc->Buffer.Pointer; + TablePtr = ACPI_CAST_PTR (ACPI_TABLE_HEADER, BufferDesc->Buffer.Pointer); break; @@ -468,7 +465,7 @@ { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Table has invalid signature [%4.4s], must be SSDT or PSDT\n", - (char *) &TablePtr->Signature)); + TablePtr->Signature)); Status = AE_BAD_SIGNATURE; goto Cleanup; } @@ -486,7 +483,7 @@ Status = AcpiExStore (DdbHandle, Target, WalkState); if (ACPI_FAILURE (Status)) { - AcpiExUnloadTable (DdbHandle); + (void) AcpiExUnloadTable (DdbHandle); } return_ACPI_STATUS (Status); @@ -537,9 +534,8 @@ * validated here. */ if ((!DdbHandle) || - (ACPI_GET_DESCRIPTOR_TYPE (DdbHandle) != ACPI_DESC_TYPE_INTERNAL) || - (((ACPI_OPERAND_OBJECT *)DdbHandle)->Common.Type != - INTERNAL_TYPE_REFERENCE)) + (ACPI_GET_DESCRIPTOR_TYPE (DdbHandle) != ACPI_DESC_TYPE_OPERAND) || + (ACPI_GET_OBJECT_TYPE (DdbHandle) != INTERNAL_TYPE_REFERENCE)) { return_ACPI_STATUS (AE_BAD_PARAMETER); } @@ -552,15 +548,11 @@ * Delete the entire namespace under this table Node * (Offset contains the TableId) */ - Status = AcpiNsDeleteNamespaceByOwner (TableInfo->TableId); - if (ACPI_FAILURE (Status)) - { - return_ACPI_STATUS (Status); - } + AcpiNsDeleteNamespaceByOwner (TableInfo->TableId); /* Delete the table itself */ - AcpiTbUninstallTable (TableInfo->InstalledDesc); + (void) AcpiTbUninstallTable (TableInfo->InstalledDesc); /* Delete the table descriptor (DdbHandle) */ Index: exconvrt.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exconvrt.c,v retrieving revision 1.1.1.9 diff -u -r1.1.1.9 exconvrt.c --- exconvrt.c 30 Jun 2002 17:50:43 -0000 1.1.1.9 +++ exconvrt.c 1 Jul 2002 21:39:53 -0000 @@ -118,12 +118,8 @@ #define __EXCONVRT_C__ #include "acpi.h" -#include "acparser.h" -#include "acnamesp.h" #include "acinterp.h" -#include "acevents.h" #include "amlcode.h" -#include "acdispat.h" #define _COMPONENT ACPI_EXECUTER @@ -153,27 +149,27 @@ UINT32 i; ACPI_OPERAND_OBJECT *RetDesc; UINT32 Count; - char *Pointer; + UINT8 *Pointer; ACPI_INTEGER Result; - UINT32 IntegerSize = sizeof (ACPI_INTEGER); + ACPI_STATUS Status; ACPI_FUNCTION_TRACE_PTR ("ExConvertToInteger", ObjDesc); - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_INTEGER: *ResultDesc = ObjDesc; return_ACPI_STATUS (AE_OK); case ACPI_TYPE_STRING: - Pointer = ObjDesc->String.Pointer; + Pointer = (UINT8 *) ObjDesc->String.Pointer; Count = ObjDesc->String.Length; break; case ACPI_TYPE_BUFFER: - Pointer = (char *) ObjDesc->Buffer.Pointer; + Pointer = ObjDesc->Buffer.Pointer; Count = ObjDesc->Buffer.Length; break; @@ -182,26 +178,6 @@ } /* - * Create a new integer - */ - RetDesc = AcpiUtCreateInternalObject (ACPI_TYPE_INTEGER); - if (!RetDesc) - { - return_ACPI_STATUS (AE_NO_MEMORY); - } - - /* Handle both ACPI 1.0 and ACPI 2.0 Integer widths */ - - if (WalkState->MethodNode->Flags & ANOBJ_DATA_WIDTH_32) - { - /* - * We are running a method that exists in a 32-bit ACPI table. - * Truncate the value to 32 bits by zeroing out the upper 32-bit field - */ - IntegerSize = sizeof (UINT32); - } - - /* * Convert the buffer/string to an integer. Note that both buffers and * strings are treated as raw data - we don't convert ascii to hex for * strings. @@ -214,25 +190,27 @@ /* Transfer no more than an integer's worth of data */ - if (Count > IntegerSize) + if (Count > AcpiGbl_IntegerByteWidth) { - Count = IntegerSize; + Count = AcpiGbl_IntegerByteWidth; } /* * String conversion is different than Buffer conversion */ - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_STRING: - /* TBD: Need to use 64-bit ACPI_STRTOUL */ - /* * Convert string to an integer * String must be hexadecimal as per the ACPI specification */ - Result = ACPI_STRTOUL (Pointer, NULL, 16); + Status = AcpiUtStrtoul64 ((char *) Pointer, 16, &Result); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } break; @@ -252,6 +230,20 @@ Result |= (((ACPI_INTEGER) Pointer[i]) << (i * 8)); } break; + + + default: + /* No other types can get here */ + break; + } + + /* + * Create a new integer + */ + RetDesc = AcpiUtCreateInternalObject (ACPI_TYPE_INTEGER); + if (!RetDesc) + { + return_ACPI_STATUS (AE_NO_MEMORY); } /* Save the Result, delete original descriptor, store new descriptor */ @@ -293,19 +285,18 @@ { ACPI_OPERAND_OBJECT *RetDesc; UINT32 i; - UINT32 IntegerSize = sizeof (ACPI_INTEGER); UINT8 *NewBuf; ACPI_FUNCTION_TRACE_PTR ("ExConvertToBuffer", ObjDesc); - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_INTEGER: /* - * Create a new Buffer + * Create a new Buffer object */ RetDesc = AcpiUtCreateInternalObject (ACPI_TYPE_BUFFER); if (!RetDesc) @@ -313,21 +304,9 @@ return_ACPI_STATUS (AE_NO_MEMORY); } - /* Handle both ACPI 1.0 and ACPI 2.0 Integer widths */ - - if (WalkState->MethodNode->Flags & ANOBJ_DATA_WIDTH_32) - { - /* - * We are running a method that exists in a 32-bit ACPI table. - * Use only 32 bits of the Integer for conversion. - */ - IntegerSize = sizeof (UINT32); - } - /* Need enough space for one integer */ - RetDesc->Buffer.Length = IntegerSize; - NewBuf = ACPI_MEM_CALLOCATE (IntegerSize); + NewBuf = ACPI_MEM_CALLOCATE (AcpiGbl_IntegerByteWidth); if (!NewBuf) { ACPI_REPORT_ERROR @@ -338,11 +317,16 @@ /* Copy the integer to the buffer */ - for (i = 0; i < IntegerSize; i++) + for (i = 0; i < AcpiGbl_IntegerByteWidth; i++) { NewBuf[i] = (UINT8) (ObjDesc->Integer.Value >> (i * 8)); } + + /* Complete buffer object initialization */ + + RetDesc->Buffer.Flags |= AOPOBJ_DATA_VALID; RetDesc->Buffer.Pointer = NewBuf; + RetDesc->Buffer.Length = AcpiGbl_IntegerByteWidth; /* Return the new buffer descriptor */ @@ -392,7 +376,7 @@ UINT32 i; UINT32 j; UINT32 k = 0; - UINT8 HexDigit; + char HexDigit; ACPI_INTEGER Digit; UINT32 Remainder; UINT32 Length = sizeof (ACPI_INTEGER); @@ -414,7 +398,7 @@ Digit = Integer; for (j = 1; j < i; j++) { - AcpiUtShortDivide (&Digit, 10, &Digit, &Remainder); + (void) AcpiUtShortDivide (&Digit, 10, &Digit, &Remainder); } /* Create the decimal digit */ @@ -447,7 +431,7 @@ if (!LeadingZero) { - String[k] = HexDigit; + String[k] = (UINT8) HexDigit; k++; } } @@ -500,7 +484,6 @@ UINT32 i; UINT32 Index; UINT32 StringLength; - UINT32 IntegerSize = sizeof (ACPI_INTEGER); UINT8 *NewBuf; UINT8 *Pointer; @@ -508,22 +491,11 @@ ACPI_FUNCTION_TRACE_PTR ("ExConvertToString", ObjDesc); - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_INTEGER: - /* Handle both ACPI 1.0 and ACPI 2.0 Integer widths */ - - if (WalkState->MethodNode->Flags & ANOBJ_DATA_WIDTH_32) - { - /* - * We are running a method that exists in a 32-bit ACPI table. - * Use only 32 bits of the Integer - */ - IntegerSize = sizeof (UINT32); - } - - StringLength = IntegerSize * 2; + StringLength = AcpiGbl_IntegerByteWidth * 2; if (Base == 10) { StringLength = ACPI_MAX_DECIMAL_DIGITS; @@ -540,7 +512,7 @@ /* Need enough space for one ASCII integer plus null terminator */ - NewBuf = ACPI_MEM_CALLOCATE (StringLength + 1); + NewBuf = ACPI_MEM_CALLOCATE ((ACPI_SIZE) StringLength + 1); if (!NewBuf) { ACPI_REPORT_ERROR @@ -549,7 +521,6 @@ return_ACPI_STATUS (AE_NO_MEMORY); } - /* Convert */ i = AcpiExConvertToAscii (ObjDesc->Integer.Value, Base, NewBuf); @@ -615,7 +586,7 @@ StringLength = MaxLength; } - NewBuf = ACPI_MEM_CALLOCATE (StringLength + 1); + NewBuf = ACPI_MEM_CALLOCATE ((ACPI_SIZE) StringLength + 1); if (!NewBuf) { ACPI_REPORT_ERROR @@ -631,7 +602,7 @@ Index = 0; for (i = 0, Index = 0; i < ObjDesc->Buffer.Length; i++) { - Index = AcpiExConvertToAscii (Pointer[i], Base, &NewBuf[Index]); + Index = AcpiExConvertToAscii ((ACPI_INTEGER) Pointer[i], Base, &NewBuf[Index]); NewBuf[Index] = ' '; Index++; @@ -643,7 +614,6 @@ RetDesc->Buffer.Pointer = NewBuf; RetDesc->String.Length = ACPI_STRLEN ((char *) NewBuf); - /* Return the new buffer descriptor */ if (*ResultDesc == ObjDesc) @@ -734,11 +704,11 @@ default: /* No conversion allowed for these types */ - if (DestinationType != SourceDesc->Common.Type) + if (DestinationType != ACPI_GET_OBJECT_TYPE (SourceDesc)) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Target does not allow conversion of type %s to %s\n", - AcpiUtGetTypeName ((SourceDesc)->Common.Type), + AcpiUtGetObjectTypeName (SourceDesc), AcpiUtGetTypeName (DestinationType))); Status = AE_TYPE; } @@ -780,6 +750,11 @@ */ Status = AcpiExConvertToBuffer (SourceDesc, ResultDesc, WalkState); break; + + + default: + Status = AE_AML_INTERNAL; + break; } break; @@ -799,7 +774,6 @@ Status = AE_AML_INTERNAL; } - /* * Source-to-Target conversion semantics: Index: excreate.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/excreate.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 excreate.c --- excreate.c 23 Feb 2002 05:10:35 -0000 1.1.1.12 +++ excreate.c 1 Jul 2002 21:39:53 -0000 @@ -118,12 +118,10 @@ #define __EXCREATE_C__ #include "acpi.h" -#include "acparser.h" #include "acinterp.h" #include "amlcode.h" #include "acnamesp.h" #include "acevents.h" -#include "acdispat.h" #include "actables.h" @@ -135,8 +133,7 @@ * * FUNCTION: AcpiExCreateAlias * - * PARAMETERS: WalkState - Current state, contains List of - * operands for the opcode + * PARAMETERS: WalkState - Current state, contains operands * * RETURN: Status * @@ -331,7 +328,7 @@ /* Get the Node from the object stack */ - Node = WalkState->Op->Node; + Node = WalkState->Op->Common.Node; /* * If the region object is already attached to this node, @@ -423,7 +420,7 @@ /* Get the Node from the object stack */ - Node = WalkState->Op->Node; + Node = WalkState->Op->Common.Node; /* * If the region object is already attached to this node, @@ -501,9 +498,7 @@ * * FUNCTION: AcpiExCreateProcessor * - * PARAMETERS: Op - Op containing the Processor definition and - * args - * ProcessorNode - Parent Node for the processor object + * PARAMETERS: WalkState - Current state * * RETURN: Status * @@ -557,9 +552,7 @@ * * FUNCTION: AcpiExCreatePowerResource * - * PARAMETERS: Op - Op containing the PowerResource definition - * and args - * PowerNode - Parent Node for the power object + * PARAMETERS: WalkState - Current state * * RETURN: Status * @@ -613,8 +606,7 @@ * * PARAMETERS: AmlStart - First byte of the method's AML * AmlLength - AML byte count for this method - * MethodFlags - AML method flag byte - * Method - Method Node + * WalkState - Current state * * RETURN: Status * Index: exdump.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exdump.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 exdump.c --- exdump.c 30 Jun 2002 17:50:43 -0000 1.1.1.12 +++ exdump.c 1 Jul 2002 21:39:53 -0000 @@ -120,7 +120,6 @@ #include "acinterp.h" #include "amlcode.h" #include "acnamesp.h" -#include "actables.h" #include "acparser.h" #define _COMPONENT ACPI_EXECUTER @@ -135,100 +134,6 @@ /***************************************************************************** * - * FUNCTION: AcpiExShowHexValue - * - * PARAMETERS: ByteCount - Number of bytes to print (1, 2, or 4) - * *AmlStart - Address in AML stream of bytes to print - * InterpreterMode - Current running mode (load1/Load2/Exec) - * LeadSpace - # of spaces to print ahead of value - * 0 => none ahead but one behind - * - * DESCRIPTION: Print ByteCount byte(s) starting at AmlStart as a single - * value, in hex. If ByteCount > 1 or the value printed is > 9, also - * print in decimal. - * - ****************************************************************************/ - -void -AcpiExShowHexValue ( - UINT32 ByteCount, - UINT8 *AmlStart, - UINT32 LeadSpace) -{ - UINT32 Value; /* Value retrieved from AML stream */ - UINT32 ShowDecimalValue; - UINT32 Length; /* Length of printed field */ - UINT8 *CurrentAmlPtr = NULL; /* Pointer to current byte of AML value */ - - - ACPI_FUNCTION_TRACE ("ExShowHexValue"); - - - if (!((ACPI_LV_LOAD & AcpiDbgLevel) && (_COMPONENT & AcpiDbgLayer))) - { - return; - } - - if (!AmlStart) - { - ACPI_REPORT_ERROR (("ExShowHexValue: null pointer\n")); - return; - } - - /* - * AML numbers are always stored little-endian, - * even if the processor is big-endian. - */ - for (CurrentAmlPtr = AmlStart + ByteCount, - Value = 0; - CurrentAmlPtr > AmlStart; ) - { - Value = (Value << 8) + (UINT32)* --CurrentAmlPtr; - } - - Length = LeadSpace * ByteCount + 2; - if (ByteCount > 1) - { - Length += (ByteCount - 1); - } - - ShowDecimalValue = (ByteCount > 1 || Value > 9); - if (ShowDecimalValue) - { - Length += 3 + AcpiExDigitsNeeded (Value, 10); - } - - for (Length = LeadSpace; Length; --Length ) - { - AcpiOsPrintf (" "); - } - - while (ByteCount--) - { - AcpiOsPrintf ("%02x", *AmlStart++); - if (ByteCount) - { - AcpiOsPrintf (" "); - } - } - - if (ShowDecimalValue) - { - AcpiOsPrintf (" [%d]", Value); - } - - if (0 == LeadSpace) - { - AcpiOsPrintf (" "); - } - - AcpiOsPrintf ("\n"); - return_VOID; -} - - -/***************************************************************************** - * * FUNCTION: AcpiExDumpOperand * * PARAMETERS: *ObjDesc - Pointer to entry to be dumped @@ -239,13 +144,16 @@ * ****************************************************************************/ -ACPI_STATUS +void AcpiExDumpOperand ( ACPI_OPERAND_OBJECT *ObjDesc) { UINT8 *Buf = NULL; UINT32 Length; UINT32 i; + ACPI_OPERAND_OBJECT **Element; + UINT16 ElementIndex; + ACPI_FUNCTION_NAME ("ExDumpOperand") @@ -253,7 +161,7 @@ if (!((ACPI_LV_EXEC & AcpiDbgLevel) && (_COMPONENT & AcpiDbgLayer))) { - return (AE_OK); + return; } if (!ObjDesc) @@ -264,57 +172,33 @@ * code that dumps the stack expects something to be there! */ AcpiOsPrintf ("Null stack entry ptr\n"); - return (AE_OK); + return; } if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) == ACPI_DESC_TYPE_NAMED) { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%p NS Node: ", ObjDesc)); ACPI_DUMP_ENTRY (ObjDesc, ACPI_LV_EXEC); - return (AE_OK); + return; } - if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_INTERNAL) + if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_OPERAND) { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%p is not a local object\n", ObjDesc)); ACPI_DUMP_BUFFER (ObjDesc, sizeof (ACPI_OPERAND_OBJECT)); - return (AE_OK); + return; } /* ObjDesc is a valid object */ ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%p ", ObjDesc)); - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case INTERNAL_TYPE_REFERENCE: switch (ObjDesc->Reference.Opcode) { - case AML_ZERO_OP: - - AcpiOsPrintf ("Reference: Zero\n"); - break; - - - case AML_ONE_OP: - - AcpiOsPrintf ("Reference: One\n"); - break; - - - case AML_ONES_OP: - - AcpiOsPrintf ("Reference: Ones\n"); - break; - - - case AML_REVISION_OP: - - AcpiOsPrintf ("Reference: Revision\n"); - break; - - case AML_DEBUG_OP: AcpiOsPrintf ("Reference: Debug\n"); @@ -341,7 +225,7 @@ AcpiOsPrintf ("Reference: Arg%d", ObjDesc->Reference.Offset); - if (ACPI_TYPE_INTEGER == ObjDesc->Common.Type) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) == ACPI_TYPE_INTEGER) { /* Value is a Number */ @@ -359,7 +243,7 @@ AcpiOsPrintf ("Reference: Local%d", ObjDesc->Reference.Offset); - if (ACPI_TYPE_INTEGER == ObjDesc->Common.Type) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) == ACPI_TYPE_INTEGER) { /* Value is a Number */ @@ -375,14 +259,14 @@ case AML_INT_NAMEPATH_OP: AcpiOsPrintf ("Reference.Node->Name %X\n", - ObjDesc->Reference.Node->Name); + ObjDesc->Reference.Node->Name.Integer); break; default: /* unknown opcode */ - AcpiOsPrintf ("Unknown opcode=%X\n", + AcpiOsPrintf ("Unknown Reference opcode=%X\n", ObjDesc->Reference.Opcode); break; @@ -457,9 +341,6 @@ ObjDesc->Package.Elements && AcpiDbgLevel > 1) { - ACPI_OPERAND_OBJECT**Element; - UINT16 ElementIndex; - for (ElementIndex = 0, Element = ObjDesc->Package.Elements; ElementIndex < ObjDesc->Package.Count; ++ElementIndex, ++Element) @@ -467,9 +348,7 @@ AcpiExDumpOperand (*Element); } } - AcpiOsPrintf ("\n"); - break; @@ -507,7 +386,6 @@ AcpiOsPrintf ("%c", ObjDesc->String.Pointer[i]); } - AcpiOsPrintf ("\"\n"); break; @@ -547,13 +425,10 @@ { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "*NULL* \n")); } - - else if (ACPI_TYPE_BUFFER != - ObjDesc->BufferField.BufferObj->Common.Type) + else if (ACPI_GET_OBJECT_TYPE (ObjDesc->BufferField.BufferObj) != ACPI_TYPE_BUFFER) { AcpiOsPrintf ("*not a Buffer* \n"); } - else { ACPI_DUMP_STACK_ENTRY (ObjDesc->BufferField.BufferObj); @@ -608,13 +483,13 @@ default: - /* unknown ObjDesc->Common.Type value */ + /* Unknown Type */ - AcpiOsPrintf ("Unknown Type %X\n", ObjDesc->Common.Type); + AcpiOsPrintf ("Unknown Type %X\n", ACPI_GET_OBJECT_TYPE (ObjDesc)); break; } - return (AE_OK); + return; } @@ -658,7 +533,6 @@ Note = "?"; } - ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "************* Operand Stack Contents (Opcode [%s], %d Operands)\n", Ident, NumLevels)); @@ -668,16 +542,12 @@ NumLevels = 1; } - /* Dump the stack starting at the top, working down */ + /* Dump the operand stack starting at the top */ for (i = 0; NumLevels > 0; i--, NumLevels--) { ObjDesc = &Operands[i]; - - if (ACPI_FAILURE (AcpiExDumpOperand (*ObjDesc))) - { - break; - } + AcpiExDumpOperand (*ObjDesc); } ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, @@ -729,7 +599,8 @@ char *Title, ACPI_PHYSICAL_ADDRESS Value) { -#ifdef _IA16 + +#if ACPI_MACHINE_WIDTH == 16 AcpiOsPrintf ("%20s : %p\n", Title, Value); #else AcpiOsPrintf ("%20s : %8.8X%8.8X\n", Title, @@ -766,8 +637,7 @@ } } - - AcpiOsPrintf ("%20s : %4.4s\n", "Name", (char *) &Node->Name); + AcpiOsPrintf ("%20s : %4.4s\n", "Name", Node->Name.Ascii); AcpiExOutString ("Type", AcpiUtGetTypeName (Node->Type)); AcpiExOutInteger ("Flags", Node->Flags); AcpiExOutInteger ("Owner Id", Node->OwnerId); @@ -809,7 +679,7 @@ } } - if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_INTERNAL) + if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_OPERAND) { AcpiOsPrintf ("ExDumpObjectDescriptor: %p is not a valid ACPI object\n", ObjDesc); return; @@ -817,17 +687,17 @@ /* Common Fields */ - AcpiExOutString ("Type", AcpiUtGetTypeName (ObjDesc->Common.Type)); + AcpiExOutString ("Type", AcpiUtGetObjectTypeName (ObjDesc)); AcpiExOutInteger ("Reference Count", ObjDesc->Common.ReferenceCount); AcpiExOutInteger ("Flags", ObjDesc->Common.Flags); /* Object-specific Fields */ - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_INTEGER: - AcpiOsPrintf ("%20s : %X%8.8X\n", "Value", + AcpiOsPrintf ("%20s : %8.8X%8.8X\n", "Value", ACPI_HIDWORD (ObjDesc->Integer.Value), ACPI_LODWORD (ObjDesc->Integer.Value)); break; @@ -863,7 +733,7 @@ AcpiOsPrintf ("[%.3d] %p", i, ObjDesc->Package.Elements[i]); if (ObjDesc->Package.Elements[i]) { - AcpiOsPrintf (" %s", AcpiUtGetTypeName ((ObjDesc->Package.Elements[i])->Common.Type)); + AcpiOsPrintf (" %s", AcpiUtGetObjectTypeName (ObjDesc->Package.Elements[i])); } AcpiOsPrintf ("\n"); } @@ -929,7 +799,7 @@ AcpiExOutInteger ("Processor ID", ObjDesc->Processor.ProcId); AcpiExOutInteger ("Length", ObjDesc->Processor.Length); - AcpiExOutInteger ("Address", ObjDesc->Processor.Address); + AcpiExOutAddress ("Address", (ACPI_PHYSICAL_ADDRESS) ObjDesc->Processor.Address); AcpiExOutPointer ("SysHandler", ObjDesc->Processor.SysHandler); AcpiExOutPointer ("DrvHandler", ObjDesc->Processor.DrvHandler); AcpiExOutPointer ("AddrHandler", ObjDesc->Processor.AddrHandler); @@ -959,7 +829,7 @@ AcpiExOutInteger ("EndBufValidBits", ObjDesc->CommonField.EndBufferValidBits); AcpiExOutPointer ("ParentNode", ObjDesc->CommonField.Node); - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_BUFFER_FIELD: AcpiExOutPointer ("BufferObj", ObjDesc->BufferField.BufferObj); @@ -980,6 +850,10 @@ AcpiExOutPointer ("Index", ObjDesc->IndexField.IndexObj); AcpiExOutPointer ("Data", ObjDesc->IndexField.DataObj); break; + + default: + /* All object types covered above */ + break; } break; @@ -1023,15 +897,10 @@ case INTERNAL_TYPE_DEF_ANY: case INTERNAL_TYPE_EXTRA: case INTERNAL_TYPE_DATA: - - AcpiOsPrintf ("ExDumpObjectDescriptor: Display not implemented for object type %X\n", - ObjDesc->Common.Type); - break; - - default: - AcpiOsPrintf ("ExDumpObjectDescriptor: Unknown object type %X\n", ObjDesc->Common.Type); + AcpiOsPrintf ("ExDumpObjectDescriptor: Display not implemented for object type %s\n", + AcpiUtGetObjectTypeName (ObjDesc)); break; } Index: exfield.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exfield.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 exfield.c --- exfield.c 30 Jun 2002 17:50:43 -0000 1.1.1.11 +++ exfield.c 1 Jul 2002 21:39:53 -0000 @@ -120,10 +120,6 @@ #include "acpi.h" #include "acdispat.h" #include "acinterp.h" -#include "amlcode.h" -#include "acnamesp.h" -#include "achware.h" -#include "acevents.h" #define _COMPONENT ACPI_EXECUTER @@ -154,7 +150,6 @@ ACPI_STATUS Status; ACPI_OPERAND_OBJECT *BufferDesc; UINT32 Length; - UINT32 IntegerSize; void *Buffer; BOOLEAN Locked; @@ -169,7 +164,7 @@ return_ACPI_STATUS (AE_AML_NO_OPERAND); } - if (ObjDesc->Common.Type == ACPI_TYPE_BUFFER_FIELD) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) == ACPI_TYPE_BUFFER_FIELD) { /* * If the BufferField arguments have not been previously evaluated, @@ -196,20 +191,7 @@ * Note: Field.length is in bits. */ Length = ACPI_ROUND_BITS_UP_TO_BYTES (ObjDesc->Field.BitLength); - - /* Handle both ACPI 1.0 and ACPI 2.0 Integer widths */ - - IntegerSize = sizeof (ACPI_INTEGER); - if (WalkState->MethodNode->Flags & ANOBJ_DATA_WIDTH_32) - { - /* - * We are running a method that exists in a 32-bit ACPI table. - * Integer size is 4. - */ - IntegerSize = sizeof (UINT32); - } - - if (Length > IntegerSize) + if (Length > AcpiGbl_IntegerByteWidth) { /* Field is too large for an Integer, create a Buffer instead */ @@ -228,6 +210,8 @@ return_ACPI_STATUS (AE_NO_MEMORY); } + /* Complete the buffer object initialization */ + BufferDesc->Common.Flags = AOPOBJ_DATA_VALID; BufferDesc->Buffer.Length = Length; Buffer = BufferDesc->Buffer.Pointer; @@ -242,14 +226,14 @@ return_ACPI_STATUS (AE_NO_MEMORY); } - Length = IntegerSize; + Length = AcpiGbl_IntegerByteWidth; BufferDesc->Integer.Value = 0; Buffer = &BufferDesc->Integer.Value; } ACPI_DEBUG_PRINT ((ACPI_DB_BFIELD, "Obj=%p Type=%X Buf=%p Len=%X\n", - ObjDesc, ObjDesc->Common.Type, Buffer, Length)); + ObjDesc, ACPI_GET_OBJECT_TYPE (ObjDesc), Buffer, Length)); ACPI_DEBUG_PRINT ((ACPI_DB_BFIELD, "FieldWrite: BitLen=%X BitOff=%X ByteOff=%X\n", ObjDesc->CommonField.BitLength, @@ -316,7 +300,7 @@ return_ACPI_STATUS (AE_AML_NO_OPERAND); } - if (ObjDesc->Common.Type == ACPI_TYPE_BUFFER_FIELD) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) == ACPI_TYPE_BUFFER_FIELD) { /* * If the BufferField arguments have not been previously evaluated, @@ -335,7 +319,7 @@ /* * Get a pointer to the data to be written */ - switch (SourceDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (SourceDesc)) { case ACPI_TYPE_INTEGER: Buffer = &SourceDesc->Integer.Value; @@ -387,7 +371,7 @@ ACPI_DEBUG_PRINT ((ACPI_DB_BFIELD, "Obj=%p Type=%X Buf=%p Len=%X\n", - ObjDesc, ObjDesc->Common.Type, Buffer, Length)); + ObjDesc, ACPI_GET_OBJECT_TYPE (ObjDesc), Buffer, Length)); ACPI_DEBUG_PRINT ((ACPI_DB_BFIELD, "FieldRead: BitLen=%X BitOff=%X ByteOff=%X\n", ObjDesc->CommonField.BitLength, Index: exfldio.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exfldio.c,v retrieving revision 1.11 diff -u -r1.11 exfldio.c --- exfldio.c 30 Jun 2002 17:53:04 -0000 1.11 +++ exfldio.c 1 Jul 2002 21:39:53 -0000 @@ -120,8 +120,6 @@ #include "acpi.h" #include "acinterp.h" #include "amlcode.h" -#include "acnamesp.h" -#include "achware.h" #include "acevents.h" #include "acdispat.h" @@ -159,10 +157,12 @@ RgnDesc = ObjDesc->CommonField.RegionObj; - if (ACPI_TYPE_REGION != RgnDesc->Common.Type) + if (ACPI_GET_OBJECT_TYPE (RgnDesc) != ACPI_TYPE_REGION) { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Needed Region, found type %x %s\n", - RgnDesc->Common.Type, AcpiUtGetTypeName (RgnDesc->Common.Type))); + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Needed Region, found type %X (%s)\n", + ACPI_GET_OBJECT_TYPE (RgnDesc), + AcpiUtGetObjectTypeName (RgnDesc))); + return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -197,8 +197,8 @@ */ ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Field [%4.4s] access width (%d bytes) too large for region [%4.4s] (length %X)\n", - (char *) &ObjDesc->CommonField.Node->Name, ObjDesc->CommonField.AccessByteWidth, - (char *) &RgnDesc->Region.Node->Name, RgnDesc->Region.Length)); + ObjDesc->CommonField.Node->Name.Ascii, ObjDesc->CommonField.AccessByteWidth, + RgnDesc->Region.Node->Name.Ascii, RgnDesc->Region.Length)); } /* @@ -207,9 +207,9 @@ */ ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Field [%4.4s] Base+Offset+Width %X+%X+%X is beyond end of region [%4.4s] (length %X)\n", - (char *) &ObjDesc->CommonField.Node->Name, ObjDesc->CommonField.BaseByteOffset, + ObjDesc->CommonField.Node->Name.Ascii, ObjDesc->CommonField.BaseByteOffset, FieldDatumByteOffset, ObjDesc->CommonField.AccessByteWidth, - (char *) &RgnDesc->Region.Node->Name, RgnDesc->Region.Length)); + RgnDesc->Region.Node->Name.Ascii, RgnDesc->Region.Length)); return_ACPI_STATUS (AE_AML_REGION_LIMIT); } @@ -339,7 +339,7 @@ return (FALSE); } - if (Value >= (ACPI_INTEGER) (1 << ObjDesc->CommonField.BitLength)) + if (Value >= ((ACPI_INTEGER) 1 << ObjDesc->CommonField.BitLength)) { /* * The Value is larger than the maximum value that can fit into @@ -407,7 +407,7 @@ * BankFields - Write to a Bank Register, then read/write from/to an OpRegion * IndexFields - Write to an Index Register, then read/write from/to a Data Register */ - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_BUFFER_FIELD: /* @@ -455,7 +455,7 @@ /* Ensure that the BankValue is not beyond the capacity of the register */ if (AcpiExRegisterOverflow (ObjDesc->BankField.BankObj, - ObjDesc->BankField.Value)) + (ACPI_INTEGER) ObjDesc->BankField.Value)) { return_ACPI_STATUS (AE_AML_REGISTER_LIMIT); } @@ -477,7 +477,7 @@ * RegionField case and write the datum to the Operation Region */ - /* No break; ! */ + /*lint -fallthrough */ case INTERNAL_TYPE_REGION_FIELD: @@ -502,7 +502,7 @@ /* Ensure that the IndexValue is not beyond the capacity of the register */ if (AcpiExRegisterOverflow (ObjDesc->IndexField.IndexObj, - ObjDesc->IndexField.Value)) + (ACPI_INTEGER) ObjDesc->IndexField.Value)) { return_ACPI_STATUS (AE_AML_REGISTER_LIMIT); } @@ -537,7 +537,7 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "%p, Wrong object type - %s\n", - ObjDesc, AcpiUtGetTypeName (ObjDesc->Common.Type))); + ObjDesc, AcpiUtGetObjectTypeName (ObjDesc))); Status = AE_AML_INTERNAL; break; } @@ -594,7 +594,7 @@ /* If the mask is all ones, we don't need to worry about the update rule */ - if (Mask != ACPI_UINT32_MAX) + if (Mask != ACPI_INTEGER_MAX) { /* Decode the update rule */ @@ -634,7 +634,7 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, - "WriteWithUpdateRule: Unknown UpdateRule setting: %x\n", + "WriteWithUpdateRule: Unknown UpdateRule setting: %X\n", (ObjDesc->CommonField.FieldFlags & AML_FIELD_UPDATE_RULE_MASK))); return_ACPI_STATUS (AE_AML_OPERAND_VALUE); } @@ -705,6 +705,10 @@ ACPI_MOVE_UNALIGNED64_TO_64 (Datum, &(((UINT64 *) Buffer) [Offset])); break; + + default: + /* Should not get here */ + break; } } @@ -758,6 +762,10 @@ ACPI_MOVE_UNALIGNED64_TO_64 (&(((UINT64 *) Buffer)[Offset]), &MergedDatum); break; + + default: + /* Should not get here */ + break; } } @@ -813,7 +821,7 @@ ObjDesc->CommonField.AccessByteWidth); ACPI_DEBUG_PRINT ((ACPI_DB_BFIELD, - "ByteLen=%x, DatumLen=%x, ByteGran=%x\n", + "ByteLen=%X, DatumLen=%X, ByteGran=%X\n", ByteFieldLength, DatumCount,ObjDesc->CommonField.AccessByteWidth)); /* @@ -1002,7 +1010,7 @@ DatumCount = ACPI_ROUND_UP_TO (ByteFieldLength, ObjDesc->CommonField.AccessByteWidth); ACPI_DEBUG_PRINT ((ACPI_DB_BFIELD, - "ByteLen=%x, DatumLen=%x, ByteGran=%x\n", + "ByteLen=%X, DatumLen=%X, ByteGran=%X\n", ByteFieldLength, DatumCount, ObjDesc->CommonField.AccessByteWidth)); /* Index: exmisc.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exmisc.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 exmisc.c --- exmisc.c 23 Feb 2002 05:10:35 -0000 1.1.1.12 +++ exmisc.c 1 Jul 2002 21:39:53 -0000 @@ -119,7 +119,6 @@ #define __EXMISC_C__ #include "acpi.h" -#include "acparser.h" #include "acinterp.h" #include "amlcode.h" #include "acdispat.h" @@ -157,9 +156,9 @@ switch (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc)) { - case ACPI_DESC_TYPE_INTERNAL: + case ACPI_DESC_TYPE_OPERAND: - if (ObjDesc->Common.Type != INTERNAL_TYPE_REFERENCE) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) != INTERNAL_TYPE_REFERENCE) { *ReturnDesc = NULL; Status = AE_TYPE; @@ -177,7 +176,7 @@ Status = AcpiDsMethodDataGetNode (ObjDesc->Reference.Opcode, ObjDesc->Reference.Offset, WalkState, - (ACPI_NAMESPACE_NODE **) ReturnDesc); + ACPI_CAST_INDIRECT_PTR (ACPI_NAMESPACE_NODE, ReturnDesc)); break; default: @@ -284,15 +283,15 @@ ACPI_MEMCPY (NewBuf, ObjDesc1->Buffer.Pointer, Length1); ACPI_MEMCPY (NewBuf + Length1, ObjDesc2->Buffer.Pointer, Length2); - /* - * Point the return object to the new buffer - */ + /* Complete the buffer object initialization */ + + ReturnDesc->Common.Flags = AOPOBJ_DATA_VALID; ReturnDesc->Buffer.Pointer = (UINT8 *) NewBuf; - ReturnDesc->Buffer.Length = Length1 + Length2; + ReturnDesc->Buffer.Length = (UINT32) (Length1 + Length2); /* Compute the new checksum */ - NewBuf[ReturnDesc->Buffer.Length - 1] = + NewBuf[ReturnDesc->Buffer.Length - 1] = (NATIVE_CHAR) AcpiUtGenerateChecksum (ReturnDesc->Buffer.Pointer, (ReturnDesc->Buffer.Length - 1)); @@ -336,7 +335,6 @@ ACPI_INTEGER ThisInteger; ACPI_OPERAND_OBJECT *ReturnDesc; NATIVE_CHAR *NewBuf; - UINT32 IntegerSize = sizeof (ACPI_INTEGER); ACPI_FUNCTION_ENTRY (); @@ -344,27 +342,16 @@ /* * There are three cases to handle: - * 1) Two Integers concatenated to produce a buffer - * 2) Two Strings concatenated to produce a string - * 3) Two Buffers concatenated to produce a buffer + * + * 1) Two Integers concatenated to produce a new Buffer + * 2) Two Strings concatenated to produce a new String + * 3) Two Buffers concatenated to produce a new Buffer */ - switch (ObjDesc1->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc1)) { case ACPI_TYPE_INTEGER: - /* Handle both ACPI 1.0 and ACPI 2.0 Integer widths */ - - if (WalkState->MethodNode->Flags & ANOBJ_DATA_WIDTH_32) - { - /* - * We are running a method that exists in a 32-bit ACPI table. - * Truncate the value to 32 bits by zeroing out the upper - * 32-bit field - */ - IntegerSize = sizeof (UINT32); - } - - /* Result of two integers is a buffer */ + /* Result of two Integers is a Buffer */ ReturnDesc = AcpiUtCreateInternalObject (ACPI_TYPE_BUFFER); if (!ReturnDesc) @@ -372,9 +359,9 @@ return (AE_NO_MEMORY); } - /* Need enough space for two integers */ + /* Need enough buffer space for two integers */ - ReturnDesc->Buffer.Length = IntegerSize * 2; + ReturnDesc->Buffer.Length = AcpiGbl_IntegerByteWidth * 2; NewBuf = ACPI_MEM_CALLOCATE (ReturnDesc->Buffer.Length); if (!NewBuf) { @@ -384,31 +371,35 @@ goto Cleanup; } - ReturnDesc->Buffer.Pointer = (UINT8 *) NewBuf; - /* Convert the first integer */ ThisInteger = ObjDesc1->Integer.Value; - for (i = 0; i < IntegerSize; i++) + for (i = 0; i < AcpiGbl_IntegerByteWidth; i++) { - NewBuf[i] = (UINT8) ThisInteger; + NewBuf[i] = (NATIVE_CHAR) ThisInteger; ThisInteger >>= 8; } /* Convert the second integer */ ThisInteger = ObjDesc2->Integer.Value; - for (; i < (IntegerSize * 2); i++) + for (; i < (ACPI_MUL_2 (AcpiGbl_IntegerByteWidth)); i++) { - NewBuf[i] = (UINT8) ThisInteger; + NewBuf[i] = (NATIVE_CHAR) ThisInteger; ThisInteger >>= 8; } + /* Complete the buffer object initialization */ + + ReturnDesc->Common.Flags = AOPOBJ_DATA_VALID; + ReturnDesc->Buffer.Pointer = (UINT8 *) NewBuf; break; case ACPI_TYPE_STRING: + /* Result of two Strings is a String */ + ReturnDesc = AcpiUtCreateInternalObject (ACPI_TYPE_STRING); if (!ReturnDesc) { @@ -417,8 +408,8 @@ /* Operand0 is string */ - NewBuf = ACPI_MEM_ALLOCATE (ObjDesc1->String.Length + - ObjDesc2->String.Length + 1); + NewBuf = ACPI_MEM_ALLOCATE ((ACPI_SIZE) ObjDesc1->String.Length + + (ACPI_SIZE) ObjDesc2->String.Length + 1); if (!NewBuf) { ACPI_REPORT_ERROR @@ -427,11 +418,13 @@ goto Cleanup; } + /* Concatenate the strings */ + ACPI_STRCPY (NewBuf, ObjDesc1->String.Pointer); ACPI_STRCPY (NewBuf + ObjDesc1->String.Length, ObjDesc2->String.Pointer); - /* Point the return object to the new string */ + /* Complete the String object initialization */ ReturnDesc->String.Pointer = NewBuf; ReturnDesc->String.Length = ObjDesc1->String.Length + @@ -441,7 +434,7 @@ case ACPI_TYPE_BUFFER: - /* Operand0 is a buffer */ + /* Result of two Buffers is a Buffer */ ReturnDesc = AcpiUtCreateInternalObject (ACPI_TYPE_BUFFER); if (!ReturnDesc) @@ -449,8 +442,8 @@ return (AE_NO_MEMORY); } - NewBuf = ACPI_MEM_ALLOCATE (ObjDesc1->Buffer.Length + - ObjDesc2->Buffer.Length); + NewBuf = ACPI_MEM_ALLOCATE ((ACPI_SIZE) ObjDesc1->Buffer.Length + + (ACPI_SIZE) ObjDesc2->Buffer.Length); if (!NewBuf) { ACPI_REPORT_ERROR @@ -459,22 +452,26 @@ goto Cleanup; } + /* Concatenate the buffers */ + ACPI_MEMCPY (NewBuf, ObjDesc1->Buffer.Pointer, ObjDesc1->Buffer.Length); ACPI_MEMCPY (NewBuf + ObjDesc1->Buffer.Length, ObjDesc2->Buffer.Pointer, ObjDesc2->Buffer.Length); - /* - * Point the return object to the new buffer - */ + /* Complete the buffer object initialization */ + ReturnDesc->Common.Flags = AOPOBJ_DATA_VALID; ReturnDesc->Buffer.Pointer = (UINT8 *) NewBuf; - ReturnDesc->Buffer.Length = ObjDesc1->Buffer.Length + - ObjDesc2->Buffer.Length; + ReturnDesc->Buffer.Length = ObjDesc1->Buffer.Length + + ObjDesc2->Buffer.Length; break; default: + + /* Invalid object type, should not happen here */ + Status = AE_AML_INTERNAL; ReturnDesc = NULL; } @@ -646,6 +643,9 @@ { return (TRUE); } + break; + + default: break; } Index: exmutex.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exmutex.c,v retrieving revision 1.1.1.4 diff -u -r1.1.1.4 exmutex.c --- exmutex.c 23 Feb 2002 05:10:35 -0000 1.1.1.4 +++ exmutex.c 1 Jul 2002 21:39:53 -0000 @@ -119,9 +119,6 @@ #include "acpi.h" #include "acinterp.h" -#include "acnamesp.h" -#include "achware.h" -#include "acevents.h" #define _COMPONENT ACPI_EXECUTER ACPI_MODULE_NAME ("exmutex") @@ -375,12 +372,13 @@ * ******************************************************************************/ -ACPI_STATUS +void AcpiExReleaseAllMutexes ( ACPI_THREAD_STATE *Thread) { ACPI_OPERAND_OBJECT *Next = Thread->AcquiredMutexList; ACPI_OPERAND_OBJECT *This; + ACPI_STATUS Status; ACPI_FUNCTION_ENTRY (); @@ -400,14 +398,16 @@ /* Release the mutex */ - AcpiExSystemReleaseMutex (This); + Status = AcpiExSystemReleaseMutex (This); + if (ACPI_FAILURE (Status)) + { + continue; + } /* Mark mutex unowned */ This->Mutex.OwnerThread = NULL; } - - return (AE_OK); } Index: exnames.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exnames.c,v retrieving revision 1.1.1.9 diff -u -r1.1.1.9 exnames.c --- exnames.c 23 Feb 2002 05:10:35 -0000 1.1.1.9 +++ exnames.c 1 Jul 2002 21:39:53 -0000 @@ -120,7 +120,6 @@ #include "acpi.h" #include "acinterp.h" #include "amlcode.h" -#include "acnamesp.h" #define _COMPONENT ACPI_EXECUTER ACPI_MODULE_NAME ("exnames") @@ -248,10 +247,10 @@ UINT8 **InAmlAddress, NATIVE_CHAR *NameString) { - UINT8 *AmlAddress = *InAmlAddress; + char *AmlAddress = (void *) *InAmlAddress; ACPI_STATUS Status = AE_OK; UINT32 Index; - NATIVE_CHAR CharBuf[5]; + char CharBuf[5]; ACPI_FUNCTION_TRACE ("ExNameSegment"); @@ -271,18 +270,18 @@ ACPI_DEBUG_PRINT ((ACPI_DB_LOAD, "Bytes from stream:\n")); - for (Index = 4; - (Index > 0) && (AcpiUtValidAcpiCharacter (*AmlAddress)); - Index--) + for (Index = 0; + (Index < ACPI_NAME_SIZE) && (AcpiUtValidAcpiCharacter (*AmlAddress)); + Index++) { - CharBuf[4 - Index] = *AmlAddress++; - ACPI_DEBUG_PRINT ((ACPI_DB_LOAD, "%c\n", CharBuf[4 - Index])); + CharBuf[Index] = *AmlAddress++; + ACPI_DEBUG_PRINT ((ACPI_DB_LOAD, "%c\n", CharBuf[Index])); } /* Valid name segment */ - if (0 == Index) + if (Index == 4) { /* Found 4 valid characters */ @@ -300,7 +299,7 @@ "No Name string - %s \n", CharBuf)); } } - else if (4 == Index) + else if (Index == 0) { /* * First character was not a valid name character, @@ -320,7 +319,7 @@ *AmlAddress, AmlAddress)); } - *InAmlAddress = AmlAddress; + *InAmlAddress = (UINT8 *) AmlAddress; return_ACPI_STATUS (Status); } Index: exoparg1.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exoparg1.c,v retrieving revision 1.1.1.4 diff -u -r1.1.1.4 exoparg1.c --- exoparg1.c 30 Jun 2002 17:50:44 -0000 1.1.1.4 +++ exoparg1.c 1 Jul 2002 21:39:53 -0000 @@ -306,7 +306,8 @@ ACPI_FUNCTION_TRACE_STR ("ExOpcode_1A_1T_1R", AcpiPsGetOpcodeName (WalkState->Opcode)); - /* Create a return object of type Integer for most opcodes */ + + /* Examine the AML opcode */ switch (WalkState->Opcode) { @@ -317,6 +318,8 @@ case AML_TO_BCD_OP: case AML_COND_REF_OF_OP: + /* Create a return object of type Integer for these opcodes */ + ReturnDesc = AcpiUtCreateInternalObject (ACPI_TYPE_INTEGER); if (!ReturnDesc) { @@ -324,163 +327,164 @@ goto Cleanup; } - break; - } + switch (WalkState->Opcode) + { + case AML_BIT_NOT_OP: /* Not (Operand, Result) */ - /* Examine the AML opcode */ + ReturnDesc->Integer.Value = ~Operand[0]->Integer.Value; + break; - switch (WalkState->Opcode) - { - case AML_BIT_NOT_OP: /* Not (Operand, Result) */ + case AML_FIND_SET_LEFT_BIT_OP: /* FindSetLeftBit (Operand, Result) */ - ReturnDesc->Integer.Value = ~Operand[0]->Integer.Value; - break; + ReturnDesc->Integer.Value = Operand[0]->Integer.Value; + /* + * Acpi specification describes Integer type as a little + * endian unsigned value, so this boundary condition is valid. + */ + for (Temp32 = 0; ReturnDesc->Integer.Value && Temp32 < ACPI_INTEGER_BIT_SIZE; ++Temp32) + { + ReturnDesc->Integer.Value >>= 1; + } - case AML_FIND_SET_LEFT_BIT_OP: /* FindSetLeftBit (Operand, Result) */ + ReturnDesc->Integer.Value = Temp32; + break; - ReturnDesc->Integer.Value = Operand[0]->Integer.Value; - /* - * Acpi specification describes Integer type as a little - * endian unsigned value, so this boundary condition is valid. - */ - for (Temp32 = 0; ReturnDesc->Integer.Value && Temp32 < ACPI_INTEGER_BIT_SIZE; ++Temp32) - { - ReturnDesc->Integer.Value >>= 1; - } + case AML_FIND_SET_RIGHT_BIT_OP: /* FindSetRightBit (Operand, Result) */ - ReturnDesc->Integer.Value = Temp32; - break; + ReturnDesc->Integer.Value = Operand[0]->Integer.Value; + /* + * The Acpi specification describes Integer type as a little + * endian unsigned value, so this boundary condition is valid. + */ + for (Temp32 = 0; ReturnDesc->Integer.Value && Temp32 < ACPI_INTEGER_BIT_SIZE; ++Temp32) + { + ReturnDesc->Integer.Value <<= 1; + } - case AML_FIND_SET_RIGHT_BIT_OP: /* FindSetRightBit (Operand, Result) */ + /* Since the bit position is one-based, subtract from 33 (65) */ - ReturnDesc->Integer.Value = Operand[0]->Integer.Value; + ReturnDesc->Integer.Value = Temp32 == 0 ? 0 : (ACPI_INTEGER_BIT_SIZE + 1) - Temp32; + break; - /* - * The Acpi specification describes Integer type as a little - * endian unsigned value, so this boundary condition is valid. - */ - for (Temp32 = 0; ReturnDesc->Integer.Value && Temp32 < ACPI_INTEGER_BIT_SIZE; ++Temp32) - { - ReturnDesc->Integer.Value <<= 1; - } - /* Since the bit position is one-based, subtract from 33 (65) */ + case AML_FROM_BCD_OP: /* FromBcd (BCDValue, Result) */ - ReturnDesc->Integer.Value = Temp32 == 0 ? 0 : (ACPI_INTEGER_BIT_SIZE + 1) - Temp32; - break; + /* + * The 64-bit ACPI integer can hold 16 4-bit BCD integers + */ + ReturnDesc->Integer.Value = 0; + for (i = 0; i < ACPI_MAX_BCD_DIGITS; i++) + { + /* Get one BCD digit */ + Digit = (ACPI_INTEGER) ((Operand[0]->Integer.Value >> (i * 4)) & 0xF); - case AML_FROM_BCD_OP: /* FromBcd (BCDValue, Result) */ + /* Check the range of the digit */ - /* - * The 64-bit ACPI integer can hold 16 4-bit BCD integers - */ - ReturnDesc->Integer.Value = 0; - for (i = 0; i < ACPI_MAX_BCD_DIGITS; i++) - { - /* Get one BCD digit */ + if (Digit > 9) + { + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "BCD digit too large: %d\n", + (UINT32) Digit)); + Status = AE_AML_NUMERIC_OVERFLOW; + goto Cleanup; + } + + if (Digit > 0) + { + /* Sum into the result with the appropriate power of 10 */ - Digit = (ACPI_INTEGER) ((Operand[0]->Integer.Value >> (i * 4)) & 0xF); + for (j = 0; j < i; j++) + { + Digit *= 10; + } - /* Check the range of the digit */ + ReturnDesc->Integer.Value += Digit; + } + } + break; - if (Digit > 9) + + case AML_TO_BCD_OP: /* ToBcd (Operand, Result) */ + + if (Operand[0]->Integer.Value > ACPI_MAX_BCD_VALUE) { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "BCD digit too large: %d\n", - (UINT32) Digit)); + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "BCD overflow: %8.8X%8.8X\n", + ACPI_HIDWORD(Operand[0]->Integer.Value), + ACPI_LODWORD(Operand[0]->Integer.Value))); Status = AE_AML_NUMERIC_OVERFLOW; goto Cleanup; } - if (Digit > 0) + ReturnDesc->Integer.Value = 0; + for (i = 0; i < ACPI_MAX_BCD_DIGITS; i++) { - /* Sum into the result with the appropriate power of 10 */ + /* Divide by nth factor of 10 */ + Temp32 = 0; + Digit = Operand[0]->Integer.Value; for (j = 0; j < i; j++) { - Digit *= 10; + (void) AcpiUtShortDivide (&Digit, 10, &Digit, &Temp32); } - ReturnDesc->Integer.Value += Digit; - } - } - break; - + /* Create the BCD digit from the remainder above */ - case AML_TO_BCD_OP: /* ToBcd (Operand, Result) */ + if (Digit > 0) + { + ReturnDesc->Integer.Value += ((ACPI_INTEGER) Temp32 << (i * 4)); + } + } + break; - if (Operand[0]->Integer.Value > ACPI_MAX_BCD_VALUE) - { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "BCD overflow: %8.8X%8.8X\n", - ACPI_HIDWORD(Operand[0]->Integer.Value), - ACPI_LODWORD(Operand[0]->Integer.Value))); - Status = AE_AML_NUMERIC_OVERFLOW; - goto Cleanup; - } - ReturnDesc->Integer.Value = 0; - for (i = 0; i < ACPI_MAX_BCD_DIGITS; i++) - { - /* Divide by nth factor of 10 */ + case AML_COND_REF_OF_OP: /* CondRefOf (SourceObject, Result) */ - Temp32 = 0; - Digit = Operand[0]->Integer.Value; - for (j = 0; j < i; j++) + /* + * This op is a little strange because the internal return value is + * different than the return value stored in the result descriptor + * (There are really two return values) + */ + if ((ACPI_NAMESPACE_NODE *) Operand[0] == AcpiGbl_RootNode) { - AcpiUtShortDivide (&Digit, 10, &Digit, &Temp32); + /* + * This means that the object does not exist in the namespace, + * return FALSE + */ + ReturnDesc->Integer.Value = 0; + + /* + * Must delete the result descriptor since there is no reference + * being returned + */ + AcpiUtRemoveReference (Operand[1]); + goto Cleanup; } - /* Create the BCD digit from the remainder above */ + /* Get the object reference and store it */ - if (Digit > 0) + Status = AcpiExGetObjectReference (Operand[0], &ReturnDesc2, WalkState); + if (ACPI_FAILURE (Status)) { - ReturnDesc->Integer.Value += ((ACPI_INTEGER) Temp32 << (i * 4)); + goto Cleanup; } - } - break; + Status = AcpiExStore (ReturnDesc2, Operand[1], WalkState); - case AML_COND_REF_OF_OP: /* CondRefOf (SourceObject, Result) */ + /* The object exists in the namespace, return TRUE */ - /* - * This op is a little strange because the internal return value is - * different than the return value stored in the result descriptor - * (There are really two return values) - */ - if ((ACPI_NAMESPACE_NODE *) Operand[0] == AcpiGbl_RootNode) - { - /* - * This means that the object does not exist in the namespace, - * return FALSE - */ - ReturnDesc->Integer.Value = 0; - - /* - * Must delete the result descriptor since there is no reference - * being returned - */ - AcpiUtRemoveReference (Operand[1]); + ReturnDesc->Integer.Value = ACPI_INTEGER_MAX; goto Cleanup; - } - /* Get the object reference and store it */ - Status = AcpiExGetObjectReference (Operand[0], &ReturnDesc2, WalkState); - if (ACPI_FAILURE (Status)) - { - goto Cleanup; + default: + /* No other opcodes get here */ + break; } - - Status = AcpiExStore (ReturnDesc2, Operand[1], WalkState); - - /* The object exists in the namespace, return TRUE */ - - ReturnDesc->Integer.Value = ACPI_INTEGER_MAX; - goto Cleanup; + break; case AML_STORE_OP: /* Store (Source, Target) */ @@ -633,7 +637,7 @@ * can be either a NS Node or an internal object. */ ReturnDesc = Operand[0]; - if (ACPI_GET_DESCRIPTOR_TYPE (Operand[0]) == ACPI_DESC_TYPE_INTERNAL) + if (ACPI_GET_DESCRIPTOR_TYPE (Operand[0]) == ACPI_DESC_TYPE_OPERAND) { /* Internal reference object - prevent deletion */ @@ -674,7 +678,7 @@ case AML_TYPE_OP: /* ObjectType (SourceObject) */ - if (INTERNAL_TYPE_REFERENCE == Operand[0]->Common.Type) + if (ACPI_GET_OBJECT_TYPE (Operand[0]) == INTERNAL_TYPE_REFERENCE) { /* * Not a Name -- an indirect name pointer would have @@ -682,17 +686,6 @@ */ switch (Operand[0]->Reference.Opcode) { - case AML_ZERO_OP: - case AML_ONE_OP: - case AML_ONES_OP: - case AML_REVISION_OP: - - /* Constants are of type Integer */ - - Type = ACPI_TYPE_INTEGER; - break; - - case AML_DEBUG_OP: /* The Debug Object is of type "DebugObject" */ @@ -713,7 +706,7 @@ * of the individual package element that is referenced by * the index. */ - Type = (*(Operand[0]->Reference.Where))->Common.Type; + Type = ACPI_GET_OBJECT_TYPE (*(Operand[0]->Reference.Where)); } break; @@ -728,7 +721,7 @@ default: - ACPI_REPORT_ERROR (("AcpiExOpcode_1A_0T_1R/TypeOp: Internal error - Unknown Reference subtype %X\n", + ACPI_REPORT_ERROR (("AcpiExOpcode_1A_0T_1R/TypeOp: Unknown Reference subtype %X\n", Operand[0]->Reference.Opcode)); Status = AE_AML_INTERNAL; goto Cleanup; @@ -750,6 +743,11 @@ case INTERNAL_TYPE_INDEX_FIELD: Type = ACPI_TYPE_FIELD_UNIT; + break; + + default: + /* No change to Type required */ + break; } } @@ -786,7 +784,7 @@ * point (even if the original operand was an object reference, it * will be resolved and typechecked during operand resolution.) */ - switch (TempDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (TempDesc)) { case ACPI_TYPE_BUFFER: Value = TempDesc->Buffer.Length; @@ -802,7 +800,7 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "SizeOf, Not Buf/Str/Pkg - found type %s\n", - AcpiUtGetTypeName (TempDesc->Common.Type))); + AcpiUtGetObjectTypeName (TempDesc))); Status = AE_AML_OPERAND_TYPE; goto Cleanup; } @@ -854,8 +852,12 @@ /* Set Operand[0] to the value of the local/arg */ - AcpiDsMethodDataGetValue (Operand[0]->Reference.Opcode, - Operand[0]->Reference.Offset, WalkState, &TempDesc); + Status = AcpiDsMethodDataGetValue (Operand[0]->Reference.Opcode, + Operand[0]->Reference.Offset, WalkState, &TempDesc); + if (ACPI_FAILURE (Status)) + { + goto Cleanup; + } /* * Delete our reference to the input object and @@ -882,14 +884,16 @@ * 2) Dereference the node to an actual object. Could be a Field, so we nee * to resolve the node to a value. */ - Status = AcpiNsGetNodeByPath (Operand[0]->String.Pointer, WalkState->ScopeInfo->Scope.Node, - ACPI_NS_SEARCH_PARENT, (ACPI_NAMESPACE_NODE **) &ReturnDesc); + Status = AcpiNsGetNodeByPath (Operand[0]->String.Pointer, + WalkState->ScopeInfo->Scope.Node, ACPI_NS_SEARCH_PARENT, + ACPI_CAST_INDIRECT_PTR (ACPI_NAMESPACE_NODE, &ReturnDesc)); if (ACPI_FAILURE (Status)) { goto Cleanup; } - Status = AcpiExResolveNodeToValue ((ACPI_NAMESPACE_NODE **) &ReturnDesc, WalkState); + Status = AcpiExResolveNodeToValue ( + ACPI_CAST_INDIRECT_PTR (ACPI_NAMESPACE_NODE, &ReturnDesc), WalkState); goto Cleanup; Index: exoparg2.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exoparg2.c,v retrieving revision 1.1.1.4 diff -u -r1.1.1.4 exoparg2.c --- exoparg2.c 30 Jun 2002 17:50:44 -0000 1.1.1.4 +++ exoparg2.c 1 Jul 2002 21:39:53 -0000 @@ -119,11 +119,9 @@ #include "acpi.h" #include "acparser.h" -#include "acnamesp.h" #include "acinterp.h" #include "acevents.h" #include "amlcode.h" -#include "acdispat.h" #define _COMPONENT ACPI_EXECUTER @@ -405,7 +403,7 @@ * guaranteed to be either Integer/String/Buffer by the operand * resolution mechanism above. */ - switch (Operand[0]->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (Operand[0])) { case ACPI_TYPE_INTEGER: Status = AcpiExConvertToInteger (Operand[1], &Operand[1], WalkState); @@ -466,7 +464,7 @@ /* * At this point, the Source operand is either a Package or a Buffer */ - if (Operand[0]->Common.Type == ACPI_TYPE_PACKAGE) + if (ACPI_GET_OBJECT_TYPE (Operand[0]) == ACPI_TYPE_PACKAGE) { /* Object to be indexed is a Package */ @@ -477,11 +475,11 @@ goto Cleanup; } - if ((Operand[2]->Common.Type == INTERNAL_TYPE_REFERENCE) && - (Operand[2]->Reference.Opcode == AML_ZERO_OP)) + if ((ACPI_GET_OBJECT_TYPE (Operand[2]) == ACPI_TYPE_INTEGER) && + (Operand[2]->Common.Flags & AOPOBJ_AML_CONSTANT)) { /* - * There is no actual result descriptor (the ZeroOp Result + * There is no actual result descriptor (the ZeroOp/Constant Result * descriptor is a placeholder), so just delete the placeholder and * return a reference to the package element */ @@ -496,7 +494,7 @@ */ TempDesc = Operand[0]->Package.Elements [Index]; ReturnDesc->Reference.Opcode = AML_INDEX_OP; - ReturnDesc->Reference.TargetType = TempDesc->Common.Type; + ReturnDesc->Reference.TargetType = ACPI_GET_OBJECT_TYPE (TempDesc); ReturnDesc->Reference.Object = TempDesc; Status = AcpiExStore (ReturnDesc, Operand[2], WalkState); Index: exoparg3.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exoparg3.c,v retrieving revision 1.1.1.3 diff -u -r1.1.1.3 exoparg3.c --- exoparg3.c 23 Feb 2002 05:10:35 -0000 1.1.1.3 +++ exoparg3.c 1 Jul 2002 21:39:53 -0000 @@ -181,7 +181,7 @@ case AML_FATAL_OP: /* Fatal (FatalType FatalCode FatalArg) */ ACPI_DEBUG_PRINT ((ACPI_DB_INFO, - "FatalOp: Type %x Code %x Arg %x <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<\n", + "FatalOp: Type %X Code %X Arg %X <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<\n", (UINT32) Operand[0]->Integer.Value, (UINT32) Operand[1]->Integer.Value, (UINT32) Operand[2]->Integer.Value)); @@ -197,7 +197,7 @@ /* * Always signal the OS! */ - AcpiOsSignal (ACPI_SIGNAL_FATAL, Fatal); + Status = AcpiOsSignal (ACPI_SIGNAL_FATAL, Fatal); /* Might return while OS is shutting down, just continue */ @@ -240,8 +240,8 @@ ACPI_OPERAND_OBJECT *ReturnDesc = NULL; char *Buffer; ACPI_STATUS Status = AE_OK; - UINT32 Index; - UINT32 Length; + NATIVE_UINT Index; + ACPI_SIZE Length; ACPI_FUNCTION_TRACE_STR ("ExOpcode_3A_1T_1R", AcpiPsGetOpcodeName (WalkState->Opcode)); @@ -255,7 +255,7 @@ * Create the return object. The Source operand is guaranteed to be * either a String or a Buffer, so just use its type. */ - ReturnDesc = AcpiUtCreateInternalObject (Operand[0]->Common.Type); + ReturnDesc = AcpiUtCreateInternalObject (ACPI_GET_OBJECT_TYPE (Operand[0])); if (!ReturnDesc) { Status = AE_NO_MEMORY; @@ -264,8 +264,8 @@ /* Get the Integer values from the objects */ - Index = (UINT32) Operand[1]->Integer.Value; - Length = (UINT32) Operand[2]->Integer.Value; + Index = (NATIVE_UINT) Operand[1]->Integer.Value; + Length = (ACPI_SIZE) Operand[2]->Integer.Value; /* * If the index is beyond the length of the String/Buffer, or if the @@ -279,12 +279,12 @@ if ((Index + Length) > Operand[0]->String.Length) { - Length = Operand[0]->String.Length - Index; + Length = (ACPI_SIZE) Operand[0]->String.Length - Index; } /* Allocate a new buffer for the String/Buffer */ - Buffer = ACPI_MEM_CALLOCATE (Length + 1); + Buffer = ACPI_MEM_CALLOCATE ((ACPI_SIZE) Length + 1); if (!Buffer) { Status = AE_NO_MEMORY; @@ -299,7 +299,7 @@ /* Set the length of the new String/Buffer */ ReturnDesc->String.Pointer = Buffer; - ReturnDesc->String.Length = Length; + ReturnDesc->String.Length = (UINT32) Length; } break; Index: exoparg6.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exoparg6.c,v retrieving revision 1.1.1.3 diff -u -r1.1.1.3 exoparg6.c --- exoparg6.c 23 Feb 2002 05:10:35 -0000 1.1.1.3 +++ exoparg6.c 1 Jul 2002 21:39:53 -0000 @@ -316,7 +316,7 @@ * Treat any NULL or non-numeric elements as non-matching. */ if (!ThisElement || - ThisElement->Common.Type != ACPI_TYPE_INTEGER) + ACPI_GET_OBJECT_TYPE (ThisElement) != ACPI_TYPE_INTEGER) { continue; } Index: exprep.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exprep.c,v retrieving revision 1.1.1.15 diff -u -r1.1.1.15 exprep.c --- exprep.c 30 Jun 2002 17:50:44 -0000 1.1.1.15 +++ exprep.c 1 Jul 2002 21:39:53 -0000 @@ -121,7 +121,6 @@ #include "acinterp.h" #include "amlcode.h" #include "acnamesp.h" -#include "acparser.h" #define _COMPONENT ACPI_EXECUTER @@ -149,16 +148,15 @@ UINT32 *ReturnByteAlignment) { UINT32 Access; - UINT32 Length; UINT8 ByteAlignment; UINT8 BitLength; +/* UINT32 Length; */ ACPI_FUNCTION_NAME ("ExDecodeFieldAccess"); Access = (FieldFlags & AML_FIELD_ACCESS_TYPE_MASK); - Length = ObjDesc->CommonField.BitLength; switch (Access) { @@ -179,6 +177,8 @@ /* Use the length to set the access type */ + Length = ObjDesc->CommonField.BitLength; + if (Length <= 8) { BitLength = 8; @@ -233,12 +233,12 @@ /* Invalid field access type */ ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, - "Unknown field access type %x\n", + "Unknown field access type %X\n", Access)); return (0); } - if (ObjDesc->Common.Type == ACPI_TYPE_BUFFER_FIELD) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) == ACPI_TYPE_BUFFER_FIELD) { /* * BufferField access can be on any byte boundary, so the @@ -518,6 +518,10 @@ ObjDesc->IndexField.IndexObj, ObjDesc->IndexField.DataObj)); break; + + default: + /* No other types should get here */ + break; } /* @@ -528,7 +532,7 @@ AcpiNsGetType (Info->FieldNode)); ACPI_DEBUG_PRINT ((ACPI_DB_BFIELD, "set NamedObj %p (%4.4s) val = %p\n", - Info->FieldNode, (char *) &(Info->FieldNode->Name), ObjDesc)); + Info->FieldNode, Info->FieldNode->Name.Ascii, ObjDesc)); /* Remove local reference to the object */ Index: exregion.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exregion.c,v retrieving revision 1.1.1.15 diff -u -r1.1.1.15 exregion.c --- exregion.c 30 Jun 2002 17:50:44 -0000 1.1.1.15 +++ exregion.c 1 Jul 2002 21:39:53 -0000 @@ -120,10 +120,6 @@ #include "acpi.h" #include "acinterp.h" -#include "amlcode.h" -#include "acnamesp.h" -#include "achware.h" -#include "acevents.h" #define _COMPONENT ACPI_EXECUTER @@ -161,8 +157,10 @@ void *LogicalAddrPtr = NULL; ACPI_MEM_SPACE_CONTEXT *MemInfo = RegionContext; UINT32 Length; - UINT32 WindowSize; - + ACPI_SIZE WindowSize; +#ifndef _HW_ALIGNMENT_SUPPORT + UINT32 Remainder; +#endif ACPI_FUNCTION_TRACE ("ExSystemMemorySpaceHandler"); @@ -193,6 +191,19 @@ return_ACPI_STATUS (AE_AML_OPERAND_VALUE); } + +#ifndef _HW_ALIGNMENT_SUPPORT + /* + * Hardware does not support non-aligned data transfers, we must verify + * the request. + */ + (void) AcpiUtShortDivide ((ACPI_INTEGER *) &Address, Length, NULL, &Remainder); + if (Remainder != 0) + { + return_ACPI_STATUS (AE_AML_ALIGNMENT); + } +#endif + /* * Does the request fit into the cached memory mapping? * Is 1) Address below the current mapping? OR @@ -218,7 +229,7 @@ * Don't attempt to map memory beyond the end of the region, and * constrain the maximum mapping size to something reasonable. */ - WindowSize = (UINT32) ((MemInfo->Address + MemInfo->Length) - Address); + WindowSize = (ACPI_SIZE) ((MemInfo->Address + MemInfo->Length) - Address); if (WindowSize > SYSMEM_REGION_WINDOW_SIZE) { WindowSize = SYSMEM_REGION_WINDOW_SIZE; @@ -230,6 +241,8 @@ (void **) &MemInfo->MappedLogicalAddress); if (ACPI_FAILURE (Status)) { + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Could not map memory at %8.8X%8.8X, size %X\n", + ACPI_HIDWORD (Address), ACPI_LODWORD (Address), (UINT32) WindowSize)); MemInfo->MappedLength = 0; return_ACPI_STATUS (Status); } @@ -251,8 +264,14 @@ "SystemMemory %d (%d width) Address=%8.8X%8.8X\n", Function, BitWidth, ACPI_HIDWORD (Address), ACPI_LODWORD (Address))); - /* Perform the memory read or write */ - + /* + * Perform the memory read or write + * + * Note: For machines that do not support non-aligned transfers, the target + * address was checked for alignment above. We do not attempt to break the + * transfer up into smaller (byte-size) chunks because the AML specifically + * asked for a transfer width that the hardware may require. + */ switch (Function) { case ACPI_READ: @@ -261,19 +280,24 @@ switch (BitWidth) { case 8: - *Value = (UINT32)* (UINT8 *) LogicalAddrPtr; + *Value = (ACPI_INTEGER) *((UINT8 *) LogicalAddrPtr); break; case 16: - ACPI_MOVE_UNALIGNED16_TO_16 (Value, LogicalAddrPtr); + *Value = (ACPI_INTEGER) *((UINT16 *) LogicalAddrPtr); break; case 32: - ACPI_MOVE_UNALIGNED32_TO_32 (Value, LogicalAddrPtr); + *Value = (ACPI_INTEGER) *((UINT32 *) LogicalAddrPtr); break; +#if ACPI_MACHINE_WIDTH != 16 case 64: - ACPI_MOVE_UNALIGNED64_TO_64 (Value, LogicalAddrPtr); + *Value = (ACPI_INTEGER) *((UINT64 *) LogicalAddrPtr); + break; +#endif + default: + /* BitWidth was already validated */ break; } break; @@ -287,15 +311,21 @@ break; case 16: - ACPI_MOVE_UNALIGNED16_TO_16 (LogicalAddrPtr, Value); + *(UINT16 *) LogicalAddrPtr = (UINT16) *Value; break; case 32: - ACPI_MOVE_UNALIGNED32_TO_32 (LogicalAddrPtr, Value); + *(UINT32 *) LogicalAddrPtr = (UINT32) *Value; break; +#if ACPI_MACHINE_WIDTH != 16 case 64: - ACPI_MOVE_UNALIGNED64_TO_64 (LogicalAddrPtr, Value); + *(UINT64 *) LogicalAddrPtr = (UINT64) *Value; + break; +#endif + + default: + /* BitWidth was already validated */ break; } break; @@ -418,7 +448,7 @@ * */ PciId = (ACPI_PCI_ID *) RegionContext; - PciRegister = (UINT16) (ACPI_SIZE) Address; + PciRegister = (UINT16) (UINT32) Address; ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "PciConfig %d (%d) Seg(%04x) Bus(%04x) Dev(%04x) Func(%04x) Reg(%04x)\n", @@ -574,6 +604,7 @@ break; case ACPI_WRITE: + default: return_ACPI_STATUS (AE_SUPPORT); } Index: exresnte.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exresnte.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 exresnte.c --- exresnte.c 30 Jun 2002 17:50:44 -0000 1.1.1.13 +++ exresnte.c 1 Jul 2002 21:39:53 -0000 @@ -119,12 +119,9 @@ #include "acpi.h" #include "amlcode.h" -#include "acparser.h" #include "acdispat.h" #include "acinterp.h" #include "acnamesp.h" -#include "actables.h" -#include "acevents.h" #define _COMPONENT ACPI_EXECUTER @@ -168,7 +165,6 @@ ACPI_OPERAND_OBJECT *ObjDesc = NULL; ACPI_NAMESPACE_NODE *Node; ACPI_OBJECT_TYPE EntryType; - ACPI_INTEGER TempVal; ACPI_FUNCTION_TRACE ("ExResolveNodeToValue"); @@ -211,10 +207,10 @@ { case ACPI_TYPE_PACKAGE: - if (ACPI_TYPE_PACKAGE != SourceDesc->Common.Type) + if (ACPI_GET_OBJECT_TYPE (SourceDesc) != ACPI_TYPE_PACKAGE) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Object not a Package, type %s\n", - AcpiUtGetTypeName (SourceDesc->Common.Type))); + AcpiUtGetObjectTypeName (SourceDesc))); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -231,10 +227,10 @@ case ACPI_TYPE_BUFFER: - if (ACPI_TYPE_BUFFER != SourceDesc->Common.Type) + if (ACPI_GET_OBJECT_TYPE (SourceDesc) != ACPI_TYPE_BUFFER) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Object not a Buffer, type %s\n", - AcpiUtGetTypeName (SourceDesc->Common.Type))); + AcpiUtGetObjectTypeName (SourceDesc))); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -251,10 +247,10 @@ case ACPI_TYPE_STRING: - if (ACPI_TYPE_STRING != SourceDesc->Common.Type) + if (ACPI_GET_OBJECT_TYPE (SourceDesc) != ACPI_TYPE_STRING) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Object not a String, type %s\n", - AcpiUtGetTypeName (SourceDesc->Common.Type))); + AcpiUtGetObjectTypeName (SourceDesc))); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -267,10 +263,10 @@ case ACPI_TYPE_INTEGER: - if (ACPI_TYPE_INTEGER != SourceDesc->Common.Type) + if (ACPI_GET_OBJECT_TYPE (SourceDesc) != ACPI_TYPE_INTEGER) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Object not a Integer, type %s\n", - AcpiUtGetTypeName (SourceDesc->Common.Type))); + AcpiUtGetObjectTypeName (SourceDesc))); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -320,64 +316,14 @@ return_ACPI_STATUS (AE_AML_OPERAND_TYPE); /* Cannot be AE_TYPE */ - /* - * The only named references allowed are named constants - * e.g. -- Name (\OSFL, Ones) - */ case INTERNAL_TYPE_REFERENCE: - switch (SourceDesc->Reference.Opcode) - { - - case AML_ZERO_OP: - - TempVal = 0; - break; - - case AML_ONE_OP: - - TempVal = 1; - break; - - case AML_ONES_OP: - - TempVal = ACPI_INTEGER_MAX; - break; - - case AML_REVISION_OP: - - TempVal = ACPI_CA_SUPPORT_LEVEL; - break; + /* No named references are allowed here */ - default: + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unsupported reference opcode %X\n", + SourceDesc->Reference.Opcode)); - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unsupported reference opcode %X\n", - SourceDesc->Reference.Opcode)); - - return_ACPI_STATUS (AE_AML_BAD_OPCODE); - } - - /* Create object for result */ - - ObjDesc = AcpiUtCreateInternalObject (ACPI_TYPE_INTEGER); - if (!ObjDesc) - { - return_ACPI_STATUS (AE_NO_MEMORY); - } - - ObjDesc->Integer.Value = TempVal; - - /* - * Truncate value if we are executing from a 32-bit ACPI table - * AND actually executing AML code. If we are resolving - * an object in the namespace via an external call to the - * subsystem, we will have a null WalkState - */ - if (WalkState) - { - AcpiExTruncateFor32bitTable (ObjDesc, WalkState); - } - break; + return_ACPI_STATUS (AE_AML_OPERAND_TYPE); /* Default case is for unknown types */ Index: exresolv.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exresolv.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 exresolv.c --- exresolv.c 30 Jun 2002 17:50:44 -0000 1.1.1.13 +++ exresolv.c 1 Jul 2002 21:39:53 -0000 @@ -119,12 +119,8 @@ #include "acpi.h" #include "amlcode.h" -#include "acparser.h" #include "acdispat.h" #include "acinterp.h" -#include "acnamesp.h" -#include "actables.h" -#include "acevents.h" #define _COMPONENT ACPI_EXECUTER @@ -168,7 +164,7 @@ * 1) A valid ACPI_OPERAND_OBJECT, or * 2) A ACPI_NAMESPACE_NODE (NamedObj) */ - if (ACPI_GET_DESCRIPTOR_TYPE (*StackPtr) == ACPI_DESC_TYPE_INTERNAL) + if (ACPI_GET_DESCRIPTOR_TYPE (*StackPtr) == ACPI_DESC_TYPE_OPERAND) { Status = AcpiExResolveObjectToValue (StackPtr, WalkState); if (ACPI_FAILURE (Status)) @@ -183,7 +179,8 @@ */ if (ACPI_GET_DESCRIPTOR_TYPE (*StackPtr) == ACPI_DESC_TYPE_NAMED) { - Status = AcpiExResolveNodeToValue ((ACPI_NAMESPACE_NODE **) StackPtr, + Status = AcpiExResolveNodeToValue ( + ACPI_CAST_INDIRECT_PTR (ACPI_NAMESPACE_NODE, StackPtr), WalkState); if (ACPI_FAILURE (Status)) { @@ -230,7 +227,7 @@ /* This is an ACPI_OPERAND_OBJECT */ - switch (StackDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (StackDesc)) { case INTERNAL_TYPE_REFERENCE: @@ -281,54 +278,6 @@ StackDesc->Reference.Offset, ObjDesc)); break; - /* - * For constants, we must change the reference/constant object - * to a real integer object - */ - case AML_ZERO_OP: - case AML_ONE_OP: - case AML_ONES_OP: - case AML_REVISION_OP: - - /* Create a new integer object */ - - ObjDesc = AcpiUtCreateInternalObject (ACPI_TYPE_INTEGER); - if (!ObjDesc) - { - return_ACPI_STATUS (AE_NO_MEMORY); - } - - switch (Opcode) - { - case AML_ZERO_OP: - ObjDesc->Integer.Value = 0; - break; - - case AML_ONE_OP: - ObjDesc->Integer.Value = 1; - break; - - case AML_ONES_OP: - ObjDesc->Integer.Value = ACPI_INTEGER_MAX; - - /* Truncate value if we are executing from a 32-bit ACPI table */ - - AcpiExTruncateFor32bitTable (ObjDesc, WalkState); - break; - - case AML_REVISION_OP: - ObjDesc->Integer.Value = ACPI_CA_SUPPORT_LEVEL; - break; - } - - /* - * Remove a reference from the original reference object - * and put the new object in its place - */ - AcpiUtRemoveReference (StackDesc); - *StackPtr = ObjDesc; - break; - case AML_INDEX_OP: @@ -341,6 +290,7 @@ case ACPI_TYPE_PACKAGE: + ObjDesc = *StackDesc->Reference.Where; if (ObjDesc) { @@ -366,7 +316,9 @@ } break; + default: + /* Invalid reference object */ ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, @@ -386,14 +338,12 @@ default: - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown Reference object subtype %02X in %p\n", + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown Reference opcode %X in %p\n", Opcode, StackDesc)); Status = AE_AML_INTERNAL; break; - - } /* switch (Opcode) */ - - break; /* case INTERNAL_TYPE_REFERENCE */ + } + break; case ACPI_TYPE_BUFFER: @@ -417,7 +367,7 @@ case INTERNAL_TYPE_INDEX_FIELD: ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "FieldRead SourceDesc=%p Type=%X\n", - StackDesc, StackDesc->Common.Type)); + StackDesc, ACPI_GET_OBJECT_TYPE (StackDesc))); Status = AcpiExReadDataFromField (WalkState, StackDesc, &ObjDesc); *StackPtr = (void *) ObjDesc; Index: exresop.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exresop.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 exresop.c --- exresop.c 30 Jun 2002 17:50:44 -0000 1.1.1.12 +++ exresop.c 1 Jul 2002 21:39:53 -0000 @@ -120,11 +120,8 @@ #include "acpi.h" #include "amlcode.h" #include "acparser.h" -#include "acdispat.h" #include "acinterp.h" #include "acnamesp.h" -#include "actables.h" -#include "acevents.h" #define _COMPONENT ACPI_EXECUTER @@ -161,6 +158,20 @@ return (AE_OK); } + if (TypeNeeded == INTERNAL_TYPE_REFERENCE) + { + /* + * Allow the AML "Constant" opcodes (Zero, One, etc.) to be reference + * objects and thus allow them to be targets. (As per the ACPI + * specification, a store to a constant is a noop.) + */ + if ((ThisType == ACPI_TYPE_INTEGER) && + (((ACPI_OPERAND_OBJECT *) Object)->Common.Flags & AOPOBJ_AML_CONSTANT)) + { + return (AE_OK); + } + } + if (TypeNeeded != ThisType) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, @@ -182,18 +193,17 @@ * PARAMETERS: Opcode - Opcode being interpreted * StackPtr - Pointer to the operand stack to be * resolved - * WalkState - Current stateu + * WalkState - Current state * * RETURN: Status * * DESCRIPTION: Convert multiple input operands to the types required by the * target operator. * - * Each nibble (actually 5 bits) in ArgTypes represents one required - * operand and indicates the required Type: - * - * The corresponding operand will be converted to the required type if - * possible, otherwise we abort with an exception. + * Each 5-bit group in ArgTypes represents one required + * operand and indicates the required Type. The corresponding operand + * will be converted to the required type if possible, otherwise we + * abort with an exception. * ******************************************************************************/ @@ -267,11 +277,11 @@ break; - case ACPI_DESC_TYPE_INTERNAL: + case ACPI_DESC_TYPE_OPERAND: /* ACPI internal object */ - ObjectType = ObjDesc->Common.Type; + ObjectType = ACPI_GET_OBJECT_TYPE (ObjDesc); /* Check for bad ACPI_OBJECT_TYPE */ @@ -296,15 +306,11 @@ switch (ObjDesc->Reference.Opcode) { - case AML_ZERO_OP: - case AML_ONE_OP: - case AML_ONES_OP: case AML_DEBUG_OP: case AML_NAME_OP: case AML_INDEX_OP: case AML_ARG_OP: case AML_LOCAL_OP: - case AML_REVISION_OP: ACPI_DEBUG_ONLY_MEMBERS (ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Reference Opcode: %s\n", OpInfo->Name))); @@ -312,7 +318,7 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, - "Reference Opcode: Unknown [%02x]\n", + "Unknown Reference Opcode %X\n", ObjDesc->Reference.Opcode)); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); @@ -347,7 +353,7 @@ { case ARGI_REF_OR_STRING: /* Can be a String or Reference */ - if ((ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) == ACPI_DESC_TYPE_INTERNAL) && + if ((ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) == ACPI_DESC_TYPE_OPERAND) && (ACPI_GET_OBJECT_TYPE (ObjDesc) == ACPI_TYPE_STRING)) { /* @@ -358,6 +364,7 @@ } /* Else not a string - fall through to the normal Reference case below */ + /*lint -fallthrough */ case ARGI_REFERENCE: /* References: */ case ARGI_INTEGER_REF: @@ -403,12 +410,16 @@ * -- All others must be resolved below. */ if ((Opcode == AML_STORE_OP) && - ((*StackPtr)->Common.Type == INTERNAL_TYPE_REFERENCE) && + (ACPI_GET_OBJECT_TYPE (*StackPtr) == INTERNAL_TYPE_REFERENCE) && ((*StackPtr)->Reference.Opcode == AML_INDEX_OP)) { goto NextOperand; } break; + + default: + /* All cases covered above */ + break; } @@ -489,7 +500,7 @@ { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Needed [Integer/String/Buffer], found [%s] %p\n", - AcpiUtGetTypeName ((*StackPtr)->Common.Type), *StackPtr)); + AcpiUtGetObjectTypeName (*StackPtr), *StackPtr)); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -512,7 +523,7 @@ { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Needed [Integer/String/Buffer], found [%s] %p\n", - AcpiUtGetTypeName ((*StackPtr)->Common.Type), *StackPtr)); + AcpiUtGetObjectTypeName (*StackPtr), *StackPtr)); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -535,7 +546,7 @@ { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Needed [Integer/String/Buffer], found [%s] %p\n", - AcpiUtGetTypeName ((*StackPtr)->Common.Type), *StackPtr)); + AcpiUtGetObjectTypeName (*StackPtr), *StackPtr)); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -549,7 +560,7 @@ /* Need an operand of type INTEGER, STRING or BUFFER */ - switch ((*StackPtr)->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (*StackPtr)) { case ACPI_TYPE_INTEGER: case ACPI_TYPE_STRING: @@ -561,7 +572,7 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Needed [Integer/String/Buffer], found [%s] %p\n", - AcpiUtGetTypeName ((*StackPtr)->Common.Type), *StackPtr)); + AcpiUtGetObjectTypeName (*StackPtr), *StackPtr)); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -576,7 +587,7 @@ * The only reference allowed here is a direct reference to * a namespace node. */ - if ((*StackPtr)->Common.Type == INTERNAL_TYPE_REFERENCE) + if (ACPI_GET_OBJECT_TYPE (*StackPtr) == INTERNAL_TYPE_REFERENCE) { if (!(*StackPtr)->Reference.Node) { @@ -611,7 +622,7 @@ /* Need a buffer, string, package */ - switch ((*StackPtr)->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (*StackPtr)) { case ACPI_TYPE_PACKAGE: case ACPI_TYPE_STRING: @@ -623,7 +634,7 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Needed [Buf/Str/Pkg], found [%s] %p\n", - AcpiUtGetTypeName ((*StackPtr)->Common.Type), *StackPtr)); + AcpiUtGetObjectTypeName (*StackPtr), *StackPtr)); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -634,7 +645,7 @@ /* Need a buffer or package or (ACPI 2.0) String */ - switch ((*StackPtr)->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (*StackPtr)) { case ACPI_TYPE_PACKAGE: case ACPI_TYPE_STRING: @@ -646,7 +657,7 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Needed [Buf/Str/Pkg], found [%s] %p\n", - AcpiUtGetTypeName ((*StackPtr)->Common.Type), *StackPtr)); + AcpiUtGetObjectTypeName (*StackPtr), *StackPtr)); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -669,7 +680,7 @@ * required object type (Simple cases only). */ Status = AcpiExCheckObjectType (TypeNeeded, - (*StackPtr)->Common.Type, *StackPtr); + ACPI_GET_OBJECT_TYPE (*StackPtr), *StackPtr); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); Index: exstore.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exstore.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 exstore.c --- exstore.c 30 Jun 2002 17:50:44 -0000 1.1.1.14 +++ exstore.c 1 Jul 2002 21:39:53 -0000 @@ -118,12 +118,10 @@ #define __EXSTORE_C__ #include "acpi.h" -#include "acparser.h" #include "acdispat.h" #include "acinterp.h" #include "amlcode.h" #include "acnamesp.h" -#include "actables.h" #define _COMPONENT ACPI_EXECUTER @@ -185,19 +183,35 @@ return_ACPI_STATUS (Status); } - /* Destination object must be an object of type Reference */ + /* Destination object must be a Reference or a Constant object */ + + switch (ACPI_GET_OBJECT_TYPE (DestDesc)) + { + case INTERNAL_TYPE_REFERENCE: + break; + + case ACPI_TYPE_INTEGER: + + /* Allow stores to Constants -- a Noop as per ACPI spec */ + + if (DestDesc->Common.Flags & AOPOBJ_AML_CONSTANT) + { + return_ACPI_STATUS (AE_OK); + } + + /*lint: -fallthrough */ + + default: - if (DestDesc->Common.Type != INTERNAL_TYPE_REFERENCE) - { /* Destination is not an Reference */ ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, - "Destination is not a ReferenceObj [%p]\n", DestDesc)); + "Destination is not a Reference or Constant object [%p]\n", DestDesc)); ACPI_DUMP_STACK_ENTRY (SourceDesc); ACPI_DUMP_STACK_ENTRY (DestDesc); ACPI_DUMP_OPERANDS (&DestDesc, ACPI_IMODE_EXECUTE, "ExStore", - 2, "Target is not a ReferenceObj"); + 2, "Target is not a Reference or Constant object"); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -209,7 +223,6 @@ * 2) Store to an indexed area of a Buffer or Package * 3) Store to a Method Local or Arg * 4) Store to the debug object - * 5) Store to a constant -- a noop */ switch (RefDesc->Reference.Opcode) { @@ -249,9 +262,9 @@ ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "**** Write to Debug Object: ****:\n\n")); ACPI_DEBUG_PRINT_RAW ((ACPI_DB_DEBUG_OBJECT, "[ACPI Debug] %s: ", - AcpiUtGetTypeName (SourceDesc->Common.Type))); + AcpiUtGetObjectTypeName (SourceDesc))); - switch (SourceDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (SourceDesc)) { case ACPI_TYPE_INTEGER: @@ -284,7 +297,7 @@ default: ACPI_DEBUG_PRINT_RAW ((ACPI_DB_DEBUG_OBJECT, "Type %s %p\n", - AcpiUtGetTypeName (SourceDesc->Common.Type), SourceDesc)); + AcpiUtGetObjectTypeName (SourceDesc), SourceDesc)); break; } @@ -292,28 +305,15 @@ break; - case AML_ZERO_OP: - case AML_ONE_OP: - case AML_ONES_OP: - case AML_REVISION_OP: - - /* - * Storing to a constant is a no-op according to the ACPI - * Specification. (Delete the reference descriptor, however.) - */ - break; - - default: - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown Reference subtype %02x\n", + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown Reference opcode %X\n", RefDesc->Reference.Opcode)); ACPI_DUMP_ENTRY (RefDesc, ACPI_LV_ERROR); Status = AE_AML_INTERNAL; break; - - } /* switch (RefDesc->Reference.Opcode) */ + } return_ACPI_STATUS (Status); } @@ -405,7 +405,7 @@ * Make sure the target is a Buffer */ ObjDesc = IndexDesc->Reference.Object; - if (ObjDesc->Common.Type != ACPI_TYPE_BUFFER) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_BUFFER) { return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -414,7 +414,7 @@ * The assignment of the individual elements will be slightly * different for each source type. */ - switch (SourceDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (SourceDesc)) { case ACPI_TYPE_INTEGER: @@ -430,7 +430,7 @@ case ACPI_TYPE_STRING: - Value = SourceDesc->String.Pointer[0]; + Value = (UINT8) SourceDesc->String.Pointer[0]; break; default: @@ -439,7 +439,7 @@ ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Source must be Integer/Buffer/String type, not %s\n", - AcpiUtGetTypeName (SourceDesc->Common.Type))); + AcpiUtGetObjectTypeName (SourceDesc))); return_ACPI_STATUS (AE_AML_OPERAND_TYPE); } @@ -507,7 +507,7 @@ TargetDesc = AcpiNsGetAttachedObject (Node); ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Storing %p(%s) into node %p(%s)\n", - SourceDesc, AcpiUtGetTypeName (SourceDesc->Common.Type), + SourceDesc, AcpiUtGetObjectTypeName (SourceDesc), Node, AcpiUtGetTypeName (TargetType))); /* @@ -564,8 +564,8 @@ ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Store %s into %s via Convert/Attach\n", - AcpiUtGetTypeName (SourceDesc->Common.Type), - AcpiUtGetTypeName (NewDesc->Common.Type))); + AcpiUtGetObjectTypeName (SourceDesc), + AcpiUtGetObjectTypeName (NewDesc))); } break; @@ -574,11 +574,11 @@ ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Storing %s (%p) directly into node (%p), no implicit conversion\n", - AcpiUtGetTypeName (SourceDesc->Common.Type), SourceDesc, Node)); + AcpiUtGetObjectTypeName (SourceDesc), SourceDesc, Node)); /* No conversions for all other types. Just attach the source object */ - Status = AcpiNsAttachObject (Node, SourceDesc, SourceDesc->Common.Type); + Status = AcpiNsAttachObject (Node, SourceDesc, ACPI_GET_OBJECT_TYPE (SourceDesc)); break; } Index: exstoren.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exstoren.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 exstoren.c --- exstoren.c 30 Jun 2002 17:50:44 -0000 1.1.1.11 +++ exstoren.c 1 Jul 2002 21:39:53 -0000 @@ -119,12 +119,7 @@ #define __EXSTOREN_C__ #include "acpi.h" -#include "acparser.h" -#include "acdispat.h" #include "acinterp.h" -#include "amlcode.h" -#include "acnamesp.h" -#include "actables.h" #define _COMPONENT ACPI_EXECUTER @@ -182,7 +177,7 @@ * are all essentially the same. This case handles the * "interchangeable" types Integer, String, and Buffer. */ - if (SourceDesc->Common.Type == INTERNAL_TYPE_REFERENCE) + if (ACPI_GET_OBJECT_TYPE (SourceDesc) == INTERNAL_TYPE_REFERENCE) { /* Resolve a reference object first */ @@ -196,16 +191,16 @@ /* * Must have a Integer, Buffer, or String */ - if ((SourceDesc->Common.Type != ACPI_TYPE_INTEGER) && - (SourceDesc->Common.Type != ACPI_TYPE_BUFFER) && - (SourceDesc->Common.Type != ACPI_TYPE_STRING)) + if ((ACPI_GET_OBJECT_TYPE (SourceDesc) != ACPI_TYPE_INTEGER) && + (ACPI_GET_OBJECT_TYPE (SourceDesc) != ACPI_TYPE_BUFFER) && + (ACPI_GET_OBJECT_TYPE (SourceDesc) != ACPI_TYPE_STRING)) { /* * Conversion successful but still not a valid type */ ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Cannot assign type %s to %s (must be type Int/Str/Buf)\n", - AcpiUtGetTypeName (SourceDesc->Common.Type), + AcpiUtGetObjectTypeName (SourceDesc), AcpiUtGetTypeName (TargetType))); Status = AE_AML_OPERAND_TYPE; } @@ -297,7 +292,7 @@ return_ACPI_STATUS (Status); } - if (SourceDesc->Common.Type != DestDesc->Common.Type) + if (ACPI_GET_OBJECT_TYPE (SourceDesc) != ACPI_GET_OBJECT_TYPE (DestDesc)) { /* * The source type does not match the type of the destination. @@ -308,7 +303,7 @@ * Otherwise, ActualSrcDesc is a temporary object to hold the * converted object. */ - Status = AcpiExConvertToTargetType (DestDesc->Common.Type, SourceDesc, + Status = AcpiExConvertToTargetType (ACPI_GET_OBJECT_TYPE (DestDesc), SourceDesc, &ActualSrcDesc, WalkState); if (ACPI_FAILURE (Status)) { @@ -320,7 +315,7 @@ * We now have two objects of identical types, and we can perform a * copy of the *value* of the source object. */ - switch (DestDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (DestDesc)) { case ACPI_TYPE_INTEGER: @@ -328,7 +323,7 @@ /* Truncate value if we are executing from a 32-bit ACPI table */ - AcpiExTruncateFor32bitTable (DestDesc, WalkState); + AcpiExTruncateFor32bitTable (DestDesc); break; case ACPI_TYPE_STRING: @@ -351,7 +346,7 @@ * All other types come here. */ ACPI_DEBUG_PRINT ((ACPI_DB_WARN, "Store into type %s not implemented\n", - AcpiUtGetTypeName (DestDesc->Common.Type))); + AcpiUtGetObjectTypeName (DestDesc))); Status = AE_NOT_IMPLEMENTED; break; Index: exstorob.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exstorob.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 exstorob.c --- exstorob.c 30 Jun 2002 17:50:44 -0000 1.1.1.12 +++ exstorob.c 1 Jul 2002 21:39:53 -0000 @@ -118,12 +118,7 @@ #define __EXSTOROB_C__ #include "acpi.h" -#include "acparser.h" -#include "acdispat.h" #include "acinterp.h" -#include "amlcode.h" -#include "acnamesp.h" -#include "actables.h" #define _COMPONENT ACPI_EXECUTER @@ -265,7 +260,7 @@ ACPI_MEM_FREE (TargetDesc->String.Pointer); } - TargetDesc->String.Pointer = ACPI_MEM_ALLOCATE (Length + 1); + TargetDesc->String.Pointer = ACPI_MEM_ALLOCATE ((ACPI_SIZE) Length + 1); if (!TargetDesc->String.Pointer) { return (AE_NO_MEMORY); Index: exsystem.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exsystem.c,v retrieving revision 1.3 diff -u -r1.3 exsystem.c --- exsystem.c 23 Feb 2002 05:16:34 -0000 1.3 +++ exsystem.c 1 Jul 2002 21:39:53 -0000 @@ -119,8 +119,6 @@ #include "acpi.h" #include "acinterp.h" -#include "acnamesp.h" -#include "achware.h" #include "acevents.h" #define _COMPONENT ACPI_EXECUTER @@ -347,8 +345,8 @@ */ if (ObjDesc->Mutex.Semaphore == AcpiGbl_GlobalLockSemaphore) { - AcpiEvReleaseGlobalLock (); - return_ACPI_STATUS (AE_OK); + Status = AcpiEvReleaseGlobalLock (); + return_ACPI_STATUS (Status); } Status = AcpiOsSignalSemaphore (ObjDesc->Mutex.Semaphore, 1); @@ -454,7 +452,7 @@ Status = AcpiOsCreateSemaphore (ACPI_NO_UNIT_LIMIT, 0, &TempSemaphore); if (ACPI_SUCCESS (Status)) { - AcpiOsDeleteSemaphore (ObjDesc->Event.Semaphore); + (void) AcpiOsDeleteSemaphore (ObjDesc->Event.Semaphore); ObjDesc->Event.Semaphore = TempSemaphore; } Index: exutils.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/exutils.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 exutils.c --- exutils.c 23 Feb 2002 05:10:37 -0000 1.1.1.13 +++ exutils.c 1 Jul 2002 21:39:53 -0000 @@ -134,12 +134,9 @@ #define DEFINE_AML_GLOBALS #include "acpi.h" -#include "acparser.h" #include "acinterp.h" #include "amlcode.h" -#include "acnamesp.h" #include "acevents.h" -#include "acparser.h" #define _COMPONENT ACPI_EXECUTER ACPI_MODULE_NAME ("exutils") @@ -167,7 +164,7 @@ Status = AcpiUtAcquireMutex (ACPI_MTX_EXECUTE); if (ACPI_FAILURE (Status)) { - ACPI_REPORT_ERROR (("Fatal - Could not acquire interpreter lock\n")); + ACPI_REPORT_ERROR (("Could not acquire interpreter mutex\n")); } return_ACPI_STATUS (Status); @@ -204,6 +201,10 @@ Status = AcpiUtReleaseMutex (ACPI_MTX_EXECUTE); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("Could not release interpreter mutex\n")); + } return_VOID; } @@ -242,8 +243,6 @@ * FUNCTION: AcpiExTruncateFor32bitTable * * PARAMETERS: ObjDesc - Object to be truncated - * WalkState - Current walk state - * (A method must be executing) * * RETURN: none * @@ -254,8 +253,7 @@ void AcpiExTruncateFor32bitTable ( - ACPI_OPERAND_OBJECT *ObjDesc, - ACPI_WALK_STATE *WalkState) + ACPI_OPERAND_OBJECT *ObjDesc) { ACPI_FUNCTION_ENTRY (); @@ -266,13 +264,12 @@ * a control method */ if ((!ObjDesc) || - (ObjDesc->Common.Type != ACPI_TYPE_INTEGER) || - (!WalkState->MethodNode)) + (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_INTEGER)) { return; } - if (WalkState->MethodNode->Flags & ANOBJ_DATA_WIDTH_32) + if (AcpiGbl_IntegerByteWidth == 4) { /* * We are running a method that exists in a 32-bit ACPI table. @@ -344,10 +341,12 @@ * ******************************************************************************/ -ACPI_STATUS +void AcpiExReleaseGlobalLock ( BOOLEAN LockedByMe) { + ACPI_STATUS Status; + ACPI_FUNCTION_TRACE ("ExReleaseGlobalLock"); @@ -358,10 +357,14 @@ { /* OK, now release the lock */ - AcpiEvReleaseGlobalLock (); - } + Status = AcpiEvReleaseGlobalLock (); + if (ACPI_FAILURE (Status)) + { + /* Report the error, but there isn't much else we can do */ - return_ACPI_STATUS (AE_OK); + ACPI_REPORT_ERROR (("Could not release ACPI Global Lock\n")); + } + } } @@ -381,25 +384,25 @@ ACPI_INTEGER Value, UINT32 Base) { - UINT32 NumDigits = 0; + UINT32 NumDigits; + ACPI_INTEGER CurrentValue; + ACPI_INTEGER Quotient; ACPI_FUNCTION_TRACE ("ExDigitsNeeded"); - if (Base < 1) - { - ACPI_REPORT_ERROR (("ExDigitsNeeded: Internal error - Invalid base\n")); - } - else + /* + * ACPI_INTEGER is unsigned, so we don't worry about a '-' + */ + CurrentValue = Value; + NumDigits = 0; + + while (CurrentValue) { - /* - * ACPI_INTEGER is unsigned, which is why we don't worry about a '-' - */ - for (NumDigits = 1; - (AcpiUtShortDivide (&Value, Base, &Value, NULL)); - ++NumDigits) - { ; } + (void) AcpiUtShortDivide (&CurrentValue, Base, &Quotient, NULL); + NumDigits++; + CurrentValue = Quotient; } return_VALUE (NumDigits); @@ -408,47 +411,6 @@ /******************************************************************************* * - * FUNCTION: ntohl - * - * PARAMETERS: Value - Value to be converted - * - * DESCRIPTION: Convert a 32-bit value to big-endian (swap the bytes) - * - ******************************************************************************/ - -static UINT32 -_ntohl ( - UINT32 Value) -{ - union - { - UINT32 Value; - UINT8 Bytes[4]; - } Out; - - union - { - UINT32 Value; - UINT8 Bytes[4]; - } In; - - - ACPI_FUNCTION_ENTRY (); - - - In.Value = Value; - - Out.Bytes[0] = In.Bytes[3]; - Out.Bytes[1] = In.Bytes[2]; - Out.Bytes[2] = In.Bytes[1]; - Out.Bytes[3] = In.Bytes[0]; - - return (Out.Value); -} - - -/******************************************************************************* - * * FUNCTION: AcpiExEisaIdToString * * PARAMETERS: NumericId - EISA ID to be converted @@ -458,31 +420,29 @@ * ******************************************************************************/ -ACPI_STATUS +void AcpiExEisaIdToString ( UINT32 NumericId, NATIVE_CHAR *OutString) { - UINT32 id; + UINT32 EisaId; ACPI_FUNCTION_ENTRY (); - /* swap to big-endian to get contiguous bits */ + /* Swap ID to big-endian to get contiguous bits */ - id = _ntohl (NumericId); + EisaId = AcpiUtDwordByteSwap (NumericId); - OutString[0] = (char) ('@' + ((id >> 26) & 0x1f)); - OutString[1] = (char) ('@' + ((id >> 21) & 0x1f)); - OutString[2] = (char) ('@' + ((id >> 16) & 0x1f)); - OutString[3] = AcpiUtHexToAsciiChar (id, 12); - OutString[4] = AcpiUtHexToAsciiChar (id, 8); - OutString[5] = AcpiUtHexToAsciiChar (id, 4); - OutString[6] = AcpiUtHexToAsciiChar (id, 0); + OutString[0] = (char) ('@' + ((EisaId >> 26) & 0x1f)); + OutString[1] = (char) ('@' + ((EisaId >> 21) & 0x1f)); + OutString[2] = (char) ('@' + ((EisaId >> 16) & 0x1f)); + OutString[3] = AcpiUtHexToAsciiChar ((ACPI_INTEGER) EisaId, 12); + OutString[4] = AcpiUtHexToAsciiChar ((ACPI_INTEGER) EisaId, 8); + OutString[5] = AcpiUtHexToAsciiChar ((ACPI_INTEGER) EisaId, 4); + OutString[6] = AcpiUtHexToAsciiChar ((ACPI_INTEGER) EisaId, 0); OutString[7] = 0; - - return (AE_OK); } @@ -497,7 +457,7 @@ * ******************************************************************************/ -ACPI_STATUS +void AcpiExUnsignedIntegerToString ( ACPI_INTEGER Value, NATIVE_CHAR *OutString) @@ -505,6 +465,7 @@ UINT32 Count; UINT32 DigitsNeeded; UINT32 Remainder; + ACPI_INTEGER Quotient; ACPI_FUNCTION_ENTRY (); @@ -515,11 +476,10 @@ for (Count = DigitsNeeded; Count > 0; Count--) { - AcpiUtShortDivide (&Value, 10, &Value, &Remainder); - OutString[Count-1] = (NATIVE_CHAR) ('0' + Remainder); + (void) AcpiUtShortDivide (&Value, 10, &Quotient, &Remainder); + OutString[Count-1] = (NATIVE_CHAR) ('0' + Remainder);\ + Value = Quotient; } - - return (AE_OK); } Index: hwacpi.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/hwacpi.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 hwacpi.c --- hwacpi.c 23 Feb 2002 05:10:34 -0000 1.1.1.12 +++ hwacpi.c 1 Jul 2002 21:39:53 -0000 @@ -118,7 +118,6 @@ #define __HWACPI_C__ #include "acpi.h" -#include "achware.h" #define _COMPONENT ACPI_HARDWARE @@ -185,38 +184,60 @@ UINT32 Mode) { - ACPI_STATUS Status = AE_NO_HARDWARE_RESPONSE; + ACPI_STATUS Status; + UINT32 Retry; ACPI_FUNCTION_TRACE ("HwSetMode"); - - if (Mode == ACPI_SYS_MODE_ACPI) + switch (Mode) { + case ACPI_SYS_MODE_ACPI: + /* BIOS should have disabled ALL fixed and GP events */ - AcpiOsWritePort (AcpiGbl_FADT->SmiCmd, AcpiGbl_FADT->AcpiEnable, 8); + Status = AcpiOsWritePort (AcpiGbl_FADT->SmiCmd, + (ACPI_INTEGER) AcpiGbl_FADT->AcpiEnable, 8); ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "Attempting to enable ACPI mode\n")); - } - else if (Mode == ACPI_SYS_MODE_LEGACY) - { + break; + + case ACPI_SYS_MODE_LEGACY: + /* * BIOS should clear all fixed status bits and restore fixed event * enable bits to default */ - AcpiOsWritePort (AcpiGbl_FADT->SmiCmd, AcpiGbl_FADT->AcpiDisable, 8); + Status = AcpiOsWritePort (AcpiGbl_FADT->SmiCmd, + (ACPI_INTEGER) AcpiGbl_FADT->AcpiDisable, 8); ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "Attempting to enable Legacy (non-ACPI) mode\n")); - } + break; - /* Give the platform some time to react */ + default: + return_ACPI_STATUS (AE_BAD_PARAMETER); + } - AcpiOsStall (20000); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } - if (AcpiHwGetMode () == Mode) + /* + * Some hardware takes a LONG time to switch modes. Give them 3 sec to + * do so, but allow faster systems to proceed more quickly. + */ + Retry = 3000; + while (Retry) { - ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "Mode %X successfully enabled\n", Mode)); - Status = AE_OK; + Status = AE_NO_HARDWARE_RESPONSE; + + if (AcpiHwGetMode() == Mode) { + ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "Mode %X successfully enabled\n", Mode)); + Status = AE_OK; + break; + } + AcpiOsStall(1000); + Retry--; } return_ACPI_STATUS (Status); @@ -239,11 +260,19 @@ UINT32 AcpiHwGetMode (void) { + ACPI_STATUS Status; + UINT32 Value; + ACPI_FUNCTION_TRACE ("HwGetMode"); + Status = AcpiGetRegister (ACPI_BITREG_SCI_ENABLE, &Value, ACPI_MTX_LOCK); + if (ACPI_FAILURE (Status)) + { + return_VALUE (ACPI_SYS_MODE_LEGACY); + } - if (AcpiHwBitRegisterRead (ACPI_BITREG_SCI_ENABLE, ACPI_MTX_LOCK)) + if (Value) { return_VALUE (ACPI_SYS_MODE_ACPI); } Index: hwgpe.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/hwgpe.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 hwgpe.c --- hwgpe.c 30 Jun 2002 17:50:41 -0000 1.1.1.11 +++ hwgpe.c 1 Jul 2002 21:39:53 -0000 @@ -116,8 +116,6 @@ *****************************************************************************/ #include "acpi.h" -#include "achware.h" -#include "acnamesp.h" #include "acevents.h" #define _COMPONENT ACPI_HARDWARE @@ -136,7 +134,7 @@ * ******************************************************************************/ -UINT32 +UINT8 AcpiHwGetGpeBitMask ( UINT32 GpeNumber) { @@ -156,13 +154,14 @@ * ******************************************************************************/ -void +ACPI_STATUS AcpiHwEnableGpe ( UINT32 GpeNumber) { UINT32 InByte; UINT32 RegisterIndex; - UINT32 BitMask; + UINT8 BitMask; + ACPI_STATUS Status; ACPI_FUNCTION_ENTRY (); @@ -180,10 +179,17 @@ * Read the current value of the register, set the appropriate bit * to enable the GPE, and write out the new register. */ - InByte = AcpiHwLowLevelRead (8, - &AcpiGbl_GpeRegisterInfo[RegisterIndex].EnableAddress, 0); - AcpiHwLowLevelWrite (8, (InByte | BitMask), - &AcpiGbl_GpeRegisterInfo[RegisterIndex].EnableAddress, 0); + Status = AcpiHwLowLevelRead (8, &InByte, + &AcpiGbl_GpeRegisterInfo[RegisterIndex].EnableAddress, 0); + if (ACPI_FAILURE (Status)) + { + return (Status); + } + + Status = AcpiHwLowLevelWrite (8, (InByte | BitMask), + &AcpiGbl_GpeRegisterInfo[RegisterIndex].EnableAddress, 0); + + return (Status); } @@ -205,7 +211,7 @@ UINT32 GpeNumber) { UINT32 RegisterIndex; - UINT32 BitMask; + UINT8 BitMask; ACPI_FUNCTION_ENTRY (); @@ -238,13 +244,14 @@ * ******************************************************************************/ -void +ACPI_STATUS AcpiHwDisableGpe ( UINT32 GpeNumber) { UINT32 InByte; UINT32 RegisterIndex; - UINT32 BitMask; + UINT8 BitMask; + ACPI_STATUS Status; ACPI_FUNCTION_ENTRY (); @@ -262,12 +269,22 @@ * Read the current value of the register, clear the appropriate bit, * and write out the new register value to disable the GPE. */ - InByte = AcpiHwLowLevelRead (8, - &AcpiGbl_GpeRegisterInfo[RegisterIndex].EnableAddress, 0); - AcpiHwLowLevelWrite (8, (InByte & ~BitMask), - &AcpiGbl_GpeRegisterInfo[RegisterIndex].EnableAddress, 0); + Status = AcpiHwLowLevelRead (8, &InByte, + &AcpiGbl_GpeRegisterInfo[RegisterIndex].EnableAddress, 0); + if (ACPI_FAILURE (Status)) + { + return (Status); + } + + Status = AcpiHwLowLevelWrite (8, (InByte & ~BitMask), + &AcpiGbl_GpeRegisterInfo[RegisterIndex].EnableAddress, 0); + if (ACPI_FAILURE (Status)) + { + return (Status); + } AcpiHwDisableGpeForWakeup(GpeNumber); + return (AE_OK); } @@ -289,7 +306,7 @@ UINT32 GpeNumber) { UINT32 RegisterIndex; - UINT32 BitMask; + UINT8 BitMask; ACPI_FUNCTION_ENTRY (); @@ -322,12 +339,13 @@ * ******************************************************************************/ -void +ACPI_STATUS AcpiHwClearGpe ( UINT32 GpeNumber) { UINT32 RegisterIndex; - UINT32 BitMask; + UINT8 BitMask; + ACPI_STATUS Status; ACPI_FUNCTION_ENTRY (); @@ -345,8 +363,10 @@ * Write a one to the appropriate bit in the status register to * clear this GPE. */ - AcpiHwLowLevelWrite (8, BitMask, - &AcpiGbl_GpeRegisterInfo[RegisterIndex].StatusAddress, 0); + Status = AcpiHwLowLevelWrite (8, BitMask, + &AcpiGbl_GpeRegisterInfo[RegisterIndex].StatusAddress, 0); + + return (Status); } @@ -362,15 +382,16 @@ * ******************************************************************************/ -void +ACPI_STATUS AcpiHwGetGpeStatus ( UINT32 GpeNumber, ACPI_EVENT_STATUS *EventStatus) { UINT32 InByte = 0; UINT32 RegisterIndex = 0; - UINT32 BitMask = 0; + UINT8 BitMask = 0; ACPI_GPE_REGISTER_INFO *GpeRegisterInfo; + ACPI_STATUS Status; ACPI_FUNCTION_ENTRY (); @@ -378,7 +399,7 @@ if (!EventStatus) { - return; + return (AE_BAD_PARAMETER); } (*EventStatus) = 0; @@ -394,7 +415,12 @@ /* GPE Enabled? */ - InByte = AcpiHwLowLevelRead (8, &GpeRegisterInfo->EnableAddress, 0); + Status = AcpiHwLowLevelRead (8, &InByte, &GpeRegisterInfo->EnableAddress, 0); + if (ACPI_FAILURE (Status)) + { + return (Status); + } + if (BitMask & InByte) { (*EventStatus) |= ACPI_EVENT_FLAG_ENABLED; @@ -409,11 +435,17 @@ /* GPE active (set)? */ - InByte = AcpiHwLowLevelRead (8, &GpeRegisterInfo->StatusAddress, 0); + Status = AcpiHwLowLevelRead (8, &InByte, &GpeRegisterInfo->StatusAddress, 0); + if (ACPI_FAILURE (Status)) + { + return (Status); + } + if (BitMask & InByte) { (*EventStatus) |= ACPI_EVENT_FLAG_SET; } + return (AE_OK); } @@ -433,12 +465,14 @@ * ******************************************************************************/ -void +ACPI_STATUS AcpiHwDisableNonWakeupGpes ( void) { UINT32 i; ACPI_GPE_REGISTER_INFO *GpeRegisterInfo; + UINT32 InValue; + ACPI_STATUS Status; ACPI_FUNCTION_ENTRY (); @@ -452,15 +486,26 @@ * Read the enabled status of all GPEs. We * will be using it to restore all the GPEs later. */ - GpeRegisterInfo->Enable = (UINT8) AcpiHwLowLevelRead (8, + Status = AcpiHwLowLevelRead (8, &InValue, &GpeRegisterInfo->EnableAddress, 0); + if (ACPI_FAILURE (Status)) + { + return (Status); + } + + GpeRegisterInfo->Enable = (UINT8) InValue; /* * Disable all GPEs except wakeup GPEs. */ - AcpiHwLowLevelWrite (8, GpeRegisterInfo->WakeEnable, + Status = AcpiHwLowLevelWrite (8, GpeRegisterInfo->WakeEnable, &GpeRegisterInfo->EnableAddress, 0); + if (ACPI_FAILURE (Status)) + { + return (Status); + } } + return (AE_OK); } @@ -476,12 +521,13 @@ * ******************************************************************************/ -void +ACPI_STATUS AcpiHwEnableNonWakeupGpes ( void) { UINT32 i; ACPI_GPE_REGISTER_INFO *GpeRegisterInfo; + ACPI_STATUS Status; ACPI_FUNCTION_ENTRY (); @@ -495,7 +541,12 @@ * We previously stored the enabled status of all GPEs. * Blast them back in. */ - AcpiHwLowLevelWrite (8, GpeRegisterInfo->Enable, & - GpeRegisterInfo->EnableAddress, 0); + Status = AcpiHwLowLevelWrite (8, GpeRegisterInfo->Enable, + &GpeRegisterInfo->EnableAddress, 0); + if (ACPI_FAILURE (Status)) + { + return (Status); + } } + return (AE_OK); } Index: hwregs.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/hwregs.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 hwregs.c --- hwregs.c 30 Jun 2002 17:50:41 -0000 1.1.1.12 +++ hwregs.c 1 Jul 2002 21:39:53 -0000 @@ -119,7 +119,6 @@ #define __HWREGS_C__ #include "acpi.h" -#include "achware.h" #include "acnamesp.h" #define _COMPONENT ACPI_HARDWARE @@ -138,10 +137,10 @@ * ******************************************************************************/ -void +ACPI_STATUS AcpiHwClearAcpiStatus (void) { - NATIVE_UINT i; + NATIVE_UINT_MAX32 i; NATIVE_UINT GpeBlock; ACPI_STATUS Status; @@ -157,18 +156,26 @@ Status = AcpiUtAcquireMutex (ACPI_MTX_HARDWARE); if (ACPI_FAILURE (Status)) { - return_VOID; + return_ACPI_STATUS (Status); } - AcpiHwRegisterWrite (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM1_STATUS, - ACPI_BITMASK_ALL_FIXED_STATUS); + Status = AcpiHwRegisterWrite (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM1_STATUS, + ACPI_BITMASK_ALL_FIXED_STATUS); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } /* Clear the fixed events */ if (ACPI_VALID_ADDRESS (AcpiGbl_FADT->XPm1bEvtBlk.Address)) { - AcpiHwLowLevelWrite (16, ACPI_BITMASK_ALL_FIXED_STATUS, - &AcpiGbl_FADT->XPm1bEvtBlk, 0); + Status = AcpiHwLowLevelWrite (16, ACPI_BITMASK_ALL_FIXED_STATUS, + &AcpiGbl_FADT->XPm1bEvtBlk, 0); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } } /* Clear the GPE Bits */ @@ -177,19 +184,24 @@ { for (i = 0; i < AcpiGbl_GpeBlockInfo[GpeBlock].RegisterCount; i++) { - AcpiHwLowLevelWrite (8, 0xFF, - AcpiGbl_GpeBlockInfo[GpeBlock].BlockAddress, i); + Status = AcpiHwLowLevelWrite (8, 0xFF, + AcpiGbl_GpeBlockInfo[GpeBlock].BlockAddress, i); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } } } +UnlockAndExit: (void) AcpiUtReleaseMutex (ACPI_MTX_HARDWARE); - return_VOID; + return_ACPI_STATUS (Status); } /******************************************************************************* * - * FUNCTION: AcpiHwGetSleepTypeData + * FUNCTION: AcpiGetSleepTypeData * * PARAMETERS: SleepState - Numeric sleep state * *SleepTypeA - Where SLP_TYPa is returned @@ -203,7 +215,7 @@ ******************************************************************************/ ACPI_STATUS -AcpiHwGetSleepTypeData ( +AcpiGetSleepTypeData ( UINT8 SleepState, UINT8 *SleepTypeA, UINT8 *SleepTypeB) @@ -212,11 +224,11 @@ ACPI_OPERAND_OBJECT *ObjDesc; - ACPI_FUNCTION_TRACE ("HwGetSleepTypeData"); + ACPI_FUNCTION_TRACE ("AcpiGetSleepTypeData"); /* - * Validate parameters + * Validate parameters */ if ((SleepState > ACPI_S_STATES_MAX) || !SleepTypeA || !SleepTypeB) @@ -225,7 +237,7 @@ } /* - * AcpiEvaluate the namespace object containing the values for this state + * Evaluate the namespace object containing the values for this state */ Status = AcpiNsEvaluateByName ((NATIVE_CHAR *) AcpiGbl_DbSleepStates[SleepState], NULL, &ObjDesc); @@ -234,42 +246,44 @@ return_ACPI_STATUS (Status); } + /* Must have a return object */ + if (!ObjDesc) { ACPI_REPORT_ERROR (("Missing Sleep State object\n")); - return_ACPI_STATUS (AE_NOT_EXIST); + Status = AE_NOT_EXIST; } - /* - * We got something, now ensure it is correct. The object must - * be a package and must have at least 2 numeric values as the - * two elements - */ + /* It must be of type Package */ - /* Even though AcpiEvaluateObject resolves package references, - * NsEvaluate doesn't. So, we do it here. - */ - Status = AcpiUtResolvePackageReferences(ObjDesc); - - if (ObjDesc->Package.Count < 2) + else if (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_PACKAGE) { - /* Must have at least two elements */ + ACPI_REPORT_ERROR (("Sleep State object not a Package\n")); + Status = AE_AML_OPERAND_TYPE; + } + + /* The package must have at least two elements */ + else if (ObjDesc->Package.Count < 2) + { ACPI_REPORT_ERROR (("Sleep State package does not have at least two elements\n")); Status = AE_AML_NO_OPERAND; } - else if (((ObjDesc->Package.Elements[0])->Common.Type != ACPI_TYPE_INTEGER) || - ((ObjDesc->Package.Elements[1])->Common.Type != ACPI_TYPE_INTEGER)) - { - /* Must have two */ - ACPI_REPORT_ERROR (("Sleep State package elements are not both of type Number\n")); + /* The first two elements must both be of type Integer */ + + else if ((ACPI_GET_OBJECT_TYPE (ObjDesc->Package.Elements[0]) != ACPI_TYPE_INTEGER) || + (ACPI_GET_OBJECT_TYPE (ObjDesc->Package.Elements[1]) != ACPI_TYPE_INTEGER)) + { + ACPI_REPORT_ERROR (("Sleep State package elements are not both Integers (%s, %s)\n", + AcpiUtGetObjectTypeName (ObjDesc->Package.Elements[0]), + AcpiUtGetObjectTypeName (ObjDesc->Package.Elements[1]))); Status = AE_AML_OPERAND_TYPE; } else { /* - * Valid _Sx_ package size, type, and value + * Valid _Sx_ package size, type, and value */ *SleepTypeA = (UINT8) (ObjDesc->Package.Elements[0])->Integer.Value; *SleepTypeB = (UINT8) (ObjDesc->Package.Elements[1])->Integer.Value; @@ -277,8 +291,8 @@ if (ACPI_FAILURE (Status)) { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Bad Sleep object %p type %X\n", - ObjDesc, ObjDesc->Common.Type)); + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Bad Sleep object %p type %s\n", + ObjDesc, AcpiUtGetObjectTypeName (ObjDesc))); } AcpiUtRemoveReference (ObjDesc); @@ -290,8 +304,8 @@ * * FUNCTION: AcpiHwGetRegisterBitMask * - * PARAMETERS: RegisterId - index of ACPI Register to access - * + * PARAMETERS: RegisterId - Index of ACPI Register to access + * * RETURN: The bit mask to be used when accessing the register * * DESCRIPTION: Map RegisterId into a register bit mask. @@ -317,10 +331,10 @@ /******************************************************************************* * - * FUNCTION: AcpiHwBitRegisterRead + * FUNCTION: AcpiGetRegister * - * PARAMETERS: RegisterId - index of ACPI Register to access - * UseLock - Lock the hardware + * PARAMETERS: RegisterId - Index of ACPI Register to access + * UseLock - Lock the hardware * * RETURN: Value is read from specified Register. Value returned is * normalized to bit0 (is shifted all the way right) @@ -329,26 +343,20 @@ * ******************************************************************************/ -UINT32 -AcpiHwBitRegisterRead ( +ACPI_STATUS +AcpiGetRegister ( UINT32 RegisterId, + UINT32 *ReturnValue, UINT32 Flags) { UINT32 RegisterValue = 0; ACPI_BIT_REGISTER_INFO *BitRegInfo; + ACPI_STATUS Status; - ACPI_FUNCTION_TRACE ("HwBitRegisterRead"); + ACPI_FUNCTION_TRACE ("AcpiGetRegister"); - if (Flags & ACPI_MTX_LOCK) - { - if (ACPI_FAILURE (AcpiUtAcquireMutex (ACPI_MTX_HARDWARE))) - { - return_VALUE (0); - } - } - /* Get the info structure corresponding to the requested ACPI Register */ BitRegInfo = AcpiHwGetBitRegisterInfo (RegisterId); @@ -357,70 +365,94 @@ return_ACPI_STATUS (AE_BAD_PARAMETER); } - RegisterValue = AcpiHwRegisterRead (ACPI_MTX_DO_NOT_LOCK, BitRegInfo->ParentRegister); + if (Flags & ACPI_MTX_LOCK) + { + Status = AcpiUtAcquireMutex (ACPI_MTX_HARDWARE); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + } + + Status = AcpiHwRegisterRead (ACPI_MTX_DO_NOT_LOCK, + BitRegInfo->ParentRegister, &RegisterValue); if (Flags & ACPI_MTX_LOCK) { (void) AcpiUtReleaseMutex (ACPI_MTX_HARDWARE); } - /* Normalize the value that was read */ + if (ACPI_SUCCESS (Status)) + { + /* Normalize the value that was read */ - RegisterValue = ((RegisterValue & BitRegInfo->AccessBitMask) >> BitRegInfo->BitPosition); + RegisterValue = ((RegisterValue & BitRegInfo->AccessBitMask) + >> BitRegInfo->BitPosition); + + *ReturnValue = RegisterValue; + + ACPI_DEBUG_PRINT ((ACPI_DB_IO, "Read value %X\n", RegisterValue)); + } - ACPI_DEBUG_PRINT ((ACPI_DB_IO, "ACPI RegisterRead: got %X\n", RegisterValue)); - return_VALUE (RegisterValue); + return_ACPI_STATUS (Status); } /******************************************************************************* * - * FUNCTION: AcpiHwBitRegisterWrite + * FUNCTION: AcpiSetRegister * * PARAMETERS: RegisterId - ID of ACPI BitRegister to access * Value - (only used on write) value to write to the * Register, NOT pre-normalized to the bit pos. * Flags - Lock the hardware or not * - * RETURN: Value written to from specified Register. This value - * is shifted all the way right. + * RETURN: None * * DESCRIPTION: ACPI Bit Register write function. * ******************************************************************************/ -UINT32 -AcpiHwBitRegisterWrite ( +ACPI_STATUS +AcpiSetRegister ( UINT32 RegisterId, UINT32 Value, UINT32 Flags) { UINT32 RegisterValue = 0; ACPI_BIT_REGISTER_INFO *BitRegInfo; + ACPI_STATUS Status; - ACPI_FUNCTION_TRACE_U32 ("HwBitRegisterWrite", RegisterId); + ACPI_FUNCTION_TRACE_U32 ("AcpiSetRegister", RegisterId); - if (Flags & ACPI_MTX_LOCK) - { - if (ACPI_FAILURE (AcpiUtAcquireMutex (ACPI_MTX_HARDWARE))) - { - return_VALUE (0); - } - } - /* Get the info structure corresponding to the requested ACPI Register */ BitRegInfo = AcpiHwGetBitRegisterInfo (RegisterId); if (!BitRegInfo) { + ACPI_REPORT_ERROR (("Bad ACPI HW RegisterId: %X\n", RegisterId)); return_ACPI_STATUS (AE_BAD_PARAMETER); } + if (Flags & ACPI_MTX_LOCK) + { + Status = AcpiUtAcquireMutex (ACPI_MTX_HARDWARE); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + } + /* Always do a register read first so we can insert the new bits */ - RegisterValue = AcpiHwRegisterRead (ACPI_MTX_DO_NOT_LOCK, BitRegInfo->ParentRegister); + Status = AcpiHwRegisterRead (ACPI_MTX_DO_NOT_LOCK, + BitRegInfo->ParentRegister, &RegisterValue); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } /* * Decode the Register ID @@ -439,11 +471,12 @@ * information is the single bit we're interested in, all others should * be written as 0 so they will be left unchanged */ - Value = ACPI_REGISTER_PREPARE_BITS (Value, BitRegInfo->BitPosition, BitRegInfo->AccessBitMask); + Value = ACPI_REGISTER_PREPARE_BITS (Value, + BitRegInfo->BitPosition, BitRegInfo->AccessBitMask); if (Value) { - AcpiHwRegisterWrite (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM1_STATUS, - (UINT16) Value); + Status = AcpiHwRegisterWrite (ACPI_MTX_DO_NOT_LOCK, + ACPI_REGISTER_PM1_STATUS, (UINT16) Value); RegisterValue = 0; } break; @@ -451,9 +484,11 @@ case ACPI_REGISTER_PM1_ENABLE: - ACPI_REGISTER_INSERT_VALUE (RegisterValue, BitRegInfo->BitPosition, BitRegInfo->AccessBitMask, Value); + ACPI_REGISTER_INSERT_VALUE (RegisterValue, BitRegInfo->BitPosition, + BitRegInfo->AccessBitMask, Value); - AcpiHwRegisterWrite (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM1_ENABLE, (UINT16) RegisterValue); + Status = AcpiHwRegisterWrite (ACPI_MTX_DO_NOT_LOCK, + ACPI_REGISTER_PM1_ENABLE, (UINT16) RegisterValue); break; @@ -466,29 +501,37 @@ */ ACPI_DEBUG_PRINT ((ACPI_DB_IO, "PM1 control: Read %X\n", RegisterValue)); - ACPI_REGISTER_INSERT_VALUE (RegisterValue, BitRegInfo->BitPosition, BitRegInfo->AccessBitMask, Value); + ACPI_REGISTER_INSERT_VALUE (RegisterValue, BitRegInfo->BitPosition, + BitRegInfo->AccessBitMask, Value); - AcpiHwRegisterWrite (ACPI_MTX_DO_NOT_LOCK, RegisterId, + Status = AcpiHwRegisterWrite (ACPI_MTX_DO_NOT_LOCK, RegisterId, (UINT16) RegisterValue); break; case ACPI_REGISTER_PM2_CONTROL: - RegisterValue = AcpiHwRegisterRead (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM2_CONTROL); + Status = AcpiHwRegisterRead (ACPI_MTX_DO_NOT_LOCK, + ACPI_REGISTER_PM2_CONTROL, &RegisterValue); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } ACPI_DEBUG_PRINT ((ACPI_DB_IO, "PM2 control: Read %X from %8.8X%8.8X\n", - RegisterValue, ACPI_HIDWORD (AcpiGbl_FADT->XPm2CntBlk.Address), - ACPI_LODWORD (AcpiGbl_FADT->XPm2CntBlk.Address))); + RegisterValue, + ACPI_HIDWORD (ACPI_GET_ADDRESS (AcpiGbl_FADT->XPm2CntBlk.Address)), + ACPI_LODWORD (ACPI_GET_ADDRESS (AcpiGbl_FADT->XPm2CntBlk.Address)))); - ACPI_REGISTER_INSERT_VALUE (RegisterValue, BitRegInfo->BitPosition, BitRegInfo->AccessBitMask, Value); + ACPI_REGISTER_INSERT_VALUE (RegisterValue, BitRegInfo->BitPosition, + BitRegInfo->AccessBitMask, Value); - ACPI_DEBUG_PRINT ((ACPI_DB_IO, "About to write %04X to %8.8X%8.8X\n", + ACPI_DEBUG_PRINT ((ACPI_DB_IO, "About to write %4.4X to %8.8X%8.8X\n", RegisterValue, - ACPI_HIDWORD (AcpiGbl_FADT->XPm2CntBlk.Address), - ACPI_LODWORD (AcpiGbl_FADT->XPm2CntBlk.Address))); + ACPI_HIDWORD (ACPI_GET_ADDRESS (AcpiGbl_FADT->XPm2CntBlk.Address)), + ACPI_LODWORD (ACPI_GET_ADDRESS (AcpiGbl_FADT->XPm2CntBlk.Address)))); - AcpiHwRegisterWrite (ACPI_MTX_DO_NOT_LOCK, + Status = AcpiHwRegisterWrite (ACPI_MTX_DO_NOT_LOCK, ACPI_REGISTER_PM2_CONTROL, (UINT8) (RegisterValue)); break; @@ -497,6 +540,9 @@ break; } + +UnlockAndExit: + if (Flags & ACPI_MTX_LOCK) { (void) AcpiUtReleaseMutex (ACPI_MTX_HARDWARE); @@ -504,10 +550,10 @@ /* Normalize the value that was read */ - RegisterValue = ((RegisterValue & BitRegInfo->AccessBitMask) >> BitRegInfo->BitPosition); + ACPI_DEBUG_EXEC (RegisterValue = ((RegisterValue & BitRegInfo->AccessBitMask) >> BitRegInfo->BitPosition)); - ACPI_DEBUG_PRINT ((ACPI_DB_IO, "ACPI RegisterWrite actual %X\n", RegisterValue)); - return_VALUE (RegisterValue); + ACPI_DEBUG_PRINT ((ACPI_DB_IO, "ACPI Register Write actual %X\n", RegisterValue)); + return_ACPI_STATUS (Status); } @@ -525,13 +571,16 @@ * ******************************************************************************/ -UINT32 +ACPI_STATUS AcpiHwRegisterRead ( BOOLEAN UseLock, - UINT32 RegisterId) + UINT32 RegisterId, + UINT32 *ReturnValue) { - UINT32 Value = 0; + UINT32 Value1 = 0; + UINT32 Value2 = 0; UINT32 BankOffset; + ACPI_STATUS Status; ACPI_FUNCTION_TRACE ("HwRegisterRead"); @@ -539,9 +588,10 @@ if (ACPI_MTX_LOCK == UseLock) { - if (ACPI_FAILURE (AcpiUtAcquireMutex (ACPI_MTX_HARDWARE))) + Status = AcpiUtAcquireMutex (ACPI_MTX_HARDWARE); + if (ACPI_FAILURE (Status)) { - return_VALUE (0); + return_ACPI_STATUS (Status); } } @@ -549,53 +599,78 @@ { case ACPI_REGISTER_PM1_STATUS: /* 16-bit access */ - Value = AcpiHwLowLevelRead (16, &AcpiGbl_FADT->XPm1aEvtBlk, 0); - Value |= AcpiHwLowLevelRead (16, &AcpiGbl_FADT->XPm1bEvtBlk, 0); + Status = AcpiHwLowLevelRead (16, &Value1, &AcpiGbl_FADT->XPm1aEvtBlk, 0); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } + + Status = AcpiHwLowLevelRead (16, &Value2, &AcpiGbl_FADT->XPm1bEvtBlk, 0); + Value1 |= Value2; break; case ACPI_REGISTER_PM1_ENABLE: /* 16-bit access*/ BankOffset = ACPI_DIV_2 (AcpiGbl_FADT->Pm1EvtLen); - Value = AcpiHwLowLevelRead (16, &AcpiGbl_FADT->XPm1aEvtBlk, BankOffset); - Value |= AcpiHwLowLevelRead (16, &AcpiGbl_FADT->XPm1bEvtBlk, BankOffset); + Status = AcpiHwLowLevelRead (16, &Value1, &AcpiGbl_FADT->XPm1aEvtBlk, BankOffset); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } + + Status = AcpiHwLowLevelRead (16, &Value2, &AcpiGbl_FADT->XPm1bEvtBlk, BankOffset); + Value1 |= Value2; break; case ACPI_REGISTER_PM1_CONTROL: /* 16-bit access */ - Value = AcpiHwLowLevelRead (16, &AcpiGbl_FADT->XPm1aCntBlk, 0); - Value |= AcpiHwLowLevelRead (16, &AcpiGbl_FADT->XPm1bCntBlk, 0); + Status = AcpiHwLowLevelRead (16, &Value1, &AcpiGbl_FADT->XPm1aCntBlk, 0); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } + + Status = AcpiHwLowLevelRead (16, &Value2, &AcpiGbl_FADT->XPm1bCntBlk, 0); + Value1 |= Value2; break; case ACPI_REGISTER_PM2_CONTROL: /* 8-bit access */ - Value = AcpiHwLowLevelRead (8, &AcpiGbl_FADT->XPm2CntBlk, 0); + Status = AcpiHwLowLevelRead (8, &Value1, &AcpiGbl_FADT->XPm2CntBlk, 0); break; case ACPI_REGISTER_PM_TIMER: /* 32-bit access */ - Value = AcpiHwLowLevelRead (32, &AcpiGbl_FADT->XPmTmrBlk, 0); + Status = AcpiHwLowLevelRead (32, &Value1, &AcpiGbl_FADT->XPmTmrBlk, 0); break; case ACPI_REGISTER_SMI_COMMAND_BLOCK: /* 8-bit access */ - AcpiOsReadPort (AcpiGbl_FADT->SmiCmd, &Value, 8); + Status = AcpiOsReadPort (AcpiGbl_FADT->SmiCmd, &Value1, 8); break; default: - /* Value will be returned as 0 */ + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unknown Register ID: %X\n", RegisterId)); + Status = AE_BAD_PARAMETER; break; } +UnlockAndExit: if (ACPI_MTX_LOCK == UseLock) { (void) AcpiUtReleaseMutex (ACPI_MTX_HARDWARE); } - return_VALUE (Value); + if (ACPI_SUCCESS (Status)) + { + *ReturnValue = Value1; + } + + return_ACPI_STATUS (Status); } @@ -613,13 +688,14 @@ * ******************************************************************************/ -void +ACPI_STATUS AcpiHwRegisterWrite ( BOOLEAN UseLock, UINT32 RegisterId, UINT32 Value) { UINT32 BankOffset; + ACPI_STATUS Status; ACPI_FUNCTION_TRACE ("HwRegisterWrite"); @@ -627,9 +703,10 @@ if (ACPI_MTX_LOCK == UseLock) { - if (ACPI_FAILURE (AcpiUtAcquireMutex (ACPI_MTX_HARDWARE))) + Status = AcpiUtAcquireMutex (ACPI_MTX_HARDWARE); + if (ACPI_FAILURE (Status)) { - return_VOID; + return_ACPI_STATUS (Status); } } @@ -637,47 +714,62 @@ { case ACPI_REGISTER_PM1_STATUS: /* 16-bit access */ - AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1aEvtBlk, 0); - AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1bEvtBlk, 0); + Status = AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1aEvtBlk, 0); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } + + Status = AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1bEvtBlk, 0); break; case ACPI_REGISTER_PM1_ENABLE: /* 16-bit access*/ BankOffset = ACPI_DIV_2 (AcpiGbl_FADT->Pm1EvtLen); - AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1aEvtBlk, BankOffset); - AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1bEvtBlk, BankOffset); + Status = AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1aEvtBlk, BankOffset); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } + + Status = AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1bEvtBlk, BankOffset); break; case ACPI_REGISTER_PM1_CONTROL: /* 16-bit access */ - AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1aCntBlk, 0); - AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1bCntBlk, 0); + Status = AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1aCntBlk, 0); + if (ACPI_FAILURE (Status)) + { + goto UnlockAndExit; + } + + Status = AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1bCntBlk, 0); break; case ACPI_REGISTER_PM1A_CONTROL: /* 16-bit access */ - AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1aCntBlk, 0); + Status = AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1aCntBlk, 0); break; case ACPI_REGISTER_PM1B_CONTROL: /* 16-bit access */ - AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1bCntBlk, 0); + Status = AcpiHwLowLevelWrite (16, Value, &AcpiGbl_FADT->XPm1bCntBlk, 0); break; case ACPI_REGISTER_PM2_CONTROL: /* 8-bit access */ - AcpiHwLowLevelWrite (8, Value, &AcpiGbl_FADT->XPm2CntBlk, 0); + Status = AcpiHwLowLevelWrite (8, Value, &AcpiGbl_FADT->XPm2CntBlk, 0); break; case ACPI_REGISTER_PM_TIMER: /* 32-bit access */ - AcpiHwLowLevelWrite (32, Value, &AcpiGbl_FADT->XPmTmrBlk, 0); + Status = AcpiHwLowLevelWrite (32, Value, &AcpiGbl_FADT->XPmTmrBlk, 0); break; @@ -685,21 +777,22 @@ /* SMI_CMD is currently always in IO space */ - AcpiOsWritePort (AcpiGbl_FADT->SmiCmd, Value, 8); + Status = AcpiOsWritePort (AcpiGbl_FADT->SmiCmd, (ACPI_INTEGER) Value, 8); break; default: - Value = 0; + Status = AE_BAD_PARAMETER; break; } +UnlockAndExit: if (ACPI_MTX_LOCK == UseLock) { (void) AcpiUtReleaseMutex (ACPI_MTX_HARDWARE); } - return_VOID; + return_ACPI_STATUS (Status); } @@ -717,31 +810,34 @@ * ******************************************************************************/ -UINT32 +ACPI_STATUS AcpiHwLowLevelRead ( UINT32 Width, + UINT32 *Value, ACPI_GENERIC_ADDRESS *Reg, UINT32 Offset) { - UINT32 Value = 0; ACPI_PHYSICAL_ADDRESS MemAddress; ACPI_IO_ADDRESS IoAddress; ACPI_PCI_ID PciId; UINT16 PciRegister; + ACPI_STATUS Status; - ACPI_FUNCTION_ENTRY (); + ACPI_FUNCTION_NAME ("HwLowLevelRead"); /* * Must have a valid pointer to a GAS structure, and - * a non-zero address within + * a non-zero address within. However, don't return an error + * because the PM1A/B code must not fail if B isn't present. */ if ((!Reg) || (!ACPI_VALID_ADDRESS (Reg->Address))) { - return 0; + return (AE_OK); } + *Value = 0; /* * Three address spaces supported: @@ -751,17 +847,19 @@ { case ACPI_ADR_SPACE_SYSTEM_MEMORY: - MemAddress = (ACPI_PHYSICAL_ADDRESS) (ACPI_GET_ADDRESS (Reg->Address) + Offset); + MemAddress = (ACPI_GET_ADDRESS (Reg->Address) + + (ACPI_PHYSICAL_ADDRESS) Offset); - AcpiOsReadMemory (MemAddress, &Value, Width); + Status = AcpiOsReadMemory (MemAddress, Value, Width); break; case ACPI_ADR_SPACE_SYSTEM_IO: - IoAddress = (ACPI_IO_ADDRESS) (ACPI_GET_ADDRESS (Reg->Address) + Offset); + IoAddress = (ACPI_IO_ADDRESS) (ACPI_GET_ADDRESS (Reg->Address) + + (ACPI_PHYSICAL_ADDRESS) Offset); - AcpiOsReadPort (IoAddress, &Value, Width); + Status = AcpiOsReadPort (IoAddress, Value, Width); break; @@ -771,13 +869,20 @@ PciId.Bus = 0; PciId.Device = ACPI_PCI_DEVICE (ACPI_GET_ADDRESS (Reg->Address)); PciId.Function = ACPI_PCI_FUNCTION (ACPI_GET_ADDRESS (Reg->Address)); - PciRegister = (UINT16) (ACPI_PCI_REGISTER (ACPI_GET_ADDRESS (Reg->Address)) + Offset); + PciRegister = (UINT16) (ACPI_PCI_REGISTER (ACPI_GET_ADDRESS (Reg->Address)) + + Offset); - AcpiOsReadPciConfiguration (&PciId, PciRegister, &Value, Width); + Status = AcpiOsReadPciConfiguration (&PciId, PciRegister, Value, Width); + break; + + + default: + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unsupported address space: %X\n", Reg->AddressSpaceId)); + Status = AE_BAD_PARAMETER; break; } - return Value; + return (Status); } @@ -797,7 +902,7 @@ * ******************************************************************************/ -void +ACPI_STATUS AcpiHwLowLevelWrite ( UINT32 Width, UINT32 Value, @@ -808,21 +913,22 @@ ACPI_IO_ADDRESS IoAddress; ACPI_PCI_ID PciId; UINT16 PciRegister; + ACPI_STATUS Status; - ACPI_FUNCTION_ENTRY (); + ACPI_FUNCTION_NAME ("HwLowLevelWrite"); /* * Must have a valid pointer to a GAS structure, and - * a non-zero address within + * a non-zero address within. However, don't return an error + * because the PM1A/B code must not fail if B isn't present. */ if ((!Reg) || (!ACPI_VALID_ADDRESS (Reg->Address))) { - return; + return (AE_OK); } - /* * Three address spaces supported: * Memory, Io, or PCI config. @@ -831,17 +937,19 @@ { case ACPI_ADR_SPACE_SYSTEM_MEMORY: - MemAddress = (ACPI_PHYSICAL_ADDRESS) (ACPI_GET_ADDRESS (Reg->Address) + Offset); + MemAddress = (ACPI_GET_ADDRESS (Reg->Address) + + (ACPI_PHYSICAL_ADDRESS) Offset); - AcpiOsWriteMemory (MemAddress, Value, Width); + Status = AcpiOsWriteMemory (MemAddress, (ACPI_INTEGER) Value, Width); break; case ACPI_ADR_SPACE_SYSTEM_IO: - IoAddress = (ACPI_IO_ADDRESS) (ACPI_GET_ADDRESS (Reg->Address) + Offset); + IoAddress = (ACPI_IO_ADDRESS) (ACPI_GET_ADDRESS (Reg->Address) + + (ACPI_PHYSICAL_ADDRESS) Offset); - AcpiOsWritePort (IoAddress, Value, Width); + Status = AcpiOsWritePort (IoAddress, (ACPI_INTEGER) Value, Width); break; @@ -851,9 +959,18 @@ PciId.Bus = 0; PciId.Device = ACPI_PCI_DEVICE (ACPI_GET_ADDRESS (Reg->Address)); PciId.Function = ACPI_PCI_FUNCTION (ACPI_GET_ADDRESS (Reg->Address)); - PciRegister = (UINT16) (ACPI_PCI_REGISTER (ACPI_GET_ADDRESS (Reg->Address)) + Offset); + PciRegister = (UINT16) (ACPI_PCI_REGISTER (ACPI_GET_ADDRESS (Reg->Address)) + + Offset); + + Status = AcpiOsWritePciConfiguration (&PciId, PciRegister, (ACPI_INTEGER) Value, Width); + break; - AcpiOsWritePciConfiguration (&PciId, PciRegister, Value, Width); + + default: + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unsupported address space: %X\n", Reg->AddressSpaceId)); + Status = AE_BAD_PARAMETER; break; } + + return (Status); } Index: hwsleep.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/hwsleep.c,v retrieving revision 1.5 diff -u -r1.5 hwsleep.c --- hwsleep.c 30 Jun 2002 17:53:04 -0000 1.5 +++ hwsleep.c 1 Jul 2002 21:39:53 -0000 @@ -116,8 +116,6 @@ *****************************************************************************/ #include "acpi.h" -#include "acnamesp.h" -#include "achware.h" #define _COMPONENT ACPI_HARDWARE ACPI_MODULE_NAME ("hwsleep") @@ -148,11 +146,13 @@ if (AcpiGbl_CommonFACS.VectorWidth == 32) { - *(UINT32 *) AcpiGbl_CommonFACS.FirmwareWakingVector = (UINT32) PhysicalAddress; + *(ACPI_CAST_PTR (UINT32, AcpiGbl_CommonFACS.FirmwareWakingVector)) + = (UINT32) PhysicalAddress; } else { - *AcpiGbl_CommonFACS.FirmwareWakingVector = PhysicalAddress; + *AcpiGbl_CommonFACS.FirmwareWakingVector + = PhysicalAddress; } return_ACPI_STATUS (AE_OK); @@ -190,11 +190,13 @@ if (AcpiGbl_CommonFACS.VectorWidth == 32) { - *PhysicalAddress = *(UINT32 *) AcpiGbl_CommonFACS.FirmwareWakingVector; + *PhysicalAddress = (ACPI_PHYSICAL_ADDRESS) + *(ACPI_CAST_PTR (UINT32, AcpiGbl_CommonFACS.FirmwareWakingVector)); } else { - *PhysicalAddress = *AcpiGbl_CommonFACS.FirmwareWakingVector; + *PhysicalAddress = + *AcpiGbl_CommonFACS.FirmwareWakingVector; } return_ACPI_STATUS (AE_OK); @@ -231,7 +233,7 @@ /* * _PSW methods could be run here to enable wake-on keyboard, LAN, etc. */ - Status = AcpiHwGetSleepTypeData (SleepState, + Status = AcpiGetSleepTypeData (SleepState, &AcpiGbl_SleepTypeA, &AcpiGbl_SleepTypeB); if (ACPI_FAILURE (Status)) { @@ -281,11 +283,13 @@ AcpiEnterSleepState ( UINT8 SleepState) { - UINT16 PM1AControl; - UINT16 PM1BControl; + UINT32 PM1AControl; + UINT32 PM1BControl; ACPI_BIT_REGISTER_INFO *SleepTypeRegInfo; ACPI_BIT_REGISTER_INFO *SleepEnableRegInfo; + UINT32 InValue; UINT32 Retry; + ACPI_STATUS Status; ACPI_FUNCTION_TRACE ("AcpiEnterSleepState"); @@ -294,7 +298,7 @@ if ((AcpiGbl_SleepTypeA > ACPI_SLEEP_TYPE_MAX) || (AcpiGbl_SleepTypeB > ACPI_SLEEP_TYPE_MAX)) { - ACPI_REPORT_ERROR (("Sleep values out of range: A=%x B=%x\n", + ACPI_REPORT_ERROR (("Sleep values out of range: A=%X B=%X\n", AcpiGbl_SleepTypeA, AcpiGbl_SleepTypeB)); return_ACPI_STATUS (AE_AML_OPERAND_VALUE); } @@ -305,16 +309,39 @@ /* Clear wake status */ - AcpiHwBitRegisterWrite (ACPI_BITREG_WAKE_STATUS, 1, ACPI_MTX_LOCK); - AcpiHwClearAcpiStatus(); + Status = AcpiSetRegister (ACPI_BITREG_WAKE_STATUS, 1, ACPI_MTX_LOCK); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } - /* TBD: Disable arbitration here? */ + Status = AcpiHwClearAcpiStatus(); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + + /* Disable BM arbitration */ + + Status = AcpiSetRegister (ACPI_BITREG_ARB_DISABLE, 1, ACPI_MTX_LOCK); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } - AcpiHwDisableNonWakeupGpes(); + Status = AcpiHwDisableNonWakeupGpes(); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } /* Get current value of PM1A control */ - PM1AControl = (UINT16) AcpiHwRegisterRead (ACPI_MTX_LOCK, ACPI_REGISTER_PM1_CONTROL); + Status = AcpiHwRegisterRead (ACPI_MTX_LOCK, ACPI_REGISTER_PM1_CONTROL, &PM1AControl); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } ACPI_DEBUG_PRINT ((ACPI_DB_OK, "Entering S%d\n", SleepState)); /* Clear SLP_EN and SLP_TYP fields */ @@ -329,8 +356,17 @@ /* Write #1: fill in SLP_TYP data */ - AcpiHwRegisterWrite (ACPI_MTX_LOCK, ACPI_REGISTER_PM1A_CONTROL, PM1AControl); - AcpiHwRegisterWrite (ACPI_MTX_LOCK, ACPI_REGISTER_PM1B_CONTROL, PM1BControl); + Status = AcpiHwRegisterWrite (ACPI_MTX_LOCK, ACPI_REGISTER_PM1A_CONTROL, PM1AControl); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + + Status = AcpiHwRegisterWrite (ACPI_MTX_LOCK, ACPI_REGISTER_PM1B_CONTROL, PM1BControl); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } /* Insert SLP_ENABLE bit */ @@ -338,36 +374,63 @@ PM1BControl |= SleepEnableRegInfo->AccessBitMask; /* Write #2: SLP_TYP + SLP_EN */ - ACPI_FLUSH_CPU_CACHE(); - AcpiHwRegisterWrite (ACPI_MTX_LOCK, ACPI_REGISTER_PM1A_CONTROL, PM1AControl); - AcpiHwRegisterWrite (ACPI_MTX_LOCK, ACPI_REGISTER_PM1B_CONTROL, PM1BControl); + ACPI_FLUSH_CPU_CACHE (); + + Status = AcpiHwRegisterWrite (ACPI_MTX_LOCK, ACPI_REGISTER_PM1A_CONTROL, PM1AControl); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + + Status = AcpiHwRegisterWrite (ACPI_MTX_LOCK, ACPI_REGISTER_PM1B_CONTROL, PM1BControl); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } /* * Wait a second, then try again. This is to get S4/5 to work on all machines. */ if (SleepState > ACPI_STATE_S3) { - AcpiOsStall (1000000); - - AcpiHwRegisterWrite (ACPI_MTX_LOCK, ACPI_REGISTER_PM1_CONTROL, - SleepEnableRegInfo->AccessBitMask); + /* + * We wait so long to allow chipsets that poll this reg very slowly to + * still read the right value. Ideally, this entire block would go + * away entirely. + */ + AcpiOsStall (10000000); + + Status = AcpiHwRegisterWrite (ACPI_MTX_LOCK, ACPI_REGISTER_PM1_CONTROL, + SleepEnableRegInfo->AccessBitMask); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } } /* Wait until we enter sleep state */ - /* Spin until we wake */ Retry = 1000; - while (!AcpiHwBitRegisterRead (ACPI_BITREG_WAKE_STATUS, ACPI_MTX_LOCK)) + do { - /* - * Some BIOSes don't set WAK_STS at all, - * give up waiting for wakeup if we time out. - */ - if (Retry-- == 0) { - break; /* giving up */ - } - } + Status = AcpiGetRegister (ACPI_BITREG_WAKE_STATUS, &InValue, ACPI_MTX_LOCK); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + + /* + * Some BIOSes don't set WAK_STS at all, + * give up waiting for wakeup if we time out. + */ + if (Retry-- == 0) { + break; /* giving up */ + } + + /* Spin until we wake */ + + } while (!InValue); return_ACPI_STATUS (AE_OK); } @@ -424,7 +487,14 @@ /* _WAK returns stuff - do we want to look at it? */ - AcpiHwEnableNonWakeupGpes(); + Status = AcpiHwEnableNonWakeupGpes(); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } - return_ACPI_STATUS (AE_OK); + /* Disable BM arbitration */ + Status = AcpiSetRegister (ACPI_BITREG_ARB_DISABLE, 0, ACPI_MTX_LOCK); + + return_ACPI_STATUS (Status); } Index: hwtimer.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/hwtimer.c,v retrieving revision 1.1.1.9 diff -u -r1.1.1.9 hwtimer.c --- hwtimer.c 30 Jun 2002 17:50:42 -0000 1.1.1.9 +++ hwtimer.c 1 Jul 2002 21:39:53 -0000 @@ -116,7 +116,6 @@ *****************************************************************************/ #include "acpi.h" -#include "achware.h" #define _COMPONENT ACPI_HARDWARE ACPI_MODULE_NAME ("hwtimer") @@ -175,6 +174,9 @@ AcpiGetTimer ( UINT32 *Ticks) { + ACPI_STATUS Status; + + ACPI_FUNCTION_TRACE ("AcpiGetTimer"); @@ -183,9 +185,9 @@ return_ACPI_STATUS (AE_BAD_PARAMETER); } - *Ticks = AcpiHwLowLevelRead (32, &AcpiGbl_FADT->XPmTmrBlk, 0); + Status = AcpiHwLowLevelRead (32, Ticks, &AcpiGbl_FADT->XPmTmrBlk, 0); - return_ACPI_STATUS (AE_OK); + return_ACPI_STATUS (Status); } Index: nsaccess.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nsaccess.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 nsaccess.c --- nsaccess.c 30 Jun 2002 17:50:45 -0000 1.1.1.13 +++ nsaccess.c 1 Jul 2002 21:39:53 -0000 @@ -118,7 +118,6 @@ #include "acpi.h" #include "amlcode.h" -#include "acinterp.h" #include "acnamesp.h" #include "acdispat.h" @@ -283,7 +282,7 @@ /* Store pointer to value descriptor in the Node */ - AcpiNsAttachObject (NewNode, ObjDesc, ObjDesc->Common.Type); + Status = AcpiNsAttachObject (NewNode, ObjDesc, ACPI_GET_OBJECT_TYPE (ObjDesc)); /* Remove local reference to the object */ @@ -409,9 +408,10 @@ NumSegments = 0; ThisNode = AcpiGbl_RootNode; + Pathname = ""; ACPI_DEBUG_PRINT ((ACPI_DB_NAMES, - "Null Pathname (Zero segments), Flags=%x\n", Flags)); + "Null Pathname (Zero segments), Flags=%X\n", Flags)); } else { @@ -428,7 +428,7 @@ * Parent Prefixes (in which case the name's scope is relative * to the current scope). */ - if (*Pathname == AML_ROOT_PREFIX) + if (*Pathname == (UINT8) AML_ROOT_PREFIX) { /* Pathname is fully qualified, start from the root */ @@ -454,7 +454,7 @@ * the parent node for each prefix instance. */ ThisNode = PrefixNode; - while (*Pathname == AML_PARENT_PREFIX) + while (*Pathname == (UINT8) AML_PARENT_PREFIX) { /* * Point past this prefix to the name segment @@ -499,7 +499,7 @@ NumSegments = 0; ACPI_DEBUG_PRINT ((ACPI_DB_NAMES, - "Prefix-only Pathname (Zero name segments), Flags=%x\n", Flags)); + "Prefix-only Pathname (Zero name segments), Flags=%X\n", Flags)); break; case AML_DUAL_NAME_PREFIX: Index: nsalloc.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nsalloc.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 nsalloc.c --- nsalloc.c 30 Jun 2002 17:50:45 -0000 1.1.1.14 +++ nsalloc.c 1 Jul 2002 21:39:53 -0000 @@ -119,7 +119,6 @@ #include "acpi.h" #include "acnamesp.h" -#include "acinterp.h" #define _COMPONENT ACPI_NAMESPACE @@ -310,7 +309,7 @@ * real definition is found later. */ ACPI_DEBUG_PRINT ((ACPI_DB_NAMES, "[%4.4s] is a forward reference\n", - (char *) &Node->Name)); + Node->Name.Ascii)); } /* @@ -337,7 +336,7 @@ } ACPI_DEBUG_PRINT ((ACPI_DB_NAMES, "%4.4s added to %p at %p\n", - (char *) &Node->Name, ParentNode, Node)); + Node->Name.Ascii, ParentNode, Node)); /* * Increment the reference count(s) of all parents up to @@ -449,7 +448,7 @@ * ******************************************************************************/ -ACPI_STATUS +void AcpiNsDeleteNamespaceSubtree ( ACPI_NAMESPACE_NODE *ParentNode) { @@ -462,7 +461,7 @@ if (!ParentNode) { - return_ACPI_STATUS (AE_OK); + return_VOID; } /* @@ -518,7 +517,7 @@ } } - return_ACPI_STATUS (AE_OK); + return_VOID; } @@ -592,7 +591,7 @@ * ******************************************************************************/ -ACPI_STATUS +void AcpiNsDeleteNamespaceByOwner ( UINT16 OwnerId) { @@ -679,7 +678,7 @@ } } - return_ACPI_STATUS (AE_OK); + return_VOID; } Index: nsdump.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nsdump.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 nsdump.c --- nsdump.c 30 Jun 2002 17:50:45 -0000 1.1.1.14 +++ nsdump.c 1 Jul 2002 21:39:53 -0000 @@ -118,9 +118,7 @@ #define __NSDUMP_C__ #include "acpi.h" -#include "acinterp.h" #include "acnamesp.h" -#include "actables.h" #include "acparser.h" @@ -309,12 +307,12 @@ { if (AcpiNsExistDownstreamSibling (ThisNode + 1)) { - DownstreamSiblingMask |= (1 << (Level - 1)); + DownstreamSiblingMask |= ((UINT32) 1 << (Level - 1)); AcpiOsPrintf ("+"); } else { - DownstreamSiblingMask &= ACPI_UINT32_MAX ^ (1 << (Level - 1)); + DownstreamSiblingMask &= ACPI_UINT32_MAX ^ ((UINT32) 1 << (Level - 1)); AcpiOsPrintf ("+"); } @@ -342,14 +340,14 @@ if (!AcpiUtValidAcpiName (ThisNode->Name.Integer)) { - ACPI_REPORT_WARNING (("Invalid ACPI Name %08X\n", ThisNode->Name)); + ACPI_REPORT_WARNING (("Invalid ACPI Name %08X\n", ThisNode->Name.Integer)); } /* * Now we can print out the pertinent information */ AcpiOsPrintf (" %4.4s %-12s %p", - (char *) &ThisNode->Name, AcpiUtGetTypeName (Type), ThisNode); + ThisNode->Name.Ascii, AcpiUtGetTypeName (Type), ThisNode); DbgLevel = AcpiDbgLevel; AcpiDbgLevel = 0; @@ -372,7 +370,7 @@ { case ACPI_TYPE_PROCESSOR: - AcpiOsPrintf (" ID %d Addr %.4X Len %.4X\n", + AcpiOsPrintf (" ID %hd Addr %.4X Len %.4X\n", ObjDesc->Processor.ProcId, ObjDesc->Processor.Address, ObjDesc->Processor.Length); @@ -387,7 +385,7 @@ case ACPI_TYPE_METHOD: - AcpiOsPrintf (" Args %d Len %.4X Aml %p \n", + AcpiOsPrintf (" Args %hd Len %.4X Aml %p \n", ObjDesc->Method.ParamCount, ObjDesc->Method.AmlLength, ObjDesc->Method.AmlStart); @@ -430,7 +428,7 @@ AcpiOsPrintf (" ="); for (i = 0; (i < ObjDesc->Buffer.Length && i < 12); i++) { - AcpiOsPrintf (" %.2X", ObjDesc->Buffer.Pointer[i]); + AcpiOsPrintf (" %.2hX", ObjDesc->Buffer.Pointer[i]); } } AcpiOsPrintf ("\n"); @@ -488,7 +486,7 @@ ObjDesc->BufferField.BufferObj->Buffer.Node) { AcpiOsPrintf (" Buf [%4.4s]", - (char *) &ObjDesc->BufferField.BufferObj->Buffer.Node->Name); + ObjDesc->BufferField.BufferObj->Buffer.Node->Name.Ascii); } break; @@ -496,23 +494,23 @@ case INTERNAL_TYPE_REGION_FIELD: AcpiOsPrintf (" Rgn [%4.4s]", - (char *) &ObjDesc->CommonField.RegionObj->Region.Node->Name); + ObjDesc->CommonField.RegionObj->Region.Node->Name.Ascii); break; case INTERNAL_TYPE_BANK_FIELD: AcpiOsPrintf (" Rgn [%4.4s] Bnk [%4.4s]", - (char *) &ObjDesc->CommonField.RegionObj->Region.Node->Name, - (char *) &ObjDesc->BankField.BankObj->CommonField.Node->Name); + ObjDesc->CommonField.RegionObj->Region.Node->Name.Ascii, + ObjDesc->BankField.BankObj->CommonField.Node->Name.Ascii); break; case INTERNAL_TYPE_INDEX_FIELD: AcpiOsPrintf (" Idx [%4.4s] Dat [%4.4s]", - (char *) &ObjDesc->IndexField.IndexObj->CommonField.Node->Name, - (char *) &ObjDesc->IndexField.DataObj->CommonField.Node->Name); + ObjDesc->IndexField.IndexObj->CommonField.Node->Name.Ascii, + ObjDesc->IndexField.DataObj->CommonField.Node->Name.Ascii); break; @@ -530,14 +528,16 @@ case INTERNAL_TYPE_REGION_FIELD: case INTERNAL_TYPE_BANK_FIELD: case INTERNAL_TYPE_INDEX_FIELD: - AcpiOsPrintf (" Off %.2X Len %.2X Acc %.2d\n", + AcpiOsPrintf (" Off %.2X Len %.2X Acc %.2hd\n", (ObjDesc->CommonField.BaseByteOffset * 8) + ObjDesc->CommonField.StartFieldBitOffset, ObjDesc->CommonField.BitLength, ObjDesc->CommonField.AccessByteWidth); break; + + default: + break; } - break; @@ -631,9 +631,9 @@ break; - case ACPI_DESC_TYPE_INTERNAL: + case ACPI_DESC_TYPE_OPERAND: - ObjType = ObjDesc->Common.Type; + ObjType = ACPI_GET_OBJECT_TYPE (ObjDesc); if (ObjType > INTERNAL_TYPE_MAX) { @@ -642,8 +642,8 @@ } else { - AcpiOsPrintf ("(Ptr to ACPI Object type %2.2X [%s])\n", - ObjType, AcpiUtGetTypeName (ObjType)); + AcpiOsPrintf ("(Ptr to ACPI Object type %s, %X)\n", + AcpiUtGetTypeName (ObjType), ObjType); BytesToDump = sizeof (ACPI_OPERAND_OBJECT); } break; @@ -660,7 +660,7 @@ /* If value is NOT an internal object, we are done */ - if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_INTERNAL) + if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) != ACPI_DESC_TYPE_OPERAND) { goto Cleanup; } @@ -671,11 +671,11 @@ switch (ObjType) { case ACPI_TYPE_STRING: - ObjDesc = (ACPI_OPERAND_OBJECT *) ObjDesc->String.Pointer; + ObjDesc = (void *) ObjDesc->String.Pointer; break; case ACPI_TYPE_BUFFER: - ObjDesc = (ACPI_OPERAND_OBJECT *) ObjDesc->Buffer.Pointer; + ObjDesc = (void *) ObjDesc->Buffer.Pointer; break; case ACPI_TYPE_BUFFER_FIELD: @@ -683,26 +683,26 @@ break; case ACPI_TYPE_PACKAGE: - ObjDesc = (ACPI_OPERAND_OBJECT *) ObjDesc->Package.Elements; + ObjDesc = (void *) ObjDesc->Package.Elements; break; case ACPI_TYPE_METHOD: - ObjDesc = (ACPI_OPERAND_OBJECT *) ObjDesc->Method.AmlStart; + ObjDesc = (void *) ObjDesc->Method.AmlStart; break; case INTERNAL_TYPE_REGION_FIELD: - ObjDesc = (ACPI_OPERAND_OBJECT *) ObjDesc->Field.RegionObj; + ObjDesc = (void *) ObjDesc->Field.RegionObj; break; case INTERNAL_TYPE_BANK_FIELD: - ObjDesc = (ACPI_OPERAND_OBJECT *) ObjDesc->BankField.RegionObj; + ObjDesc = (void *) ObjDesc->BankField.RegionObj; break; case INTERNAL_TYPE_INDEX_FIELD: - ObjDesc = (ACPI_OPERAND_OBJECT *) ObjDesc->IndexField.IndexObj; + ObjDesc = (void *) ObjDesc->IndexField.IndexObj; break; - default: + default: goto Cleanup; } @@ -750,8 +750,9 @@ Info.DisplayType = DisplayType; - AcpiNsWalkNamespace (Type, StartHandle, MaxDepth, ACPI_NS_WALK_NO_UNLOCK, AcpiNsDumpOneObject, - (void *) &Info, NULL); + (void) AcpiNsWalkNamespace (Type, StartHandle, MaxDepth, + ACPI_NS_WALK_NO_UNLOCK, AcpiNsDumpOneObject, + (void *) &Info, NULL); } @@ -794,7 +795,7 @@ ACPI_DEBUG_PRINT_RAW ((ACPI_DB_TABLES, " ")); } - ACPI_DEBUG_PRINT_RAW ((ACPI_DB_TABLES, " HID: %s, ADR: %8.8X%8.8X, Status: %x\n", + ACPI_DEBUG_PRINT_RAW ((ACPI_DB_TABLES, " HID: %s, ADR: %8.8X%8.8X, Status: %X\n", Info.HardwareId, ACPI_HIDWORD (Info.Address), ACPI_LODWORD (Info.Address), Info.CurrentStatus)); @@ -818,6 +819,7 @@ AcpiNsDumpRootDevices (void) { ACPI_HANDLE SysBusHandle; + ACPI_STATUS Status; ACPI_FUNCTION_NAME ("NsDumpRootDevices"); @@ -830,11 +832,17 @@ return; } - AcpiGetHandle (0, ACPI_NS_SYSTEM_BUS, &SysBusHandle); + Status = AcpiGetHandle (0, ACPI_NS_SYSTEM_BUS, &SysBusHandle); + if (ACPI_FAILURE (Status)) + { + return; + } ACPI_DEBUG_PRINT ((ACPI_DB_TABLES, "Display of all devices in the namespace:\n")); - AcpiNsWalkNamespace (ACPI_TYPE_DEVICE, SysBusHandle, ACPI_UINT32_MAX, ACPI_NS_WALK_NO_UNLOCK, - AcpiNsDumpOneDevice, NULL, NULL); + + Status = AcpiNsWalkNamespace (ACPI_TYPE_DEVICE, SysBusHandle, + ACPI_UINT32_MAX, ACPI_NS_WALK_NO_UNLOCK, + AcpiNsDumpOneDevice, NULL, NULL); } #endif @@ -914,7 +922,7 @@ Info.OwnerId = ACPI_UINT32_MAX; Info.DisplayType = ACPI_DISPLAY_SUMMARY; - AcpiNsDumpOneObject (Handle, 1, &Info, NULL); + (void) AcpiNsDumpOneObject (Handle, 1, &Info, NULL); } #endif Index: nseval.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nseval.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 nseval.c --- nseval.c 30 Jun 2002 17:50:45 -0000 1.1.1.13 +++ nseval.c 1 Jul 2002 21:39:53 -0000 @@ -119,7 +119,6 @@ #define __NSEVAL_C__ #include "acpi.h" -#include "amlcode.h" #include "acparser.h" #include "acinterp.h" #include "acnamesp.h" @@ -134,12 +133,12 @@ * FUNCTION: AcpiNsEvaluateRelative * * PARAMETERS: Handle - The relative containing object - * *Pathname - Name of method to execute, If NULL, the + * Pathname - Name of method to execute, If NULL, the * handle is the object to execute - * **Params - List of parameters to pass to the method, + * Params - List of parameters to pass to the method, * terminated by NULL. Params itself may be * NULL if no parameters are being passed. - * *ReturnObject - Where to put method's return value (if + * ReturnObject - Where to put method's return value (if * any). If NULL, no value is returned. * * RETURN: Status @@ -240,9 +239,9 @@ * FUNCTION: AcpiNsEvaluateByName * * PARAMETERS: Pathname - Fully qualified pathname to the object - * *ReturnObject - Where to put method's return value (if + * ReturnObject - Where to put method's return value (if * any). If NULL, no value is returned. - * **Params - List of parameters to pass to the method, + * Params - List of parameters to pass to the method, * terminated by NULL. Params itself may be * NULL if no parameters are being passed. * @@ -329,10 +328,10 @@ * FUNCTION: AcpiNsEvaluateByHandle * * PARAMETERS: Handle - Method Node to execute - * **Params - List of parameters to pass to the method, + * Params - List of parameters to pass to the method, * terminated by NULL. Params itself may be * NULL if no parameters are being passed. - * *ReturnObject - Where to put method's return value (if + * ReturnObject - Where to put method's return value (if * any). If NULL, no value is returned. * * RETURN: Status @@ -393,7 +392,6 @@ return_ACPI_STATUS (AE_BAD_PARAMETER); } - /* * Two major cases here: * 1) The object is an actual control method -- execute it. @@ -411,7 +409,6 @@ Status = AcpiNsExecuteControlMethod (Node, Params, &LocalReturnObject); } - else { /* @@ -421,7 +418,6 @@ Status = AcpiNsGetObjectValue (Node, &LocalReturnObject); } - /* * Check if there is a return value on the stack that must * be dealt with @@ -443,13 +439,9 @@ *ReturnObject = LocalReturnObject; } + /* Map AE_CTRL_RETURN_VALUE to AE_OK, we are done with it */ - /* Map AE_RETURN_VALUE to AE_OK, we are done with it */ - - if (Status == AE_CTRL_RETURN_VALUE) - { - Status = AE_OK; - } + Status = AE_OK; } /* @@ -464,11 +456,11 @@ * * FUNCTION: AcpiNsExecuteControlMethod * - * PARAMETERS: MethodNode - The object/method - * **Params - List of parameters to pass to the method, + * PARAMETERS: MethodNode - The method to execute + * Params - List of parameters to pass to the method, * terminated by NULL. Params itself may be * NULL if no parameters are being passed. - * **ReturnObjDesc - List of result objects to be returned + * ReturnObjDesc - List of result objects to be returned * from the method. * * RETURN: Status @@ -506,7 +498,7 @@ ACPI_DUMP_PATHNAME (MethodNode, "NsExecuteControlMethod: Executing", ACPI_LV_INFO, _COMPONENT); - ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Method at AML address %p Length %x\n", + ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Method at AML address %p Length %X\n", ObjDesc->Method.AmlStart + 1, ObjDesc->Method.AmlLength - 1)); /* @@ -543,7 +535,8 @@ * * FUNCTION: AcpiNsGetObjectValue * - * PARAMETERS: Node - The object + * PARAMETERS: Node - The object + * ReturnObjDesc - Where the objects value is returned * * RETURN: Status * @@ -559,7 +552,7 @@ ACPI_OPERAND_OBJECT **ReturnObjDesc) { ACPI_STATUS Status = AE_OK; - ACPI_OPERAND_OBJECT *ObjDesc; + ACPI_NAMESPACE_NODE *ResolvedNode = Node; ACPI_FUNCTION_TRACE ("NsGetObjectValue"); @@ -570,7 +563,6 @@ * Node may be a field that must be read, etc.) -- we can't just grab * the object out of the node. */ - ObjDesc = (ACPI_OPERAND_OBJECT *) Node; /* * Use ResolveNodeToValue() to get the associated value. This call @@ -599,18 +591,18 @@ Status = AcpiExEnterInterpreter (); if (ACPI_SUCCESS (Status)) { - Status = AcpiExResolveNodeToValue ((ACPI_NAMESPACE_NODE **) &ObjDesc, NULL); + Status = AcpiExResolveNodeToValue (&ResolvedNode, NULL); /* * If AcpiExResolveNodeToValue() succeeded, the return value was - * placed in ObjDesc. + * placed in ResolvedNode. */ AcpiExExitInterpreter (); if (ACPI_SUCCESS (Status)) { Status = AE_CTRL_RETURN_VALUE; - *ReturnObjDesc = ObjDesc; - ACPI_DEBUG_PRINT ((ACPI_DB_NAMES, "Returning obj %p\n", *ReturnObjDesc)); + *ReturnObjDesc = ACPI_CAST_PTR (ACPI_OPERAND_OBJECT, ResolvedNode); + ACPI_DEBUG_PRINT ((ACPI_DB_NAMES, "Returning obj %p\n", ResolvedNode)); } } Index: nsinit.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nsinit.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 nsinit.c --- nsinit.c 30 Jun 2002 17:50:45 -0000 1.1.1.14 +++ nsinit.c 1 Jul 2002 21:39:53 -0000 @@ -165,19 +165,20 @@ &Info, NULL); if (ACPI_FAILURE (Status)) { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "WalkNamespace failed! %x\n", Status)); + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "WalkNamespace failed! %s\n", + AcpiFormatException (Status))); } ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OK, - "\n Initialized %d/%d Regions %d/%d Fields %d/%d Buffers %d/%d Packages (%d nodes)\n", + "\nInitialized %hd/%hd Regions %hd/%hd Fields %hd/%hd Buffers %hd/%hd Packages (%hd nodes)\n", Info.OpRegionInit, Info.OpRegionCount, Info.FieldInit, Info.FieldCount, Info.BufferInit, Info.BufferCount, Info.PackageInit, Info.PackageCount, Info.ObjectCount)); ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, - "%d Control Methods found\n", Info.MethodCount)); + "%hd Control Methods found\n", Info.MethodCount)); ACPI_DEBUG_PRINT ((ACPI_DB_DISPATCH, - "%d Op Regions found\n", Info.OpRegionCount)); + "%hd Op Regions found\n", Info.OpRegionCount)); return_ACPI_STATUS (AE_OK); } @@ -225,11 +226,12 @@ if (ACPI_FAILURE (Status)) { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "WalkNamespace failed! %x\n", Status)); + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "WalkNamespace failed! %s\n", + AcpiFormatException (Status))); } ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OK, - "\n%d Devices found containing: %d _STA, %d _INI methods\n", + "\n%hd Devices found containing: %hd _STA, %hd _INI methods\n", Info.DeviceCount, Info.Num_STA, Info.Num_INI)); return_ACPI_STATUS (Status); @@ -359,6 +361,10 @@ Info->PackageInit++; Status = AcpiDsGetPackageArguments (ObjDesc); break; + + default: + /* No other types can get here */ + break; } if (ACPI_FAILURE (Status)) @@ -366,7 +372,7 @@ ACPI_DEBUG_PRINT_RAW ((ACPI_DB_ERROR, "\n")); ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Could not execute arguments for [%4.4s] (%s), %s\n", - (char *) &Node->Name, AcpiUtGetTypeName (Type), AcpiFormatException (Status))); + Node->Name.Ascii, AcpiUtGetTypeName (Type), AcpiFormatException (Status))); } if (!(AcpiDbgLevel & ACPI_LV_INIT)) @@ -465,27 +471,26 @@ */ ACPI_DEBUG_EXEC (AcpiUtDisplayInitPathname (ObjHandle, "_INI [Method]")); Status = AcpiNsEvaluateRelative (ObjHandle, "_INI", NULL, NULL); - if (AE_NOT_FOUND == Status) + if (ACPI_FAILURE (Status)) { - /* No _INI means device requires no initialization */ + /* No _INI (AE_NOT_FOUND) means device requires no initialization */ - Status = AE_OK; - } + if (Status != AE_NOT_FOUND) + { + /* Ignore error and move on to next device */ - else if (ACPI_FAILURE (Status)) - { - /* Ignore error and move on to next device */ + #ifdef ACPI_DEBUG + NATIVE_CHAR *ScopeName = AcpiNsGetExternalPathname (ObjHandle); -#ifdef ACPI_DEBUG - NATIVE_CHAR *ScopeName = AcpiNsGetExternalPathname (ObjHandle); + ACPI_DEBUG_PRINT ((ACPI_DB_WARN, "%s._INI failed: %s\n", + ScopeName, AcpiFormatException (Status))); - ACPI_DEBUG_PRINT ((ACPI_DB_WARN, "%s._INI failed: %s\n", - ScopeName, AcpiFormatException (Status))); + ACPI_MEM_FREE (ScopeName); + #endif + } - ACPI_MEM_FREE (ScopeName); -#endif + Status = AE_OK; } - else { /* Count of successful INIs */ @@ -493,5 +498,13 @@ Info->Num_INI++; } - return_ACPI_STATUS (AE_OK); + if (AcpiGbl_InitHandler) + { + /* External initialization handler is present, call it */ + + Status = AcpiGbl_InitHandler (ObjHandle, ACPI_INIT_DEVICE_INI); + } + + + return_ACPI_STATUS (Status); } Index: nsload.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nsload.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 nsload.c --- nsload.c 23 Feb 2002 05:10:40 -0000 1.1.1.11 +++ nsload.c 1 Jul 2002 21:39:53 -0000 @@ -117,12 +117,10 @@ #define __NSLOAD_C__ #include "acpi.h" -#include "acinterp.h" #include "acnamesp.h" #include "amlcode.h" #include "acparser.h" #include "acdispat.h" -#include "acdebug.h" #define _COMPONENT ACPI_NAMESPACE @@ -172,8 +170,8 @@ /* Ignore exceptions from these */ - AcpiNsLoadTableByType (ACPI_TABLE_SSDT); - AcpiNsLoadTableByType (ACPI_TABLE_PSDT); + (void) AcpiNsLoadTableByType (ACPI_TABLE_SSDT); + (void) AcpiNsLoadTableByType (ACPI_TABLE_PSDT); ACPI_DEBUG_PRINT_RAW ((ACPI_DB_OK, "ACPI Namespace successfully loaded at root %p\n", @@ -217,7 +215,7 @@ return_ACPI_STATUS (AE_NO_MEMORY); } - ((ACPI_PARSE2_OBJECT *) ParseRoot)->Name = ACPI_ROOT_NAME; + ParseRoot->Named.Name = ACPI_ROOT_NAME; /* Create and initialize a new walk state */ @@ -615,7 +613,11 @@ AcpiNsDeleteChildren (ChildHandle); ChildHandle = ParentHandle; - AcpiGetParent (ParentHandle, &ParentHandle); + Status = AcpiGetParent (ParentHandle, &ParentHandle); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } } } Index: nsnames.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nsnames.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 nsnames.c --- nsnames.c 23 Feb 2002 05:10:40 -0000 1.1.1.12 +++ nsnames.c 1 Jul 2002 21:39:53 -0000 @@ -118,7 +118,6 @@ #include "acpi.h" #include "amlcode.h" -#include "acinterp.h" #include "acnamesp.h" @@ -147,7 +146,7 @@ ACPI_SIZE Size, NATIVE_CHAR *NameBuffer) { - UINT32 Index; + ACPI_SIZE Index; ACPI_NAMESPACE_NODE *ParentNode; @@ -192,7 +191,7 @@ { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Could not construct pathname; index=%X, size=%X, Path=%s\n", - Index, Size, &NameBuffer[Size])); + (UINT32) Index, (UINT32) Size, &NameBuffer[Size])); } return; @@ -335,7 +334,7 @@ AcpiNsBuildExternalPath (Node, RequiredSize, Buffer->Pointer); - ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%s [%X] \n", (char *) Buffer->Pointer, RequiredSize)); + ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%s [%X] \n", (char *) Buffer->Pointer, (UINT32) RequiredSize)); return_ACPI_STATUS (AE_OK); } Index: nsobject.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nsobject.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 nsobject.c --- nsobject.c 30 Jun 2002 17:50:45 -0000 1.1.1.13 +++ nsobject.c 1 Jul 2002 21:39:53 -0000 @@ -119,10 +119,7 @@ #define __NSOBJECT_C__ #include "acpi.h" -#include "amlcode.h" #include "acnamesp.h" -#include "acinterp.h" -#include "actables.h" #define _COMPONENT ACPI_NAMESPACE @@ -243,13 +240,7 @@ } ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Installing %p into Node %p [%4.4s]\n", - ObjDesc, Node, (char *) &Node->Name)); - - /* - * Must increment the new value's reference count - * (if it is an internal object) - */ - AcpiUtAddReference (ObjDesc); + ObjDesc, Node, Node->Name.Ascii)); /* Detach an existing attached object if present */ @@ -258,20 +249,28 @@ AcpiNsDetachObject (Node); } - - /* - * Handle objects with multiple descriptors - walk - * to the end of the descriptor list - */ - LastObjDesc = ObjDesc; - while (LastObjDesc->Common.NextObject) + if (ObjDesc) { - LastObjDesc = LastObjDesc->Common.NextObject; - } + /* + * Must increment the new value's reference count + * (if it is an internal object) + */ + AcpiUtAddReference (ObjDesc); + + /* + * Handle objects with multiple descriptors - walk + * to the end of the descriptor list + */ + LastObjDesc = ObjDesc; + while (LastObjDesc->Common.NextObject) + { + LastObjDesc = LastObjDesc->Common.NextObject; + } - /* Install the object at the front of the object list */ + /* Install the object at the front of the object list */ - LastObjDesc->Common.NextObject = Node->Object; + LastObjDesc->Common.NextObject = Node->Object; + } Node->Type = (UINT8) ObjectType; Node->Object = ObjDesc; @@ -305,8 +304,9 @@ ObjDesc = Node->Object; - if (!ObjDesc || - (ObjDesc->Common.Type == INTERNAL_TYPE_DATA)) + + if (!ObjDesc || + (ACPI_GET_OBJECT_TYPE (ObjDesc) == INTERNAL_TYPE_DATA)) { return_VOID; } @@ -314,11 +314,11 @@ /* Clear the entry in all cases */ Node->Object = NULL; - if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) == ACPI_DESC_TYPE_INTERNAL) + if (ACPI_GET_DESCRIPTOR_TYPE (ObjDesc) == ACPI_DESC_TYPE_OPERAND) { Node->Object = ObjDesc->Common.NextObject; if (Node->Object && - (Node->Object->Common.Type != INTERNAL_TYPE_DATA)) + (ACPI_GET_OBJECT_TYPE (Node->Object) != INTERNAL_TYPE_DATA)) { Node->Object = Node->Object->Common.NextObject; } @@ -329,7 +329,7 @@ Node->Type = ACPI_TYPE_ANY; ACPI_DEBUG_PRINT ((ACPI_DB_NAMES, "Node %p [%4.4s] Object %p\n", - Node, (char *) &Node->Name, ObjDesc)); + Node, Node->Name.Ascii, ObjDesc)); /* Remove one reference on the object (and all subobjects) */ @@ -363,9 +363,9 @@ } if (!Node->Object || - ((ACPI_GET_DESCRIPTOR_TYPE (Node->Object) != ACPI_DESC_TYPE_INTERNAL) && - (ACPI_GET_DESCRIPTOR_TYPE (Node->Object) != ACPI_DESC_TYPE_NAMED)) || - (Node->Object->Common.Type == INTERNAL_TYPE_DATA)) + ((ACPI_GET_DESCRIPTOR_TYPE (Node->Object) != ACPI_DESC_TYPE_OPERAND) && + (ACPI_GET_DESCRIPTOR_TYPE (Node->Object) != ACPI_DESC_TYPE_NAMED)) || + (ACPI_GET_OBJECT_TYPE (Node->Object) == INTERNAL_TYPE_DATA)) { return_PTR (NULL); } @@ -392,10 +392,10 @@ ACPI_FUNCTION_TRACE_PTR ("NsGetSecondaryObject", ObjDesc); - if ((!ObjDesc) || - (ObjDesc->Common.Type == INTERNAL_TYPE_DATA) || - (!ObjDesc->Common.NextObject) || - (ObjDesc->Common.NextObject->Common.Type == INTERNAL_TYPE_DATA)) + if ((!ObjDesc) || + (ACPI_GET_OBJECT_TYPE (ObjDesc) == INTERNAL_TYPE_DATA) || + (!ObjDesc->Common.NextObject) || + (ACPI_GET_OBJECT_TYPE (ObjDesc->Common.NextObject) == INTERNAL_TYPE_DATA)) { return_PTR (NULL); } @@ -432,7 +432,7 @@ ObjDesc = Node->Object; while (ObjDesc) { - if ((ObjDesc->Common.Type == INTERNAL_TYPE_DATA) && + if ((ACPI_GET_OBJECT_TYPE (ObjDesc) == INTERNAL_TYPE_DATA) && (ObjDesc->Data.Handler == Handler)) { return (AE_ALREADY_EXISTS); @@ -495,7 +495,7 @@ ObjDesc = Node->Object; while (ObjDesc) { - if ((ObjDesc->Common.Type == INTERNAL_TYPE_DATA) && + if ((ACPI_GET_OBJECT_TYPE (ObjDesc) == INTERNAL_TYPE_DATA) && (ObjDesc->Data.Handler == Handler)) { if (PrevObjDesc) @@ -543,7 +543,7 @@ ObjDesc = Node->Object; while (ObjDesc) { - if ((ObjDesc->Common.Type == INTERNAL_TYPE_DATA) && + if ((ACPI_GET_OBJECT_TYPE (ObjDesc) == INTERNAL_TYPE_DATA) && (ObjDesc->Data.Handler == Handler)) { *Data = ObjDesc->Data.Pointer; Index: nssearch.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nssearch.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 nssearch.c --- nssearch.c 30 Jun 2002 17:50:45 -0000 1.1.1.14 +++ nssearch.c 1 Jul 2002 21:39:53 -0000 @@ -117,8 +117,6 @@ #define __NSSEARCH_C__ #include "acpi.h" -#include "amlcode.h" -#include "acinterp.h" #include "acnamesp.h" @@ -308,7 +306,8 @@ if (AcpiNsLocal (Type)) { - ACPI_DEBUG_PRINT ((ACPI_DB_NAMES, "[%4.4s] type [%s] must be local to this scope (no parent search)\n", + ACPI_DEBUG_PRINT ((ACPI_DB_NAMES, + "[%4.4s] type [%s] must be local to this scope (no parent search)\n", (char *) &TargetName, AcpiUtGetTypeName (Type))); } Index: nsutils.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nsutils.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 nsutils.c --- nsutils.c 30 Jun 2002 17:50:45 -0000 1.1.1.13 +++ nsutils.c 1 Jul 2002 21:39:53 -0000 @@ -119,7 +119,6 @@ #include "acpi.h" #include "acnamesp.h" -#include "acinterp.h" #include "amlcode.h" #include "actables.h" @@ -240,7 +239,7 @@ * ******************************************************************************/ -ACPI_STATUS +void AcpiNsGetInternalNameLength ( ACPI_NAMESTRING_INFO *Info) { @@ -304,8 +303,6 @@ 4 + Info->NumCarats; Info->NextExternalChar = NextExternalChar; - - return (AE_OK); } @@ -330,7 +327,7 @@ NATIVE_CHAR *InternalName = Info->InternalName; NATIVE_CHAR *ExternalName = Info->NextExternalChar; NATIVE_CHAR *Result = NULL; - UINT32 i; + NATIVE_UINT i; ACPI_FUNCTION_TRACE ("NsBuildInternalName"); @@ -407,7 +404,7 @@ { /* Convert the character to uppercase and save it */ - Result[i] = (char) ACPI_TOUPPER (*ExternalName); + Result[i] = (char) ACPI_TOUPPER ((int) *ExternalName); ExternalName++; } } @@ -530,12 +527,12 @@ UINT32 *ConvertedNameLength, char **ConvertedName) { - UINT32 PrefixLength = 0; - UINT32 NamesIndex = 0; - UINT32 NumSegments = 0; - UINT32 i = 0; - UINT32 j = 0; - UINT32 RequiredLength; + NATIVE_UINT_MIN32 PrefixLength = 0; + NATIVE_UINT_MIN32 NamesIndex = 0; + NATIVE_UINT_MIN32 NumSegments = 0; + NATIVE_UINT_MIN32 i = 0; + NATIVE_UINT_MIN32 j = 0; + NATIVE_UINT_MIN32 RequiredLength; ACPI_FUNCTION_TRACE ("NsExternalizeName"); @@ -572,6 +569,9 @@ } break; + + default: + break; } /* @@ -668,7 +668,7 @@ if (ConvertedNameLength) { - *ConvertedNameLength = RequiredLength; + *ConvertedNameLength = (UINT32) RequiredLength; } return_ACPI_STATUS (AE_OK); @@ -963,17 +963,17 @@ if (ParentNode) { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Parent of %p [%4.4s] is %p [%4.4s]\n", - ChildNode, (char *) &ChildNode->Name, - ParentNode, (char *) &ParentNode->Name)); + ChildNode, ChildNode->Name.Ascii, + ParentNode, ParentNode->Name.Ascii)); if (ParentNode->Name.Integer) { - return_VALUE (ParentNode->Name.Integer); + return_VALUE ((ACPI_NAME) ParentNode->Name.Integer); } } ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "unable to find parent of %p (%4.4s)\n", - ChildNode, (char *) &ChildNode->Name)); + ChildNode, ChildNode->Name.Ascii)); } return_VALUE (ACPI_UNKNOWN_NAME); Index: nswalk.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nswalk.c,v retrieving revision 1.1.1.8 diff -u -r1.1.1.8 nswalk.c --- nswalk.c 23 Feb 2002 05:10:40 -0000 1.1.1.8 +++ nswalk.c 1 Jul 2002 21:39:53 -0000 @@ -118,7 +118,6 @@ #define __NSWALK_C__ #include "acpi.h" -#include "acinterp.h" #include "acnamesp.h" Index: nsxfname.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nsxfname.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 nsxfname.c --- nsxfname.c 30 Jun 2002 17:50:45 -0000 1.1.1.11 +++ nsxfname.c 1 Jul 2002 21:39:53 -0000 @@ -118,12 +118,7 @@ #define __NSXFNAME_C__ #include "acpi.h" -#include "acinterp.h" #include "acnamesp.h" -#include "amlcode.h" -#include "acparser.h" -#include "acdispat.h" -#include "acevents.h" #define _COMPONENT ACPI_NAMESPACE @@ -290,7 +285,7 @@ /* Just copy the ACPI name from the Node and zero terminate it */ - ACPI_STRNCPY (Buffer->Pointer, (NATIVE_CHAR *) &Node->Name, + ACPI_STRNCPY (Buffer->Pointer, Node->Name.Ascii, ACPI_NAME_SIZE); ((NATIVE_CHAR *) Buffer->Pointer) [ACPI_NAME_SIZE] = 0; Status = AE_OK; Index: nsxfobj.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/nsxfobj.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 nsxfobj.c --- nsxfobj.c 23 Feb 2002 05:10:40 -0000 1.1.1.14 +++ nsxfobj.c 1 Jul 2002 21:39:53 -0000 @@ -119,9 +119,7 @@ #define __NSXFOBJ_C__ #include "acpi.h" -#include "acinterp.h" #include "acnamesp.h" -#include "acdispat.h" #define _COMPONENT ACPI_NAMESPACE @@ -130,6 +128,106 @@ /******************************************************************************* * + * FUNCTION: AcpiEvaluateObjectTyped + * + * PARAMETERS: Handle - Object handle (optional) + * *Pathname - Object pathname (optional) + * **ExternalParams - List of parameters to pass to method, + * terminated by NULL. May be NULL + * if no parameters are being passed. + * *ReturnBuffer - Where to put method's return value (if + * any). If NULL, no value is returned. + * ReturnType - Expected type of return object + * + * RETURN: Status + * + * DESCRIPTION: Find and evaluate the given object, passing the given + * parameters if necessary. One of "Handle" or "Pathname" must + * be valid (non-null) + * + ******************************************************************************/ + +ACPI_STATUS +AcpiEvaluateObjectTyped ( + ACPI_HANDLE Handle, + ACPI_STRING Pathname, + ACPI_OBJECT_LIST *ExternalParams, + ACPI_BUFFER *ReturnBuffer, + ACPI_OBJECT_TYPE ReturnType) +{ + ACPI_STATUS Status; + BOOLEAN MustFree = FALSE; + + + ACPI_FUNCTION_TRACE ("AcpiEvaluateObjectTyped"); + + + /* Return buffer must be valid */ + + if (!ReturnBuffer) + { + return_ACPI_STATUS (AE_BAD_PARAMETER); + } + + if (ReturnBuffer->Length == ACPI_ALLOCATE_BUFFER) + { + MustFree = TRUE; + } + + /* Evaluate the object */ + + Status = AcpiEvaluateObject (Handle, Pathname, ExternalParams, ReturnBuffer); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } + + /* Type ANY means "don't care" */ + + if (ReturnType == ACPI_TYPE_ANY) + { + return_ACPI_STATUS (AE_OK); + } + + if (ReturnBuffer->Length == 0) + { + /* Error because caller specifically asked for a return value */ + + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, + "No return value\n")); + + return_ACPI_STATUS (AE_NULL_OBJECT); + } + + /* Examine the object type returned from EvaluateObject */ + + if (((ACPI_OBJECT *) ReturnBuffer->Pointer)->Type == ReturnType) + { + return_ACPI_STATUS (AE_OK); + } + + /* Return object type does not match requested type */ + + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, + "Incorrect return type [%s] requested [%s]\n", + AcpiUtGetTypeName (((ACPI_OBJECT *) ReturnBuffer->Pointer)->Type), + AcpiUtGetTypeName (ReturnType))); + + if (MustFree) + { + /* Caller used ACPI_ALLOCATE_BUFFER, free the return buffer */ + + AcpiOsFree (ReturnBuffer->Pointer); + ReturnBuffer->Pointer = NULL; + } + + ReturnBuffer->Length = 0; + return_ACPI_STATUS (AE_TYPE); +} + + +/******************************************************************************* + * * FUNCTION: AcpiEvaluateObject * * PARAMETERS: Handle - Object handle (optional) @@ -176,7 +274,7 @@ * Allocate a new parameter block for the internal objects * Add 1 to count to allow for null terminated internal list */ - InternalParams = ACPI_MEM_CALLOCATE ((ExternalParams->Count + 1) * + InternalParams = ACPI_MEM_CALLOCATE (((ACPI_SIZE) ExternalParams->Count + 1) * sizeof (void *)); if (!InternalParams) { @@ -309,7 +407,7 @@ */ ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "Needed buffer size %X, %s\n", - BufferSpaceNeeded, AcpiFormatException (Status))); + (UINT32) BufferSpaceNeeded, AcpiFormatException (Status))); } else { @@ -747,8 +845,8 @@ } } - Info->UserFunction (ObjHandle, NestingLevel, Info->Context, ReturnValue); - return (AE_OK); + Status = Info->UserFunction (ObjHandle, NestingLevel, Info->Context, ReturnValue); + return (Status); } Index: psargs.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/psargs.c,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 psargs.c --- psargs.c 23 Feb 2002 05:10:37 -0000 1.1.1.10 +++ psargs.c 1 Jul 2002 21:39:53 -0000 @@ -186,6 +186,10 @@ (EncodedLength & 0x0F)); ParserState->Aml += 3; break; + + default: + /* Can't get here, only 2 bits / 4 cases */ + break; } return_VALUE (Length); @@ -241,9 +245,8 @@ AcpiPsGetNextNamestring ( ACPI_PARSE_STATE *ParserState) { - UINT8 *Start = ParserState->Aml; - UINT8 *End = ParserState->Aml; - UINT32 Length; + UINT8 *Start = ParserState->Aml; + UINT8 *End = ParserState->Aml; ACPI_FUNCTION_TRACE ("PsGetNextNamestring"); @@ -273,35 +276,29 @@ End++; break; - case AML_DUAL_NAME_PREFIX: - /* two name segments */ + /* Two name segments */ End += 9; break; - case AML_MULTI_NAME_PREFIX_OP: - /* multiple name segments */ + /* Multiple name segments, 4 chars each */ - Length = (UINT32) ACPI_GET8 (End + 1) * 4; - End += 2 + Length; + End += 2 + ((ACPI_SIZE) ACPI_GET8 (End + 1) * 4); break; - default: - /* single name segment */ - /* assert (AcpiPsIsLead (GET8 (End))); */ + /* Single name segment */ End += 4; break; } ParserState->Aml = (UINT8*) End; - return_PTR ((NATIVE_CHAR *) Start); } @@ -352,7 +349,7 @@ /* Null name case, create a null namepath object */ AcpiPsInitOp (Arg, AML_INT_NAMEPATH_OP); - Arg->Value.Name = Path; + Arg->Common.Value.Name = Path; return_VOID; } @@ -371,7 +368,7 @@ if (Op) { - if (Op->Opcode == AML_METHOD_OP) + if (Op->Common.AmlOpcode == AML_METHOD_OP) { /* * The name refers to a control method, so this namepath is a @@ -380,7 +377,7 @@ * object into a METHODCALL object. */ Count = AcpiPsGetArg (Op, 0); - if (Count && Count->Opcode == AML_BYTE_OP) + if (Count && Count->Common.AmlOpcode == AML_BYTE_OP) { NameOp = AcpiPsAllocOp (AML_INT_NAMEPATH_OP); if (NameOp) @@ -389,14 +386,14 @@ AcpiPsInitOp (Arg, AML_INT_METHODCALL_OP); - NameOp->Value.Name = Path; + NameOp->Common.Value.Name = Path; /* Point METHODCALL/NAME to the METHOD Node */ - NameOp->Node = (ACPI_NAMESPACE_NODE *) Op; + NameOp->Common.Node = (ACPI_NAMESPACE_NODE *) Op; AcpiPsAppendArg (Arg, NameOp); - *ArgCount = (UINT32) Count->Value.Integer & + *ArgCount = (UINT32) Count->Common.Value.Integer & METHOD_FLAGS_ARG_COUNT; } } @@ -418,7 +415,7 @@ * pathname */ AcpiPsInitOp (Arg, AML_INT_NAMEPATH_OP); - Arg->Value.Name = Path; + Arg->Common.Value.Name = Path; return_VOID; @@ -452,71 +449,67 @@ /* Null name case, create a null namepath object */ AcpiPsInitOp (Arg, AML_INT_NAMEPATH_OP); - Arg->Value.Name = Path; + Arg->Common.Value.Name = Path; return_VOID; } - - if (MethodCall) + /* + * Lookup the name in the internal namespace + */ + ScopeInfo.Scope.Node = NULL; + Node = ParserState->StartNode; + if (Node) { - /* - * Lookup the name in the internal namespace - */ - ScopeInfo.Scope.Node = NULL; - Node = ParserState->StartNode; - if (Node) - { - ScopeInfo.Scope.Node = Node; - } - - /* - * Lookup object. We don't want to add anything new to the namespace - * here, however. So we use MODE_EXECUTE. Allow searching of the - * parent tree, but don't open a new scope -- we just want to lookup the - * object (MUST BE mode EXECUTE to perform upsearch) - */ - Status = AcpiNsLookup (&ScopeInfo, Path, ACPI_TYPE_ANY, ACPI_IMODE_EXECUTE, - ACPI_NS_SEARCH_PARENT | ACPI_NS_DONT_OPEN_SCOPE, NULL, - &Node); - if (ACPI_SUCCESS (Status)) - { - if (Node->Type == ACPI_TYPE_METHOD) - { - MethodNode = Node; - ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, "method - %p Path=%p\n", - MethodNode, Path)); + ScopeInfo.Scope.Node = Node; + } - NameOp = AcpiPsAllocOp (AML_INT_NAMEPATH_OP); - if (NameOp) - { - /* Change arg into a METHOD CALL and attach name to it */ + /* + * Lookup object. We don't want to add anything new to the namespace + * here, however. So we use MODE_EXECUTE. Allow searching of the + * parent tree, but don't open a new scope -- we just want to lookup the + * object (MUST BE mode EXECUTE to perform upsearch) + */ + Status = AcpiNsLookup (&ScopeInfo, Path, ACPI_TYPE_ANY, ACPI_IMODE_EXECUTE, + ACPI_NS_SEARCH_PARENT | ACPI_NS_DONT_OPEN_SCOPE, NULL, + &Node); + if (ACPI_SUCCESS (Status)) + { + if (Node->Type == ACPI_TYPE_METHOD) + { + MethodNode = Node; + ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, "method - %p Path=%p\n", + MethodNode, Path)); - AcpiPsInitOp (Arg, AML_INT_METHODCALL_OP); + NameOp = AcpiPsAllocOp (AML_INT_NAMEPATH_OP); + if (NameOp) + { + /* Change arg into a METHOD CALL and attach name to it */ - NameOp->Value.Name = Path; + AcpiPsInitOp (Arg, AML_INT_METHODCALL_OP); - /* Point METHODCALL/NAME to the METHOD Node */ + NameOp->Common.Value.Name = Path; - NameOp->Node = MethodNode; - AcpiPsAppendArg (Arg, NameOp); + /* Point METHODCALL/NAME to the METHOD Node */ - if (!AcpiNsGetAttachedObject (MethodNode)) - { - return_VOID; - } + NameOp->Common.Node = MethodNode; + AcpiPsAppendArg (Arg, NameOp); - *ArgCount = (AcpiNsGetAttachedObject (MethodNode))->Method.ParamCount; + if (!AcpiNsGetAttachedObject (MethodNode)) + { + return_VOID; } - return_VOID; + *ArgCount = (AcpiNsGetAttachedObject (MethodNode))->Method.ParamCount; } - /* - * Else this is normal named object reference. - * Just init the NAMEPATH object with the pathname. - * (See code below) - */ + return_VOID; } + + /* + * Else this is normal named object reference. + * Just init the NAMEPATH object with the pathname. + * (See code below) + */ } /* @@ -525,7 +518,7 @@ * pathname. */ AcpiPsInitOp (Arg, AML_INT_NAMEPATH_OP); - Arg->Value.Name = Path; + Arg->Common.Value.Name = Path; return_VOID; @@ -559,11 +552,10 @@ switch (ArgType) { - case ARGP_BYTEDATA: AcpiPsInitOp (Arg, AML_BYTE_OP); - Arg->Value.Integer = (UINT32) ACPI_GET8 (ParserState->Aml); + Arg->Common.Value.Integer = (UINT32) ACPI_GET8 (ParserState->Aml); ParserState->Aml++; break; @@ -574,7 +566,7 @@ /* Get 2 bytes from the AML stream */ - ACPI_MOVE_UNALIGNED16_TO_32 (&Arg->Value.Integer, ParserState->Aml); + ACPI_MOVE_UNALIGNED16_TO_32 (&Arg->Common.Value.Integer, ParserState->Aml); ParserState->Aml += 2; break; @@ -585,7 +577,7 @@ /* Get 4 bytes from the AML stream */ - ACPI_MOVE_UNALIGNED32_TO_32 (&Arg->Value.Integer, ParserState->Aml); + ACPI_MOVE_UNALIGNED32_TO_32 (&Arg->Common.Value.Integer, ParserState->Aml); ParserState->Aml += 4; break; @@ -596,7 +588,7 @@ /* Get 8 bytes from the AML stream */ - ACPI_MOVE_UNALIGNED64_TO_64 (&Arg->Value.Integer, ParserState->Aml); + ACPI_MOVE_UNALIGNED64_TO_64 (&Arg->Common.Value.Integer, ParserState->Aml); ParserState->Aml += 8; break; @@ -604,7 +596,7 @@ case ARGP_CHARLIST: AcpiPsInitOp (Arg, AML_STRING_OP); - Arg->Value.String = (char *) ParserState->Aml; + Arg->Common.Value.String = (char *) ParserState->Aml; while (ACPI_GET8 (ParserState->Aml) != '\0') { @@ -618,7 +610,12 @@ case ARGP_NAMESTRING: AcpiPsInitOp (Arg, AML_INT_NAMEPATH_OP); - Arg->Value.Name = AcpiPsGetNextNamestring (ParserState); + Arg->Common.Value.Name = AcpiPsGetNextNamestring (ParserState); + break; + + + default: + ACPI_REPORT_ERROR (("Invalid ArgType %X\n", ArgType)); break; } @@ -642,8 +639,8 @@ AcpiPsGetNextField ( ACPI_PARSE_STATE *ParserState) { - UINT32 AmlOffset = ParserState->Aml - - ParserState->AmlStart; + UINT32 AmlOffset = ACPI_PTR_DIFF (ParserState->Aml, + ParserState->AmlStart); ACPI_PARSE_OBJECT *Field; UINT16 Opcode; UINT32 Name; @@ -656,20 +653,17 @@ switch (ACPI_GET8 (ParserState->Aml)) { - default: Opcode = AML_INT_NAMEDFIELD_OP; break; - case 0x00: Opcode = AML_INT_RESERVEDFIELD_OP; ParserState->Aml++; break; - case 0x01: Opcode = AML_INT_ACCESSFIELD_OP; @@ -681,48 +675,54 @@ /* Allocate a new field op */ Field = AcpiPsAllocOp (Opcode); - if (Field) + if (!Field) { - Field->AmlOffset = AmlOffset; + return_PTR (NULL); + } - /* Decode the field type */ + Field->Common.AmlOffset = AmlOffset; - switch (Opcode) - { - case AML_INT_NAMEDFIELD_OP: + /* Decode the field type */ - /* Get the 4-character name */ + switch (Opcode) + { + case AML_INT_NAMEDFIELD_OP: + + /* Get the 4-character name */ + + ACPI_MOVE_UNALIGNED32_TO_32 (&Name, ParserState->Aml); + AcpiPsSetName (Field, Name); + ParserState->Aml += 4; - ACPI_MOVE_UNALIGNED32_TO_32 (&Name, ParserState->Aml); - AcpiPsSetName (Field, Name); - ParserState->Aml += 4; + /* Get the length which is encoded as a package length */ - /* Get the length which is encoded as a package length */ + Field->Common.Value.Size = AcpiPsGetNextPackageLength (ParserState); + break; - Field->Value.Size = AcpiPsGetNextPackageLength (ParserState); - break; + case AML_INT_RESERVEDFIELD_OP: - case AML_INT_RESERVEDFIELD_OP: + /* Get the length which is encoded as a package length */ - /* Get the length which is encoded as a package length */ + Field->Common.Value.Size = AcpiPsGetNextPackageLength (ParserState); + break; - Field->Value.Size = AcpiPsGetNextPackageLength (ParserState); - break; + case AML_INT_ACCESSFIELD_OP: - case AML_INT_ACCESSFIELD_OP: + /* + * Get AccessType and AccessAttrib and merge into the field Op + * AccessType is first operand, AccessAttribute is second + */ + Field->Common.Value.Integer32 = (ACPI_GET8 (ParserState->Aml) << 8); + ParserState->Aml++; + Field->Common.Value.Integer32 |= ACPI_GET8 (ParserState->Aml); + ParserState->Aml++; + break; - /* - * Get AccessType and AccessAttrib and merge into the field Op - * AccessType is first operand, AccessAttribute is second - */ - Field->Value.Integer32 = (ACPI_GET8 (ParserState->Aml) << 8); - ParserState->Aml++; - Field->Value.Integer32 |= ACPI_GET8 (ParserState->Aml); - ParserState->Aml++; - break; - } + default: + /* Opcode was set in previous switch */ + break; } return_PTR (Field); @@ -803,7 +803,7 @@ if (Prev) { - Prev->Next = Field; + Prev->Common.Next = Field; } else @@ -832,8 +832,8 @@ { /* fill in bytelist data */ - Arg->Value.Size = (ParserState->PkgEnd - ParserState->Aml); - ((ACPI_PARSE2_OBJECT *) Arg)->Data = ParserState->Aml; + Arg->Common.Value.Size = ACPI_PTR_DIFF (ParserState->PkgEnd, ParserState->Aml); + Arg->Named.Data = ParserState->Aml; } /* skip to End of byte data */ @@ -890,6 +890,10 @@ *ArgCount = ACPI_VAR_ARGS; } + break; + + default: + ACPI_REPORT_ERROR (("Invalid ArgType: %X\n", ArgType)); break; } Index: psfind.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/psfind.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 psfind.c --- psfind.c 23 Feb 2002 05:10:37 -0000 1.1.1.12 +++ psfind.c 1 Jul 2002 21:39:53 -0000 @@ -149,7 +149,7 @@ while (Parent) { - switch (Parent->Opcode) + switch (Parent->Common.AmlOpcode) { case AML_SCOPE_OP: case AML_PACKAGE_OP: @@ -158,10 +158,13 @@ case AML_POWER_RES_OP: case AML_THERMAL_ZONE_OP: - return (Parent->Parent); + return (Parent->Common.Parent); + + default: + break; } - Parent = Parent->Parent; + Parent = Parent->Common.Parent; } return (Parent); @@ -200,13 +203,13 @@ while (Op) { - OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); + OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); /* Check AML_CREATE first (since some opcodes have AML_FIELD set also )*/ if (OpInfo->Flags & AML_CREATE) { - if (Op->Opcode == AML_CREATE_FIELD_OP) + if (Op->Common.AmlOpcode == AML_CREATE_FIELD_OP) { Field = AcpiPsGetArg (Op, 3); } @@ -218,8 +221,8 @@ } if ((Field) && - (Field->Value.String) && - (!ACPI_STRNCMP (Field->Value.String, (char *) &Name, ACPI_NAME_SIZE))) + (Field->Common.Value.String) && + (!ACPI_STRNCMP (Field->Common.Value.String, (char *) &Name, ACPI_NAME_SIZE))) { return (Op); } @@ -231,26 +234,26 @@ Field = AcpiPsGetChild (Op); while (Field) { - OpInfo = AcpiPsGetOpcodeInfo (Field->Opcode); + OpInfo = AcpiPsGetOpcodeInfo (Field->Common.AmlOpcode); if ((OpInfo->Flags & AML_NAMED) && AcpiPsGetName (Field) == Name && - (!Opcode || Field->Opcode == Opcode)) + (!Opcode || Field->Common.AmlOpcode == Opcode)) { return (Field); } - Field = Field->Next; + Field = Field->Common.Next; } } else if ((OpInfo->Flags & AML_NAMED) && (AcpiPsGetName (Op) == Name) && - (!Opcode || Op->Opcode == Opcode || Opcode == AML_SCOPE_OP)) + (!Opcode || Op->Common.AmlOpcode == Opcode || Opcode == AML_SCOPE_OP)) { break; } - Op = Op->Next; + Op = Op->Common.Next; } return (Op); @@ -308,9 +311,9 @@ /* Could just use a global for "root scope" here */ - while (Scope->Parent) + while (Scope->Common.Parent) { - Scope = Scope->Parent; + Scope = Scope->Common.Parent; } break; @@ -324,6 +327,10 @@ Scope = AcpiPsGetParent (Scope); } break; + + default: + /* Should not get here */ + break; } Unprefixed = FALSE; @@ -369,7 +376,7 @@ } ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, - "Search scope %p Segs=%d Opcode=%4.4X Create=%d\n", + "Search scope %p Segs=%d Opcode=%4.4hX Create=%d\n", Scope, SegCount, Opcode, Create)); /* match each name segment */ @@ -393,8 +400,8 @@ if (Op) { ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, - "[%4.4s] Found! Op=%p Opcode=%4.4X\n", - (char *) &Name, Op, Op->Opcode)); + "[%4.4s] Found! Op=%p Opcode=%4.4hX\n", + (char *) &Name, Op, Op->Common.AmlOpcode)); } if (!Op) @@ -418,7 +425,7 @@ AcpiPsAppendArg (Scope, Op); ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, - "[%4.4s] Not found, created Op=%p Opcode=%4.4X\n", + "[%4.4s] Not found, created Op=%p Opcode=%4.4hX\n", (char *) &Name, Op, Opcode)); } } @@ -427,15 +434,15 @@ { /* Search higher scopes for unprefixed name */ - while (!Op && Scope->Parent) + while (!Op && Scope->Common.Parent) { - Scope = Scope->Parent; + Scope = Scope->Common.Parent; Op = AcpiPsFindName (Scope, Name, Opcode); if (Op) { ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, - "[%4.4s] Found in parent tree! Op=%p Opcode=%4.4X\n", - (char *) &Name, Op, Op->Opcode)); + "[%4.4s] Found in parent tree! Op=%p Opcode=%4.4hX\n", + (char *) &Name, Op, Op->Common.AmlOpcode)); } else { Index: psopcode.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/psopcode.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 psopcode.c --- psopcode.c 30 Jun 2002 17:50:44 -0000 1.1.1.13 +++ psopcode.c 1 Jul 2002 21:39:53 -0000 @@ -136,9 +136,9 @@ #define _UNKNOWN_OPCODE 0x02 /* An example unknown opcode */ #define MAX_EXTENDED_OPCODE 0x88 -#define NUM_EXTENDED_OPCODE MAX_EXTENDED_OPCODE + 1 +#define NUM_EXTENDED_OPCODE (MAX_EXTENDED_OPCODE + 1) #define MAX_INTERNAL_OPCODE -#define NUM_INTERNAL_OPCODE MAX_INTERNAL_OPCODE + 1 +#define NUM_INTERNAL_OPCODE (MAX_INTERNAL_OPCODE + 1) /******************************************************************************* @@ -539,22 +539,22 @@ */ -static const ACPI_OPCODE_INFO AcpiGbl_AmlOpInfo[] = +const ACPI_OPCODE_INFO AcpiGbl_AmlOpInfo[AML_NUM_OPCODES] = { /*! [Begin] no source code translation */ /* Index Name Parser Args Interpreter Args ObjectType Class Type Flags */ -/* 00 */ ACPI_OP ("Zero", ARGP_ZERO_OP, ARGI_ZERO_OP, INTERNAL_TYPE_REFERENCE, AML_CLASS_ARGUMENT, AML_TYPE_CONSTANT, 0), -/* 01 */ ACPI_OP ("One", ARGP_ONE_OP, ARGI_ONE_OP, INTERNAL_TYPE_REFERENCE, AML_CLASS_ARGUMENT, AML_TYPE_CONSTANT, 0), +/* 00 */ ACPI_OP ("Zero", ARGP_ZERO_OP, ARGI_ZERO_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_CONSTANT, AML_CONSTANT), +/* 01 */ ACPI_OP ("One", ARGP_ONE_OP, ARGI_ONE_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_CONSTANT, AML_CONSTANT), /* 02 */ ACPI_OP ("Alias", ARGP_ALIAS_OP, ARGI_ALIAS_OP, INTERNAL_TYPE_ALIAS, AML_CLASS_NAMED_OBJECT, AML_TYPE_NAMED_SIMPLE, AML_HAS_ARGS | AML_NSOBJECT | AML_NSOPCODE | AML_NSNODE | AML_NAMED), /* 03 */ ACPI_OP ("Name", ARGP_NAME_OP, ARGI_NAME_OP, ACPI_TYPE_ANY, AML_CLASS_NAMED_OBJECT, AML_TYPE_NAMED_COMPLEX, AML_HAS_ARGS | AML_NSOBJECT | AML_NSOPCODE | AML_NSNODE | AML_NAMED), -/* 04 */ ACPI_OP ("ByteConst", ARGP_BYTE_OP, ARGI_BYTE_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, 0), -/* 05 */ ACPI_OP ("WordConst", ARGP_WORD_OP, ARGI_WORD_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, 0), -/* 06 */ ACPI_OP ("DwordConst", ARGP_DWORD_OP, ARGI_DWORD_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, 0), -/* 07 */ ACPI_OP ("String", ARGP_STRING_OP, ARGI_STRING_OP, ACPI_TYPE_STRING, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, 0), +/* 04 */ ACPI_OP ("ByteConst", ARGP_BYTE_OP, ARGI_BYTE_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, AML_CONSTANT), +/* 05 */ ACPI_OP ("WordConst", ARGP_WORD_OP, ARGI_WORD_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, AML_CONSTANT), +/* 06 */ ACPI_OP ("DwordConst", ARGP_DWORD_OP, ARGI_DWORD_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, AML_CONSTANT), +/* 07 */ ACPI_OP ("String", ARGP_STRING_OP, ARGI_STRING_OP, ACPI_TYPE_STRING, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, AML_CONSTANT), /* 08 */ ACPI_OP ("Scope", ARGP_SCOPE_OP, ARGI_SCOPE_OP, INTERNAL_TYPE_SCOPE, AML_CLASS_NAMED_OBJECT, AML_TYPE_NAMED_NO_OBJ, AML_HAS_ARGS | AML_NSOBJECT | AML_NSOPCODE | AML_NSNODE | AML_NAMED), -/* 09 */ ACPI_OP ("Buffer", ARGP_BUFFER_OP, ARGI_BUFFER_OP, ACPI_TYPE_BUFFER, AML_CLASS_CREATE, AML_TYPE_CREATE_OBJECT, AML_HAS_ARGS | AML_DEFER), -/* 0A */ ACPI_OP ("Package", ARGP_PACKAGE_OP, ARGI_PACKAGE_OP, ACPI_TYPE_PACKAGE, AML_CLASS_CREATE, AML_TYPE_CREATE_OBJECT, AML_HAS_ARGS | AML_DEFER), +/* 09 */ ACPI_OP ("Buffer", ARGP_BUFFER_OP, ARGI_BUFFER_OP, ACPI_TYPE_BUFFER, AML_CLASS_CREATE, AML_TYPE_CREATE_OBJECT, AML_HAS_ARGS | AML_DEFER | AML_CONSTANT), +/* 0A */ ACPI_OP ("Package", ARGP_PACKAGE_OP, ARGI_PACKAGE_OP, ACPI_TYPE_PACKAGE, AML_CLASS_CREATE, AML_TYPE_CREATE_OBJECT, AML_HAS_ARGS | AML_DEFER | AML_CONSTANT), /* 0B */ ACPI_OP ("Method", ARGP_METHOD_OP, ARGI_METHOD_OP, ACPI_TYPE_METHOD, AML_CLASS_NAMED_OBJECT, AML_TYPE_NAMED_COMPLEX, AML_HAS_ARGS | AML_NSOBJECT | AML_NSOPCODE | AML_NSNODE | AML_NAMED | AML_DEFER), /* 0C */ ACPI_OP ("Local0", ARGP_LOCAL0, ARGI_LOCAL0, INTERNAL_TYPE_REFERENCE, AML_CLASS_ARGUMENT, AML_TYPE_LOCAL_VARIABLE, 0), /* 0D */ ACPI_OP ("Local1", ARGP_LOCAL1, ARGI_LOCAL1, INTERNAL_TYPE_REFERENCE, AML_CLASS_ARGUMENT, AML_TYPE_LOCAL_VARIABLE, 0), @@ -573,39 +573,39 @@ /* 1A */ ACPI_OP ("Arg6", ARGP_ARG6, ARGI_ARG6, INTERNAL_TYPE_REFERENCE, AML_CLASS_ARGUMENT, AML_TYPE_METHOD_ARGUMENT, 0), /* 1B */ ACPI_OP ("Store", ARGP_STORE_OP, ARGI_STORE_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), /* 1C */ ACPI_OP ("RefOf", ARGP_REF_OF_OP, ARGI_REF_OF_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_1R, AML_FLAGS_EXEC_1A_0T_1R), -/* 1D */ ACPI_OP ("Add", ARGP_ADD_OP, ARGI_ADD_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH), -/* 1E */ ACPI_OP ("Concatenate", ARGP_CONCAT_OP, ARGI_CONCAT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R), -/* 1F */ ACPI_OP ("Subtract", ARGP_SUBTRACT_OP, ARGI_SUBTRACT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH), -/* 20 */ ACPI_OP ("Increment", ARGP_INCREMENT_OP, ARGI_INCREMENT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_1R, AML_FLAGS_EXEC_1A_0T_1R), -/* 21 */ ACPI_OP ("Decrement", ARGP_DECREMENT_OP, ARGI_DECREMENT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_1R, AML_FLAGS_EXEC_1A_0T_1R), -/* 22 */ ACPI_OP ("Multiply", ARGP_MULTIPLY_OP, ARGI_MULTIPLY_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH), -/* 23 */ ACPI_OP ("Divide", ARGP_DIVIDE_OP, ARGI_DIVIDE_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_2T_1R, AML_FLAGS_EXEC_2A_2T_1R), -/* 24 */ ACPI_OP ("ShiftLeft", ARGP_SHIFT_LEFT_OP, ARGI_SHIFT_LEFT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH), -/* 25 */ ACPI_OP ("ShiftRight", ARGP_SHIFT_RIGHT_OP, ARGI_SHIFT_RIGHT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH), -/* 26 */ ACPI_OP ("And", ARGP_BIT_AND_OP, ARGI_BIT_AND_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH), -/* 27 */ ACPI_OP ("NAnd", ARGP_BIT_NAND_OP, ARGI_BIT_NAND_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH), -/* 28 */ ACPI_OP ("Or", ARGP_BIT_OR_OP, ARGI_BIT_OR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH), -/* 29 */ ACPI_OP ("NOr", ARGP_BIT_NOR_OP, ARGI_BIT_NOR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH), -/* 2A */ ACPI_OP ("XOr", ARGP_BIT_XOR_OP, ARGI_BIT_XOR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH), -/* 2B */ ACPI_OP ("Not", ARGP_BIT_NOT_OP, ARGI_BIT_NOT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), -/* 2C */ ACPI_OP ("FindSetLeftBit", ARGP_FIND_SET_LEFT_BIT_OP, ARGI_FIND_SET_LEFT_BIT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), -/* 2D */ ACPI_OP ("FindSetRightBit", ARGP_FIND_SET_RIGHT_BIT_OP,ARGI_FIND_SET_RIGHT_BIT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), +/* 1D */ ACPI_OP ("Add", ARGP_ADD_OP, ARGI_ADD_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH | AML_CONSTANT), +/* 1E */ ACPI_OP ("Concatenate", ARGP_CONCAT_OP, ARGI_CONCAT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_CONSTANT), +/* 1F */ ACPI_OP ("Subtract", ARGP_SUBTRACT_OP, ARGI_SUBTRACT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH | AML_CONSTANT), +/* 20 */ ACPI_OP ("Increment", ARGP_INCREMENT_OP, ARGI_INCREMENT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_1R, AML_FLAGS_EXEC_1A_0T_1R | AML_CONSTANT), +/* 21 */ ACPI_OP ("Decrement", ARGP_DECREMENT_OP, ARGI_DECREMENT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_1R, AML_FLAGS_EXEC_1A_0T_1R | AML_CONSTANT), +/* 22 */ ACPI_OP ("Multiply", ARGP_MULTIPLY_OP, ARGI_MULTIPLY_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH | AML_CONSTANT), +/* 23 */ ACPI_OP ("Divide", ARGP_DIVIDE_OP, ARGI_DIVIDE_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_2T_1R, AML_FLAGS_EXEC_2A_2T_1R | AML_CONSTANT), +/* 24 */ ACPI_OP ("ShiftLeft", ARGP_SHIFT_LEFT_OP, ARGI_SHIFT_LEFT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH | AML_CONSTANT), +/* 25 */ ACPI_OP ("ShiftRight", ARGP_SHIFT_RIGHT_OP, ARGI_SHIFT_RIGHT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH | AML_CONSTANT), +/* 26 */ ACPI_OP ("And", ARGP_BIT_AND_OP, ARGI_BIT_AND_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH | AML_CONSTANT), +/* 27 */ ACPI_OP ("NAnd", ARGP_BIT_NAND_OP, ARGI_BIT_NAND_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH | AML_CONSTANT), +/* 28 */ ACPI_OP ("Or", ARGP_BIT_OR_OP, ARGI_BIT_OR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH | AML_CONSTANT), +/* 29 */ ACPI_OP ("NOr", ARGP_BIT_NOR_OP, ARGI_BIT_NOR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH | AML_CONSTANT), +/* 2A */ ACPI_OP ("XOr", ARGP_BIT_XOR_OP, ARGI_BIT_XOR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_MATH | AML_CONSTANT), +/* 2B */ ACPI_OP ("Not", ARGP_BIT_NOT_OP, ARGI_BIT_NOT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R | AML_CONSTANT), +/* 2C */ ACPI_OP ("FindSetLeftBit", ARGP_FIND_SET_LEFT_BIT_OP, ARGI_FIND_SET_LEFT_BIT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R | AML_CONSTANT), +/* 2D */ ACPI_OP ("FindSetRightBit", ARGP_FIND_SET_RIGHT_BIT_OP,ARGI_FIND_SET_RIGHT_BIT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R | AML_CONSTANT), /* 2E */ ACPI_OP ("DerefOf", ARGP_DEREF_OF_OP, ARGI_DEREF_OF_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_1R, AML_FLAGS_EXEC_1A_0T_1R), /* 2F */ ACPI_OP ("Notify", ARGP_NOTIFY_OP, ARGI_NOTIFY_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_0R, AML_FLAGS_EXEC_2A_0T_0R), /* 30 */ ACPI_OP ("SizeOf", ARGP_SIZE_OF_OP, ARGI_SIZE_OF_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_1R, AML_FLAGS_EXEC_1A_0T_1R), -/* 31 */ ACPI_OP ("Index", ARGP_INDEX_OP, ARGI_INDEX_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R), -/* 32 */ ACPI_OP ("Match", ARGP_MATCH_OP, ARGI_MATCH_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_6A_0T_1R, AML_FLAGS_EXEC_6A_0T_1R), +/* 31 */ ACPI_OP ("Index", ARGP_INDEX_OP, ARGI_INDEX_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_CONSTANT), +/* 32 */ ACPI_OP ("Match", ARGP_MATCH_OP, ARGI_MATCH_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_6A_0T_1R, AML_FLAGS_EXEC_6A_0T_1R | AML_CONSTANT), /* 33 */ ACPI_OP ("CreateDWordField", ARGP_CREATE_DWORD_FIELD_OP,ARGI_CREATE_DWORD_FIELD_OP, ACPI_TYPE_BUFFER_FIELD, AML_CLASS_CREATE, AML_TYPE_CREATE_FIELD, AML_HAS_ARGS | AML_NSOBJECT | AML_NSNODE | AML_DEFER | AML_CREATE), /* 34 */ ACPI_OP ("CreateWordField", ARGP_CREATE_WORD_FIELD_OP, ARGI_CREATE_WORD_FIELD_OP, ACPI_TYPE_BUFFER_FIELD, AML_CLASS_CREATE, AML_TYPE_CREATE_FIELD, AML_HAS_ARGS | AML_NSOBJECT | AML_NSNODE | AML_DEFER | AML_CREATE), /* 35 */ ACPI_OP ("CreateByteField", ARGP_CREATE_BYTE_FIELD_OP, ARGI_CREATE_BYTE_FIELD_OP, ACPI_TYPE_BUFFER_FIELD, AML_CLASS_CREATE, AML_TYPE_CREATE_FIELD, AML_HAS_ARGS | AML_NSOBJECT | AML_NSNODE | AML_DEFER | AML_CREATE), /* 36 */ ACPI_OP ("CreateBitField", ARGP_CREATE_BIT_FIELD_OP, ARGI_CREATE_BIT_FIELD_OP, ACPI_TYPE_BUFFER_FIELD, AML_CLASS_CREATE, AML_TYPE_CREATE_FIELD, AML_HAS_ARGS | AML_NSOBJECT | AML_NSNODE | AML_DEFER | AML_CREATE), /* 37 */ ACPI_OP ("ObjectType", ARGP_TYPE_OP, ARGI_TYPE_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_1R, AML_FLAGS_EXEC_1A_0T_1R), -/* 38 */ ACPI_OP ("LAnd", ARGP_LAND_OP, ARGI_LAND_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R | AML_LOGICAL), -/* 39 */ ACPI_OP ("LOr", ARGP_LOR_OP, ARGI_LOR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R | AML_LOGICAL), -/* 3A */ ACPI_OP ("LNot", ARGP_LNOT_OP, ARGI_LNOT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_1R, AML_FLAGS_EXEC_1A_0T_1R), -/* 3B */ ACPI_OP ("LEqual", ARGP_LEQUAL_OP, ARGI_LEQUAL_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R | AML_LOGICAL), -/* 3C */ ACPI_OP ("LGreater", ARGP_LGREATER_OP, ARGI_LGREATER_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R | AML_LOGICAL), -/* 3D */ ACPI_OP ("LLess", ARGP_LLESS_OP, ARGI_LLESS_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R | AML_LOGICAL), +/* 38 */ ACPI_OP ("LAnd", ARGP_LAND_OP, ARGI_LAND_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R | AML_LOGICAL | AML_CONSTANT), +/* 39 */ ACPI_OP ("LOr", ARGP_LOR_OP, ARGI_LOR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R | AML_LOGICAL | AML_CONSTANT), +/* 3A */ ACPI_OP ("LNot", ARGP_LNOT_OP, ARGI_LNOT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_1R, AML_FLAGS_EXEC_1A_0T_1R | AML_CONSTANT), +/* 3B */ ACPI_OP ("LEqual", ARGP_LEQUAL_OP, ARGI_LEQUAL_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R | AML_LOGICAL | AML_CONSTANT), +/* 3C */ ACPI_OP ("LGreater", ARGP_LGREATER_OP, ARGI_LGREATER_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R | AML_LOGICAL | AML_CONSTANT), +/* 3D */ ACPI_OP ("LLess", ARGP_LLESS_OP, ARGI_LLESS_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R | AML_LOGICAL | AML_CONSTANT), /* 3E */ ACPI_OP ("If", ARGP_IF_OP, ARGI_IF_OP, ACPI_TYPE_ANY, AML_CLASS_CONTROL, AML_TYPE_CONTROL, AML_HAS_ARGS), /* 3F */ ACPI_OP ("Else", ARGP_ELSE_OP, ARGI_ELSE_OP, ACPI_TYPE_ANY, AML_CLASS_CONTROL, AML_TYPE_CONTROL, AML_HAS_ARGS), /* 40 */ ACPI_OP ("While", ARGP_WHILE_OP, ARGI_WHILE_OP, ACPI_TYPE_ANY, AML_CLASS_CONTROL, AML_TYPE_CONTROL, AML_HAS_ARGS), @@ -613,7 +613,7 @@ /* 42 */ ACPI_OP ("Return", ARGP_RETURN_OP, ARGI_RETURN_OP, ACPI_TYPE_ANY, AML_CLASS_CONTROL, AML_TYPE_CONTROL, AML_HAS_ARGS), /* 43 */ ACPI_OP ("Break", ARGP_BREAK_OP, ARGI_BREAK_OP, ACPI_TYPE_ANY, AML_CLASS_CONTROL, AML_TYPE_CONTROL, 0), /* 44 */ ACPI_OP ("BreakPoint", ARGP_BREAK_POINT_OP, ARGI_BREAK_POINT_OP, ACPI_TYPE_ANY, AML_CLASS_CONTROL, AML_TYPE_CONTROL, 0), -/* 45 */ ACPI_OP ("Ones", ARGP_ONES_OP, ARGI_ONES_OP, INTERNAL_TYPE_REFERENCE, AML_CLASS_ARGUMENT, AML_TYPE_CONSTANT, 0), +/* 45 */ ACPI_OP ("Ones", ARGP_ONES_OP, ARGI_ONES_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_CONSTANT, AML_CONSTANT), /* Prefixed opcodes (Two-byte opcodes with a prefix op) */ @@ -629,10 +629,10 @@ /* 4F */ ACPI_OP ("Wait", ARGP_WAIT_OP, ARGI_WAIT_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_0T_1R, AML_FLAGS_EXEC_2A_0T_1R), /* 50 */ ACPI_OP ("Reset", ARGP_RESET_OP, ARGI_RESET_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_0R, AML_FLAGS_EXEC_1A_0T_0R), /* 51 */ ACPI_OP ("Release", ARGP_RELEASE_OP, ARGI_RELEASE_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_0R, AML_FLAGS_EXEC_1A_0T_0R), -/* 52 */ ACPI_OP ("FromBCD", ARGP_FROM_BCD_OP, ARGI_FROM_BCD_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), -/* 53 */ ACPI_OP ("ToBCD", ARGP_TO_BCD_OP, ARGI_TO_BCD_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), +/* 52 */ ACPI_OP ("FromBCD", ARGP_FROM_BCD_OP, ARGI_FROM_BCD_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R | AML_CONSTANT), +/* 53 */ ACPI_OP ("ToBCD", ARGP_TO_BCD_OP, ARGI_TO_BCD_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R | AML_CONSTANT), /* 54 */ ACPI_OP ("Unload", ARGP_UNLOAD_OP, ARGI_UNLOAD_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_0T_0R, AML_FLAGS_EXEC_1A_0T_0R), -/* 55 */ ACPI_OP ("Revision", ARGP_REVISION_OP, ARGI_REVISION_OP, INTERNAL_TYPE_REFERENCE, AML_CLASS_ARGUMENT, AML_TYPE_CONSTANT, 0), +/* 55 */ ACPI_OP ("Revision", ARGP_REVISION_OP, ARGI_REVISION_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_CONSTANT, 0), /* 56 */ ACPI_OP ("Debug", ARGP_DEBUG_OP, ARGI_DEBUG_OP, INTERNAL_TYPE_REFERENCE, AML_CLASS_ARGUMENT, AML_TYPE_CONSTANT, 0), /* 57 */ ACPI_OP ("Fatal", ARGP_FATAL_OP, ARGI_FATAL_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_3A_0T_0R, AML_FLAGS_EXEC_3A_0T_0R), /* 58 */ ACPI_OP ("OperationRegion", ARGP_REGION_OP, ARGI_REGION_OP, ACPI_TYPE_REGION, AML_CLASS_NAMED_OBJECT, AML_TYPE_NAMED_COMPLEX, AML_HAS_ARGS | AML_NSOBJECT | AML_NSOPCODE | AML_NSNODE | AML_NAMED | AML_DEFER), @@ -646,9 +646,9 @@ /* Internal opcodes that map to invalid AML opcodes */ -/* 60 */ ACPI_OP ("LNotEqual", ARGP_LNOTEQUAL_OP, ARGI_LNOTEQUAL_OP, ACPI_TYPE_ANY, AML_CLASS_INTERNAL, AML_TYPE_BOGUS, AML_HAS_ARGS), -/* 61 */ ACPI_OP ("LLessEqual", ARGP_LLESSEQUAL_OP, ARGI_LLESSEQUAL_OP, ACPI_TYPE_ANY, AML_CLASS_INTERNAL, AML_TYPE_BOGUS, AML_HAS_ARGS), -/* 62 */ ACPI_OP ("LGreaterEqual", ARGP_LGREATEREQUAL_OP, ARGI_LGREATEREQUAL_OP, ACPI_TYPE_ANY, AML_CLASS_INTERNAL, AML_TYPE_BOGUS, AML_HAS_ARGS), +/* 60 */ ACPI_OP ("LNotEqual", ARGP_LNOTEQUAL_OP, ARGI_LNOTEQUAL_OP, ACPI_TYPE_ANY, AML_CLASS_INTERNAL, AML_TYPE_BOGUS, AML_HAS_ARGS | AML_CONSTANT), +/* 61 */ ACPI_OP ("LLessEqual", ARGP_LLESSEQUAL_OP, ARGI_LLESSEQUAL_OP, ACPI_TYPE_ANY, AML_CLASS_INTERNAL, AML_TYPE_BOGUS, AML_HAS_ARGS | AML_CONSTANT), +/* 62 */ ACPI_OP ("LGreaterEqual", ARGP_LGREATEREQUAL_OP, ARGI_LGREATEREQUAL_OP, ACPI_TYPE_ANY, AML_CLASS_INTERNAL, AML_TYPE_BOGUS, AML_HAS_ARGS | AML_CONSTANT), /* 63 */ ACPI_OP ("[NamePath]", ARGP_NAMEPATH_OP, ARGI_NAMEPATH_OP, INTERNAL_TYPE_REFERENCE, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, AML_NSOBJECT | AML_NSNODE ), /* 64 */ ACPI_OP ("[MethodCall]", ARGP_METHODCALL_OP, ARGI_METHODCALL_OP, ACPI_TYPE_METHOD, AML_CLASS_METHOD_CALL, AML_TYPE_METHOD_CALL, AML_HAS_ARGS | AML_NSOBJECT | AML_NSNODE), /* 65 */ ACPI_OP ("[ByteList]", ARGP_BYTELIST_OP, ARGI_BYTELIST_OP, ACPI_TYPE_ANY, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, 0), @@ -664,18 +664,18 @@ /* ACPI 2.0 opcodes */ -/* 6E */ ACPI_OP ("QwordConst", ARGP_QWORD_OP, ARGI_QWORD_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, 0), +/* 6E */ ACPI_OP ("QwordConst", ARGP_QWORD_OP, ARGI_QWORD_OP, ACPI_TYPE_INTEGER, AML_CLASS_ARGUMENT, AML_TYPE_LITERAL, AML_CONSTANT), /* 6F */ ACPI_OP ("Package /*Var*/", ARGP_VAR_PACKAGE_OP, ARGI_VAR_PACKAGE_OP, ACPI_TYPE_PACKAGE, AML_CLASS_CREATE, AML_TYPE_CREATE_OBJECT, AML_HAS_ARGS | AML_DEFER), -/* 70 */ ACPI_OP ("ConcatenateResTemplate", ARGP_CONCAT_RES_OP, ARGI_CONCAT_RES_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R), -/* 71 */ ACPI_OP ("Mod", ARGP_MOD_OP, ARGI_MOD_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R), +/* 70 */ ACPI_OP ("ConcatenateResTemplate", ARGP_CONCAT_RES_OP, ARGI_CONCAT_RES_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_CONSTANT), +/* 71 */ ACPI_OP ("Mod", ARGP_MOD_OP, ARGI_MOD_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_CONSTANT), /* 72 */ ACPI_OP ("CreateQWordField", ARGP_CREATE_QWORD_FIELD_OP,ARGI_CREATE_QWORD_FIELD_OP, ACPI_TYPE_BUFFER_FIELD, AML_CLASS_CREATE, AML_TYPE_CREATE_FIELD, AML_HAS_ARGS | AML_NSOBJECT | AML_NSNODE | AML_DEFER | AML_CREATE), -/* 73 */ ACPI_OP ("ToBuffer", ARGP_TO_BUFFER_OP, ARGI_TO_BUFFER_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), -/* 74 */ ACPI_OP ("ToDecimalString", ARGP_TO_DEC_STR_OP, ARGI_TO_DEC_STR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), -/* 75 */ ACPI_OP ("ToHexString", ARGP_TO_HEX_STR_OP, ARGI_TO_HEX_STR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), -/* 76 */ ACPI_OP ("ToInteger", ARGP_TO_INTEGER_OP, ARGI_TO_INTEGER_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), -/* 77 */ ACPI_OP ("ToString", ARGP_TO_STRING_OP, ARGI_TO_STRING_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R), +/* 73 */ ACPI_OP ("ToBuffer", ARGP_TO_BUFFER_OP, ARGI_TO_BUFFER_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R | AML_CONSTANT), +/* 74 */ ACPI_OP ("ToDecimalString", ARGP_TO_DEC_STR_OP, ARGI_TO_DEC_STR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R | AML_CONSTANT), +/* 75 */ ACPI_OP ("ToHexString", ARGP_TO_HEX_STR_OP, ARGI_TO_HEX_STR_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R | AML_CONSTANT), +/* 76 */ ACPI_OP ("ToInteger", ARGP_TO_INTEGER_OP, ARGI_TO_INTEGER_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R | AML_CONSTANT), +/* 77 */ ACPI_OP ("ToString", ARGP_TO_STRING_OP, ARGI_TO_STRING_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_2A_1T_1R, AML_FLAGS_EXEC_2A_1T_1R | AML_CONSTANT), /* 78 */ ACPI_OP ("CopyObject", ARGP_COPY_OP, ARGI_COPY_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_1A_1T_1R, AML_FLAGS_EXEC_1A_1T_1R), -/* 79 */ ACPI_OP ("Mid", ARGP_MID_OP, ARGI_MID_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_3A_1T_1R, AML_FLAGS_EXEC_3A_1T_1R), +/* 79 */ ACPI_OP ("Mid", ARGP_MID_OP, ARGI_MID_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_3A_1T_1R, AML_FLAGS_EXEC_3A_1T_1R | AML_CONSTANT), /* 7A */ ACPI_OP ("Continue", ARGP_CONTINUE_OP, ARGI_CONTINUE_OP, ACPI_TYPE_ANY, AML_CLASS_CONTROL, AML_TYPE_CONTROL, 0), /* 7B */ ACPI_OP ("LoadTable", ARGP_LOAD_TABLE_OP, ARGI_LOAD_TABLE_OP, ACPI_TYPE_ANY, AML_CLASS_EXECUTE, AML_TYPE_EXEC_6A_0T_1R, AML_FLAGS_EXEC_6A_0T_1R), /* 7C */ ACPI_OP ("DataTableRegion", ARGP_DATA_REGION_OP, ARGI_DATA_REGION_OP, ACPI_TYPE_REGION, AML_CLASS_NAMED_OBJECT, AML_TYPE_NAMED_SIMPLE, AML_HAS_ARGS | AML_NSOBJECT | AML_NSOPCODE | AML_NSNODE | AML_NAMED), @@ -795,6 +795,7 @@ } /* Else fall through to error case below */ + /*lint -fallthrough */ default: @@ -842,5 +843,4 @@ #endif } - Index: psparse.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/psparse.c,v retrieving revision 1.15 diff -u -r1.15 psparse.c --- psparse.c 30 Jun 2002 17:53:04 -0000 1.15 +++ psparse.c 1 Jul 2002 21:39:53 -0000 @@ -129,15 +129,13 @@ #include "acdispat.h" #include "amlcode.h" #include "acnamesp.h" -#include "acdebug.h" #include "acinterp.h" #define _COMPONENT ACPI_PARSER ACPI_MODULE_NAME ("psparse") -UINT32 AcpiGbl_Depth = 0; -extern UINT32 AcpiGbl_ScopeDepth; +static UINT32 AcpiGbl_Depth = 0; /******************************************************************************* @@ -267,13 +265,13 @@ * PARAMETERS: WalkState - Current State * Op - Op to complete * - * RETURN: TRUE if Op and subtree was deleted + * RETURN: None. * * DESCRIPTION: Perform any cleanup at the completion of an Op. * ******************************************************************************/ -BOOLEAN +void AcpiPsCompleteThisOp ( ACPI_WALK_STATE *WalkState, ACPI_PARSE_OBJECT *Op) @@ -292,7 +290,7 @@ if (!Op) { - return_VALUE (TRUE); + return_VOID; } /* Delete this op and the subtree below it if asked to */ @@ -302,13 +300,13 @@ { /* Make sure that we only delete this subtree */ - if (Op->Parent) + if (Op->Common.Parent) { /* * Check if we need to replace the operator and its subtree * with a return value op (placeholder op) */ - ParentInfo = AcpiPsGetOpcodeInfo (Op->Parent->Opcode); + ParentInfo = AcpiPsGetOpcodeInfo (Op->Common.Parent->Common.AmlOpcode); switch (ParentInfo->Class) { @@ -324,7 +322,7 @@ ReplacementOp = AcpiPsAllocOp (AML_INT_RETURN_VALUE_OP); if (!ReplacementOp) { - return_VALUE (FALSE); + return_VOID; } break; @@ -334,37 +332,35 @@ * These opcodes contain TermArg operands. The current * op must be replaced by a placeholder return op */ - if ((Op->Parent->Opcode == AML_REGION_OP) || - (Op->Parent->Opcode == AML_DATA_REGION_OP) || - (Op->Parent->Opcode == AML_BUFFER_OP) || - (Op->Parent->Opcode == AML_PACKAGE_OP) || - (Op->Parent->Opcode == AML_VAR_PACKAGE_OP)) + if ((Op->Common.Parent->Common.AmlOpcode == AML_REGION_OP) || + (Op->Common.Parent->Common.AmlOpcode == AML_DATA_REGION_OP) || + (Op->Common.Parent->Common.AmlOpcode == AML_BUFFER_OP) || + (Op->Common.Parent->Common.AmlOpcode == AML_PACKAGE_OP) || + (Op->Common.Parent->Common.AmlOpcode == AML_VAR_PACKAGE_OP)) { ReplacementOp = AcpiPsAllocOp (AML_INT_RETURN_VALUE_OP); if (!ReplacementOp) { - return_VALUE (FALSE); + return_VOID; } } - if ((Op->Parent->Opcode == AML_NAME_OP) && + if ((Op->Common.Parent->Common.AmlOpcode == AML_NAME_OP) && (WalkState->DescendingCallback != AcpiDsExecBeginOp)) { - if ((Op->Opcode == AML_BUFFER_OP) || - (Op->Opcode == AML_PACKAGE_OP) || - (Op->Opcode == AML_VAR_PACKAGE_OP)) + if ((Op->Common.AmlOpcode == AML_BUFFER_OP) || + (Op->Common.AmlOpcode == AML_PACKAGE_OP) || + (Op->Common.AmlOpcode == AML_VAR_PACKAGE_OP)) { - ReplacementOp = AcpiPsAllocOp (Op->Opcode); + ReplacementOp = AcpiPsAllocOp (Op->Common.AmlOpcode); if (!ReplacementOp) { - return_VALUE (FALSE); + return_VOID; } - ((ACPI_PARSE2_OBJECT *) ReplacementOp)->Data = - ((ACPI_PARSE2_OBJECT *) Op)->Data; - ((ACPI_PARSE2_OBJECT *) ReplacementOp)->Length = - ((ACPI_PARSE2_OBJECT *) Op)->Length; + ReplacementOp->Named.Data = Op->Named.Data; + ReplacementOp->Named.Length = Op->Named.Length; } } break; @@ -373,28 +369,28 @@ ReplacementOp = AcpiPsAllocOp (AML_INT_RETURN_VALUE_OP); if (!ReplacementOp) { - return_VALUE (FALSE); + return_VOID; } } /* We must unlink this op from the parent tree */ - Prev = Op->Parent->Value.Arg; + Prev = Op->Common.Parent->Common.Value.Arg; if (Prev == Op) { /* This op is the first in the list */ if (ReplacementOp) { - ReplacementOp->Parent = Op->Parent; - ReplacementOp->Value.Arg = NULL; - ReplacementOp->Node = Op->Node; - Op->Parent->Value.Arg = ReplacementOp; - ReplacementOp->Next = Op->Next; + ReplacementOp->Common.Parent = Op->Common.Parent; + ReplacementOp->Common.Value.Arg = NULL; + ReplacementOp->Common.Node = Op->Common.Node; + Op->Common.Parent->Common.Value.Arg = ReplacementOp; + ReplacementOp->Common.Next = Op->Common.Next; } else { - Op->Parent->Value.Arg = Op->Next; + Op->Common.Parent->Common.Value.Arg = Op->Common.Next; } } @@ -404,21 +400,21 @@ { /* Traverse all siblings in the parent's argument list */ - Next = Prev->Next; + Next = Prev->Common.Next; if (Next == Op) { if (ReplacementOp) { - ReplacementOp->Parent = Op->Parent; - ReplacementOp->Value.Arg = NULL; - ReplacementOp->Node = Op->Node; - Prev->Next = ReplacementOp; - ReplacementOp->Next = Op->Next; + ReplacementOp->Common.Parent = Op->Common.Parent; + ReplacementOp->Common.Value.Arg = NULL; + ReplacementOp->Common.Node = Op->Common.Node; + Prev->Common.Next = ReplacementOp; + ReplacementOp->Common.Next = Op->Common.Next; Next = NULL; } else { - Prev->Next = Op->Next; + Prev->Common.Next = Op->Common.Next; Next = NULL; } } @@ -431,13 +427,13 @@ AcpiPsDeleteParseTree (Op); - return_VALUE (TRUE); + return_VOID; } - return_VALUE (FALSE); + return_VOID; #else - return (FALSE); + return; #endif } @@ -537,7 +533,7 @@ Status = AE_CTRL_TRANSFER; WalkState->PrevOp = Op; WalkState->MethodCallOp = Op; - WalkState->MethodCallNode = (Op->Value.Arg)->Node; + WalkState->MethodCallNode = (Op->Common.Value.Arg)->Common.Node; /* Will return value (if any) be used by the caller? */ @@ -585,6 +581,11 @@ ACPI_FUNCTION_TRACE_PTR ("PsParseLoop", WalkState); + if (WalkState->DescendingCallback == NULL) + { + return_ACPI_STATUS (AE_BAD_PARAMETER); + } + ParserState = &WalkState->ParserState; WalkState->ArgTypes = 0; @@ -601,8 +602,8 @@ * was just completed */ if ((ParserState->Scope->ParseScope.Op) && - ((ParserState->Scope->ParseScope.Op->Opcode == AML_IF_OP) || - (ParserState->Scope->ParseScope.Op->Opcode == AML_WHILE_OP)) && + ((ParserState->Scope->ParseScope.Op->Common.AmlOpcode == AML_IF_OP) || + (ParserState->Scope->ParseScope.Op->Common.AmlOpcode == AML_WHILE_OP)) && (WalkState->ControlState) && (WalkState->ControlState->Common.State == ACPI_CONTROL_PREDICATE_EXECUTING)) @@ -649,13 +650,13 @@ */ while ((ParserState->Aml < ParserState->AmlEnd) || (Op)) { + AmlOpStart = ParserState->Aml; if (!Op) { /* Get the next opcode from the AML stream */ - AmlOpStart = ParserState->Aml; - WalkState->AmlOffset = ParserState->Aml - ParserState->AmlStart; - WalkState->Opcode = AcpiPsPeekOpcode (ParserState); + WalkState->AmlOffset = ACPI_PTR_DIFF (ParserState->Aml, ParserState->AmlStart); + WalkState->Opcode = AcpiPsPeekOpcode (ParserState); /* * First cut to determine what we have found: @@ -704,8 +705,8 @@ if (WalkState->OpInfo->Flags & AML_NAMED) { - PreOp.Value.Arg = NULL; - PreOp.Opcode = WalkState->Opcode; + PreOp.Common.Value.Arg = NULL; + PreOp.Common.AmlOpcode = WalkState->Opcode; while (GET_CURRENT_ARG_TYPE (WalkState->ArgTypes) != ARGP_NAME) { @@ -720,44 +721,41 @@ INCREMENT_ARG_LIST (WalkState->ArgTypes); - if (WalkState->DescendingCallback != NULL) - { - /* - * Find the object. This will either insert the object into - * the namespace or simply look it up - */ - WalkState->Op = NULL; + /* + * Find the object. This will either insert the object into + * the namespace or simply look it up + */ + WalkState->Op = NULL; - Status = WalkState->DescendingCallback (WalkState, &Op); - if (ACPI_FAILURE (Status)) - { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "During name lookup/catalog, %s\n", - AcpiFormatException (Status))); - goto CloseThisOp; - } + Status = WalkState->DescendingCallback (WalkState, &Op); + if (ACPI_FAILURE (Status)) + { + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "During name lookup/catalog, %s\n", + AcpiFormatException (Status))); + goto CloseThisOp; + } - if (Op == NULL) - { - continue; - } + if (Op == NULL) + { + continue; + } - Status = AcpiPsNextParseState (WalkState, Op, Status); - if (Status == AE_CTRL_PENDING) - { - Status = AE_OK; - goto CloseThisOp; - } + Status = AcpiPsNextParseState (WalkState, Op, Status); + if (Status == AE_CTRL_PENDING) + { + Status = AE_OK; + goto CloseThisOp; + } - if (ACPI_FAILURE (Status)) - { - goto CloseThisOp; - } + if (ACPI_FAILURE (Status)) + { + goto CloseThisOp; } - AcpiPsAppendArg (Op, PreOp.Value.Arg); + AcpiPsAppendArg (Op, PreOp.Common.Value.Arg); AcpiGbl_Depth++; - if (Op->Opcode == AML_REGION_OP) + if (Op->Common.AmlOpcode == AML_REGION_OP) { /* * Defer final parsing of an OperationRegion body, @@ -771,8 +769,8 @@ * * (Length is unknown until parse of the body complete) */ - ((ACPI_PARSE2_OBJECT * ) Op)->Data = AmlOpStart; - ((ACPI_PARSE2_OBJECT * ) Op)->Length = 0; + Op->Named.Data = AmlOpStart; + Op->Named.Length = 0; } } else @@ -792,8 +790,8 @@ * Backup to beginning of CreateXXXfield declaration * BodyLength is unknown until we parse the body */ - ((ACPI_PARSE2_OBJECT * ) Op)->Data = AmlOpStart; - ((ACPI_PARSE2_OBJECT * ) Op)->Length = 0; + Op->Named.Data = AmlOpStart; + Op->Named.Length = 0; } AcpiPsAppendArg (AcpiPsGetParentScope (ParserState), Op); @@ -821,13 +819,14 @@ } } - Op->AmlOffset = WalkState->AmlOffset; + Op->Common.AmlOffset = WalkState->AmlOffset; if (WalkState->OpInfo) { ACPI_DEBUG_PRINT ((ACPI_DB_PARSE, - "Opcode %4.4X [%s] Op %p Aml %p AmlOffset %5.5X\n", - Op->Opcode, WalkState->OpInfo->Name, Op, ParserState->Aml, Op->AmlOffset)); + "Opcode %4.4hX [%s] Op %p Aml %p AmlOffset %5.5X\n", + Op->Common.AmlOpcode, WalkState->OpInfo->Name, + Op, ParserState->Aml, Op->Common.AmlOffset)); } } @@ -840,7 +839,7 @@ { /* Get arguments */ - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_BYTE_OP: /* AML_BYTEDATA_ARG */ case AML_WORD_OP: /* AML_WORDDATA_ARG */ @@ -867,20 +866,21 @@ while (GET_CURRENT_ARG_TYPE (WalkState->ArgTypes) && !WalkState->ArgCount) { - WalkState->AmlOffset = ParserState->Aml - ParserState->AmlStart; + WalkState->AmlOffset = ACPI_PTR_DIFF (ParserState->Aml, + ParserState->AmlStart); Arg = AcpiPsGetNextArg (ParserState, GET_CURRENT_ARG_TYPE (WalkState->ArgTypes), &WalkState->ArgCount); if (Arg) { - Arg->AmlOffset = WalkState->AmlOffset; + Arg->Common.AmlOffset = WalkState->AmlOffset; AcpiPsAppendArg (Op, Arg); } INCREMENT_ARG_LIST (WalkState->ArgTypes); } - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_METHOD_OP: @@ -891,9 +891,8 @@ * because we don't have enough info in the first pass * to parse them correctly. */ - ((ACPI_PARSE2_OBJECT * ) Op)->Data = ParserState->Aml; - ((ACPI_PARSE2_OBJECT * ) Op)->Length = (UINT32) (ParserState->PkgEnd - - ParserState->Aml); + Op->Named.Data = ParserState->Aml; + Op->Named.Length = (UINT32) (ParserState->PkgEnd - ParserState->Aml); /* * Skip body of method. For OpRegions, we must continue * parsing because the opregion is not a standalone @@ -907,8 +906,8 @@ case AML_PACKAGE_OP: case AML_VAR_PACKAGE_OP: - if ((Op->Parent) && - (Op->Parent->Opcode == AML_NAME_OP) && + if ((Op->Common.Parent) && + (Op->Common.Parent->Common.AmlOpcode == AML_NAME_OP) && (WalkState->DescendingCallback != AcpiDsExecBeginOp)) { /* @@ -916,9 +915,8 @@ * because we don't have enough info in the first pass * to parse them correctly. */ - ((ACPI_PARSE2_OBJECT * ) Op)->Data = AmlOpStart; - ((ACPI_PARSE2_OBJECT * ) Op)->Length = (UINT32) (ParserState->PkgEnd - - AmlOpStart); + Op->Named.Data = AmlOpStart; + Op->Named.Length = (UINT32) (ParserState->PkgEnd - AmlOpStart); /* * Skip body */ @@ -934,6 +932,10 @@ WalkState->ControlState->Control.PackageEnd = ParserState->PkgEnd; } break; + + default: + /* No action for all other opcodes */ + break; } break; } @@ -945,14 +947,18 @@ { /* There are arguments (complex ones), push Op and prepare for argument */ - AcpiPsPushScope (ParserState, Op, WalkState->ArgTypes, WalkState->ArgCount); + Status = AcpiPsPushScope (ParserState, Op, WalkState->ArgTypes, WalkState->ArgCount); + if (ACPI_FAILURE (Status)) + { + return_ACPI_STATUS (Status); + } Op = NULL; continue; } /* All arguments have been processed -- Op is complete, prepare for next */ - WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); + WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); if (WalkState->OpInfo->Flags & AML_NAMED) { if (AcpiGbl_Depth) @@ -960,7 +966,7 @@ AcpiGbl_Depth--; } - if (Op->Opcode == AML_REGION_OP) + if (Op->Common.AmlOpcode == AML_REGION_OP) { /* * Skip parsing of control method or opregion body, @@ -970,8 +976,7 @@ * Completed parsing an OpRegion declaration, we now * know the length. */ - ((ACPI_PARSE2_OBJECT * ) Op)->Length = (UINT32) (ParserState->Aml - - ((ACPI_PARSE2_OBJECT * ) Op)->Data); + Op->Named.Length = (UINT32) (ParserState->Aml - Op->Named.Data); } } @@ -983,8 +988,7 @@ * * BodyLength is unknown until we parse the body */ - ((ACPI_PARSE2_OBJECT * ) Op)->Length = (UINT32) (ParserState->Aml - - ((ACPI_PARSE2_OBJECT * ) Op)->Data); + Op->Named.Length = (UINT32) (ParserState->Aml - Op->Named.Data); } /* This op complete, notify the dispatcher */ @@ -992,7 +996,7 @@ if (WalkState->AscendingCallback != NULL) { WalkState->Op = Op; - WalkState->Opcode = Op->Opcode; + WalkState->Opcode = Op->Common.AmlOpcode; Status = WalkState->AscendingCallback (WalkState); Status = AcpiPsNextParseState (WalkState, Op, Status); @@ -1010,12 +1014,10 @@ */ ParserState->Scope->ParseScope.ArgCount--; - /* Close this Op (may result in parse subtree deletion) */ + /* Close this Op (will result in parse subtree deletion) */ - if (AcpiPsCompleteThisOp (WalkState, Op)) - { - Op = NULL; - } + AcpiPsCompleteThisOp (WalkState, Op); + Op = NULL; switch (Status) { @@ -1038,8 +1040,8 @@ AcpiPsPopScope (ParserState, &Op, &WalkState->ArgTypes, &WalkState->ArgCount); WalkState->Op = Op; - WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); - WalkState->Opcode = Op->Opcode; + WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); + WalkState->Opcode = Op->Common.AmlOpcode; Status = WalkState->AscendingCallback (WalkState); Status = AcpiPsNextParseState (WalkState, Op, Status); @@ -1055,7 +1057,7 @@ /* Pop off scopes until we find the While */ - while (!Op || (Op->Opcode != AML_WHILE_OP)) + while (!Op || (Op->Common.AmlOpcode != AML_WHILE_OP)) { AcpiPsPopScope (ParserState, &Op, &WalkState->ArgTypes, &WalkState->ArgCount); } @@ -1063,8 +1065,8 @@ /* Close this iteration of the While loop */ WalkState->Op = Op; - WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); - WalkState->Opcode = Op->Opcode; + WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); + WalkState->Opcode = Op->Common.AmlOpcode; Status = WalkState->AscendingCallback (WalkState); Status = AcpiPsNextParseState (WalkState, Op, Status); @@ -1150,8 +1152,8 @@ if (WalkState->AscendingCallback != NULL) { WalkState->Op = Op; - WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); - WalkState->Opcode = Op->Opcode; + WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); + WalkState->Opcode = Op->Common.AmlOpcode; Status = WalkState->AscendingCallback (WalkState); Status = AcpiPsNextParseState (WalkState, Op, Status); @@ -1315,7 +1317,14 @@ */ if ((WalkState->ParseFlags & ACPI_PARSE_MODE_MASK) == ACPI_PARSE_EXECUTE) { - AcpiDsTerminateControlMethod (WalkState); + Status = AcpiDsTerminateControlMethod (WalkState); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("Could not terminate control method properly\n")); + Status = AE_OK; + + /* Ignore error and continue */ + } } /* Delete this walk state and all linked control states */ @@ -1339,8 +1348,11 @@ * If the method return value is not used by the parent, * The object is deleted */ - AcpiDsRestartControlMethod (WalkState, PreviousWalkState->ReturnDesc); - WalkState->WalkType |= ACPI_WALK_METHOD_RESTART; + Status = AcpiDsRestartControlMethod (WalkState, PreviousWalkState->ReturnDesc); + if (ACPI_SUCCESS (Status)) + { + WalkState->WalkType |= ACPI_WALK_METHOD_RESTART; + } } else { @@ -1388,7 +1400,7 @@ AcpiUtRemoveReference (EffectiveReturnDesc); AcpiExReleaseAllMutexes (Thread); - AcpiUtDeleteGenericState ((ACPI_GENERIC_STATE *) Thread); + AcpiUtDeleteGenericState (ACPI_CAST_PTR (ACPI_GENERIC_STATE, Thread)); AcpiGbl_CurrentWalkList = PrevWalkList; return_ACPI_STATUS (Status); } Index: pstree.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/pstree.c,v retrieving revision 1.1.1.9 diff -u -r1.1.1.9 pstree.c --- pstree.c 23 Feb 2002 05:10:40 -0000 1.1.1.9 +++ pstree.c 1 Jul 2002 21:39:53 -0000 @@ -152,7 +152,7 @@ /* Get the info structure for this opcode */ - OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); + OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); if (OpInfo->Class == AML_CLASS_UNKNOWN) { /* Invalid opcode or ASCII character */ @@ -171,11 +171,11 @@ /* Get the requested argument object */ - Arg = Op->Value.Arg; + Arg = Op->Common.Value.Arg; while (Arg && Argn) { Argn--; - Arg = Arg->Next; + Arg = Arg->Common.Next; } return (Arg); @@ -214,12 +214,13 @@ /* Get the info structure for this opcode */ - OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); + OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); if (OpInfo->Class == AML_CLASS_UNKNOWN) { /* Invalid opcode */ - ACPI_REPORT_ERROR (("PsAppendArg: Invalid AML Opcode: 0x%2.2X\n", Op->Opcode)); + ACPI_REPORT_ERROR (("PsAppendArg: Invalid AML Opcode: 0x%2.2X\n", + Op->Common.AmlOpcode)); return; } @@ -235,23 +236,23 @@ /* Append the argument to the linked argument list */ - if (Op->Value.Arg) + if (Op->Common.Value.Arg) { /* Append to existing argument list */ - PrevArg = Op->Value.Arg; - while (PrevArg->Next) + PrevArg = Op->Common.Value.Arg; + while (PrevArg->Common.Next) { - PrevArg = PrevArg->Next; + PrevArg = PrevArg->Common.Next; } - PrevArg->Next = Arg; + PrevArg->Common.Next = Arg; } else { /* No argument list, this will be the first argument */ - Op->Value.Arg = Arg; + Op->Common.Value.Arg = Arg; } @@ -259,8 +260,8 @@ while (Arg) { - Arg->Parent = Op; - Arg = Arg->Next; + Arg->Common.Parent = Op; + Arg = Arg->Common.Next; } } @@ -287,7 +288,7 @@ ACPI_FUNCTION_ENTRY (); - switch (Op->Opcode) + switch (Op->Common.AmlOpcode) { case AML_SCOPE_OP: case AML_ELSE_OP: @@ -323,6 +324,10 @@ Child = AcpiPsGetArg (Op, 3); break; + + default: + /* All others have no children */ + break; } return (Child); @@ -371,7 +376,7 @@ /* look for a sibling */ - Next = Op->Next; + Next = Op->Common.Next; if (Next) { return (Next); @@ -379,14 +384,14 @@ /* look for a sibling of parent */ - Parent = Op->Parent; + Parent = Op->Common.Parent; while (Parent) { Arg = AcpiPsGetArg (Parent, 0); while (Arg && (Arg != Origin) && (Arg != Op)) { - Arg = Arg->Next; + Arg = Arg->Common.Next; } if (Arg == Origin) @@ -396,14 +401,15 @@ return (NULL); } - if (Parent->Next) + if (Parent->Common.Next) { /* found sibling of parent */ - return (Parent->Next); + + return (Parent->Common.Next); } Op = Parent; - Parent = Parent->Parent; + Parent = Parent->Common.Parent; } return (Next); Index: psutils.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/psutils.c,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 psutils.c --- psutils.c 30 Jun 2002 17:50:45 -0000 1.1.1.10 +++ psutils.c 1 Jul 2002 21:39:53 -0000 @@ -145,11 +145,11 @@ ACPI_FUNCTION_ENTRY (); - Op->DataType = ACPI_DESC_TYPE_PARSER; - Op->Opcode = Opcode; + Op->Common.DataType = ACPI_DESC_TYPE_PARSER; + Op->Common.AmlOpcode = Opcode; - ACPI_DEBUG_ONLY_MEMBERS (ACPI_STRNCPY (Op->OpName, - (AcpiPsGetOpcodeInfo (Opcode))->Name, sizeof (Op->OpName))); + ACPI_DEBUG_ONLY_MEMBERS (ACPI_STRNCPY (Op->Common.AmlOpName, + (AcpiPsGetOpcodeInfo (Opcode))->Name, sizeof (Op->Common.AmlOpName))); } @@ -186,26 +186,26 @@ if (OpInfo->Flags & AML_DEFER) { - Size = sizeof (ACPI_PARSE2_OBJECT); + Size = sizeof (ACPI_PARSE_OBJ_NAMED); Flags = ACPI_PARSEOP_DEFERRED; } else if (OpInfo->Flags & AML_NAMED) { - Size = sizeof (ACPI_PARSE2_OBJECT); + Size = sizeof (ACPI_PARSE_OBJ_NAMED); Flags = ACPI_PARSEOP_NAMED; } else if (Opcode == AML_INT_BYTELIST_OP) { - Size = sizeof (ACPI_PARSE2_OBJECT); + Size = sizeof (ACPI_PARSE_OBJ_NAMED); Flags = ACPI_PARSEOP_BYTELIST; } else { - Size = sizeof (ACPI_PARSE_OBJECT); + Size = sizeof (ACPI_PARSE_OBJ_COMMON); Flags = ACPI_PARSEOP_GENERIC; } - if (Size == sizeof (ACPI_PARSE_OBJECT)) + if (Size == sizeof (ACPI_PARSE_OBJ_COMMON)) { /* * The generic op is by far the most common (16 to 1) @@ -222,7 +222,7 @@ if (Op) { AcpiPsInitOp (Op, Opcode); - Op->Flags = Flags; + Op->Common.Flags = Flags; } return (Op); @@ -249,12 +249,12 @@ ACPI_FUNCTION_NAME ("PsFreeOp"); - if (Op->Opcode == AML_INT_RETURN_VALUE_OP) + if (Op->Common.AmlOpcode == AML_INT_RETURN_VALUE_OP) { ACPI_DEBUG_PRINT ((ACPI_DB_ALLOCATIONS, "Free retval op: %p\n", Op)); } - if (Op->Flags == ACPI_PARSEOP_GENERIC) + if (Op->Common.Flags == ACPI_PARSEOP_GENERIC) { AcpiUtReleaseToCache (ACPI_MEM_LIST_PSNODE, Op); } @@ -332,14 +332,14 @@ /* The "generic" object has no name associated with it */ - if (Op->Flags & ACPI_PARSEOP_GENERIC) + if (Op->Common.Flags & ACPI_PARSEOP_GENERIC) { return (0); } /* Only the "Extended" parse objects have a name */ - return (((ACPI_PARSE2_OBJECT *) Op)->Name); + return (Op->Named.Name); } @@ -354,11 +354,11 @@ /* The "generic" object has no name associated with it */ - if (Op->Flags & ACPI_PARSEOP_GENERIC) + if (Op->Common.Flags & ACPI_PARSEOP_GENERIC) { return; } - ((ACPI_PARSE2_OBJECT *) Op)->Name = name; + Op->Named.Name = name; } Index: pswalk.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/pswalk.c,v retrieving revision 1.1.1.9 diff -u -r1.1.1.9 pswalk.c --- pswalk.c 23 Feb 2002 05:10:40 -0000 1.1.1.9 +++ pswalk.c 1 Jul 2002 21:39:53 -0000 @@ -116,11 +116,8 @@ #include "acpi.h" -#include "amlcode.h" #include "acparser.h" #include "acdispat.h" -#include "acnamesp.h" -#include "acinterp.h" #define _COMPONENT ACPI_PARSER ACPI_MODULE_NAME ("pswalk") @@ -177,12 +174,12 @@ * No more children, this Op is complete. Save Next and Parent * in case the Op object gets deleted by the callback routine */ - Next = Op->Next; - Parent = Op->Parent; + Next = Op->Common.Next; + Parent = Op->Common.Parent; WalkState->Op = Op; - WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Opcode); - WalkState->Opcode = Op->Opcode; + WalkState->OpInfo = AcpiPsGetOpcodeInfo (Op->Common.AmlOpcode); + WalkState->Opcode = Op->Common.AmlOpcode; Status = AscendingCallback (WalkState); @@ -239,12 +236,12 @@ { /* We are moving up the tree, therefore this parent Op is complete */ - GrandParent = Parent->Parent; - Next = Parent->Next; + GrandParent = Parent->Common.Parent; + Next = Parent->Common.Next; WalkState->Op = Parent; - WalkState->OpInfo = AcpiPsGetOpcodeInfo (Parent->Opcode); - WalkState->Opcode = Parent->Opcode; + WalkState->OpInfo = AcpiPsGetOpcodeInfo (Parent->Common.AmlOpcode); + WalkState->Opcode = Parent->Common.AmlOpcode; Status = AscendingCallback (WalkState); @@ -337,6 +334,7 @@ { ACPI_WALK_STATE *WalkState; ACPI_THREAD_STATE *Thread; + ACPI_STATUS Status; ACPI_FUNCTION_TRACE_PTR ("PsDeleteParseTree", SubtreeRoot); @@ -355,7 +353,6 @@ return_VOID; } - WalkState = AcpiDsCreateWalkState (TABLE_ID_DSDT, NULL, NULL, Thread); if (!WalkState) { @@ -377,13 +374,17 @@ while (WalkState->NextOp) { - AcpiPsGetNextWalkOp (WalkState, WalkState->NextOp, + Status = AcpiPsGetNextWalkOp (WalkState, WalkState->NextOp, AcpiPsDeleteCompletedOp); + if (ACPI_FAILURE (Status)) + { + break; + } } /* We are done with this walk */ - AcpiUtDeleteGenericState ((ACPI_GENERIC_STATE *) Thread); + AcpiUtDeleteGenericState (ACPI_CAST_PTR (ACPI_GENERIC_STATE, Thread)); AcpiDsDeleteWalkState (WalkState); return_VOID; Index: psxface.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/psxface.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 psxface.c --- psxface.c 30 Jun 2002 17:50:45 -0000 1.1.1.12 +++ psxface.c 1 Jul 2002 21:39:53 -0000 @@ -240,7 +240,6 @@ Status = AcpiPsParseAml (WalkState); AcpiPsDeleteParseTree (Op); - /* * 2) Execute the method. Performs second pass parse simultaneously */ @@ -259,12 +258,11 @@ /* Init new op with the method name and pointer back to the NS node */ AcpiPsSetName (Op, MethodNode->Name.Integer); - Op->Node = MethodNode; + Op->Common.Node = MethodNode; /* Create and initialize a new walk state */ - WalkState = AcpiDsCreateWalkState (TABLE_ID_DSDT, - NULL, NULL, NULL); + WalkState = AcpiDsCreateWalkState (TABLE_ID_DSDT, NULL, NULL, NULL); if (!WalkState) { return_ACPI_STATUS (AE_NO_MEMORY); @@ -290,7 +288,9 @@ for (i = 0; Params[i]; i++) { - AcpiUtUpdateObjectReference (Params[i], REF_DECREMENT); + /* Ignore errors, just do them all */ + + (void) AcpiUtUpdateObjectReference (Params[i], REF_DECREMENT); } } Index: rsaddr.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rsaddr.c,v retrieving revision 1.1.1.8 diff -u -r1.1.1.8 rsaddr.c --- rsaddr.c 23 Feb 2002 05:10:40 -0000 1.1.1.8 +++ rsaddr.c 1 Jul 2002 21:39:53 -0000 @@ -152,8 +152,8 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; - NATIVE_CHAR *TempPtr; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; + UINT8 *TempPtr; ACPI_SIZE StructSize = ACPI_SIZEOF_RESOURCE (ACPI_RESOURCE_ADDRESS16); UINT32 Index; UINT16 Temp16; @@ -298,7 +298,7 @@ OutputStruct->Data.Address16.ResourceSource.StringPtr = (NATIVE_CHAR *)((UINT8 * )OutputStruct + StructSize); - TempPtr = OutputStruct->Data.Address16.ResourceSource.StringPtr; + TempPtr = (UINT8 *) OutputStruct->Data.Address16.ResourceSource.StringPtr; /* Copy the string into the buffer */ @@ -338,7 +338,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -493,8 +493,7 @@ * Buffer needs to be set to the length of the sting + one for the * terminating null */ - Buffer += (ACPI_STRLEN (LinkedList->Data.Address16.ResourceSource.StringPtr) - + 1); + Buffer += (ACPI_STRLEN (LinkedList->Data.Address16.ResourceSource.StringPtr) + 1); } /* @@ -542,10 +541,10 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer; - ACPI_RESOURCE *OutputStruct; + ACPI_RESOURCE *OutputStruct= (void *) *OutputBuffer; UINT16 Temp16; UINT8 Temp8; - NATIVE_CHAR *TempPtr; + UINT8 *TempPtr; ACPI_SIZE StructSize; UINT32 Index; @@ -554,8 +553,6 @@ Buffer = ByteStreamBuffer; - OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; - StructSize = ACPI_SIZEOF_RESOURCE (ACPI_RESOURCE_ADDRESS32); /* @@ -697,7 +694,7 @@ OutputStruct->Data.Address32.ResourceSource.StringPtr = (NATIVE_CHAR *)((UINT8 *)OutputStruct + StructSize); - TempPtr = OutputStruct->Data.Address32.ResourceSource.StringPtr; + TempPtr = (UINT8 *) OutputStruct->Data.Address32.ResourceSource.StringPtr; /* Copy the string into the buffer */ @@ -735,7 +732,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -787,7 +784,7 @@ /* * Set a pointer to the Length field - to be filled in later */ - LengthField = (UINT16 *) Buffer; + LengthField = ACPI_CAST_PTR (UINT16, Buffer); Buffer += 2; /* @@ -937,10 +934,10 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer; - ACPI_RESOURCE *OutputStruct; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT16 Temp16; UINT8 Temp8; - NATIVE_CHAR *TempPtr; + UINT8 *TempPtr; ACPI_SIZE StructSize; UINT32 Index; @@ -949,8 +946,6 @@ Buffer = ByteStreamBuffer; - OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; - StructSize = ACPI_SIZEOF_RESOURCE (ACPI_RESOURCE_ADDRESS64); /* @@ -1095,7 +1090,7 @@ OutputStruct->Data.Address64.ResourceSource.StringPtr = (NATIVE_CHAR *)((UINT8 *)OutputStruct + StructSize); - TempPtr = OutputStruct->Data.Address64.ResourceSource.StringPtr; + TempPtr = (UINT8 *) OutputStruct->Data.Address64.ResourceSource.StringPtr; /* Copy the string into the buffer */ @@ -1134,7 +1129,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -1187,7 +1182,7 @@ * Set a pointer to the Length field - to be filled in later */ - LengthField = (UINT16 *)Buffer; + LengthField = ACPI_CAST_PTR (UINT16, Buffer); Buffer += 2; /* Index: rscalc.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rscalc.c,v retrieving revision 1.1.1.10 diff -u -r1.1.1.10 rscalc.c --- rscalc.c 23 Feb 2002 05:10:40 -0000 1.1.1.10 +++ rscalc.c 1 Jul 2002 21:39:53 -0000 @@ -127,7 +127,7 @@ /******************************************************************************* * - * FUNCTION: AcpiRsCalculateByteStreamLength + * FUNCTION: AcpiRsGetByteStreamLength * * PARAMETERS: LinkedList - Pointer to the resource linked list * SizeNeeded - UINT32 pointer of the size buffer needed @@ -142,7 +142,7 @@ ******************************************************************************/ ACPI_STATUS -AcpiRsCalculateByteStreamLength ( +AcpiRsGetByteStreamLength ( ACPI_RESOURCE *LinkedList, ACPI_SIZE *SizeNeeded) { @@ -152,7 +152,7 @@ BOOLEAN Done = FALSE; - ACPI_FUNCTION_TRACE ("RsCalculateByteStreamLength"); + ACPI_FUNCTION_TRACE ("RsGetByteStreamLength"); while (!Done) @@ -276,10 +276,10 @@ */ SegmentSize = 16; - if (NULL != LinkedList->Data.Address16.ResourceSource.StringPtr) + if (LinkedList->Data.Address16.ResourceSource.StringPtr) { - SegmentSize += (1 + - LinkedList->Data.Address16.ResourceSource.StringLength); + SegmentSize += LinkedList->Data.Address16.ResourceSource.StringLength; + SegmentSize++; } break; @@ -293,10 +293,10 @@ */ SegmentSize = 26; - if (NULL != LinkedList->Data.Address32.ResourceSource.StringPtr) + if (LinkedList->Data.Address32.ResourceSource.StringPtr) { - SegmentSize += (1 + - LinkedList->Data.Address32.ResourceSource.StringLength); + SegmentSize += LinkedList->Data.Address32.ResourceSource.StringLength; + SegmentSize++; } break; @@ -310,10 +310,10 @@ */ SegmentSize = 46; - if (NULL != LinkedList->Data.Address64.ResourceSource.StringPtr) + if (LinkedList->Data.Address64.ResourceSource.StringPtr) { - SegmentSize += (1 + - LinkedList->Data.Address64.ResourceSource.StringLength); + SegmentSize += LinkedList->Data.Address64.ResourceSource.StringLength; + SegmentSize++; } break; @@ -328,12 +328,12 @@ * Resource Source + 1 for the null. */ SegmentSize = 9 + - ((LinkedList->Data.ExtendedIrq.NumberOfInterrupts - 1) * 4); + (((ACPI_SIZE) LinkedList->Data.ExtendedIrq.NumberOfInterrupts - 1) * 4); - if (NULL != ExIrq->ResourceSource.StringPtr) + if (ExIrq && ExIrq->ResourceSource.StringPtr) { - SegmentSize += (1 + - LinkedList->Data.ExtendedIrq.ResourceSource.StringLength); + SegmentSize += LinkedList->Data.ExtendedIrq.ResourceSource.StringLength; + SegmentSize++; } break; @@ -368,7 +368,7 @@ /******************************************************************************* * - * FUNCTION: AcpiRsCalculateListLength + * FUNCTION: AcpiRsGetListLength * * PARAMETERS: ByteStreamBuffer - Pointer to the resource byte stream * ByteStreamBufferLength - Size of ByteStreamBuffer @@ -385,7 +385,7 @@ ******************************************************************************/ ACPI_STATUS -AcpiRsCalculateListLength ( +AcpiRsGetListLength ( UINT8 *ByteStreamBuffer, UINT32 ByteStreamBufferLength, ACPI_SIZE *SizeNeeded) @@ -404,7 +404,7 @@ UINT8 AdditionalBytes; - ACPI_FUNCTION_TRACE ("RsCalculateListLength"); + ACPI_FUNCTION_TRACE ("RsGetListLength"); while (BytesParsed < ByteStreamBufferLength) @@ -823,7 +823,7 @@ /******************************************************************************* * - * FUNCTION: AcpiRsCalculatePciRoutingTableLength + * FUNCTION: AcpiRsGetPciRoutingTableLength * * PARAMETERS: PackageObject - Pointer to the package object * BufferSizeNeeded - UINT32 pointer of the size buffer @@ -839,12 +839,12 @@ ******************************************************************************/ ACPI_STATUS -AcpiRsCalculatePciRoutingTableLength ( +AcpiRsGetPciRoutingTableLength ( ACPI_OPERAND_OBJECT *PackageObject, ACPI_SIZE *BufferSizeNeeded) { UINT32 NumberOfElements; - UINT32 TempSizeNeeded = 0; + ACPI_SIZE TempSizeNeeded = 0; ACPI_OPERAND_OBJECT **TopObjectList; UINT32 Index; ACPI_OPERAND_OBJECT *PackageElement; @@ -853,7 +853,7 @@ UINT32 TableIndex; - ACPI_FUNCTION_TRACE ("RsCalculatePciRoutingTableLength"); + ACPI_FUNCTION_TRACE ("RsGetPciRoutingTableLength"); NumberOfElements = PackageObject->Package.Count; @@ -890,8 +890,8 @@ for (TableIndex = 0; TableIndex < 4 && !NameFound; TableIndex++) { - if ((ACPI_TYPE_STRING == (*SubObjectList)->Common.Type) || - ((INTERNAL_TYPE_REFERENCE == (*SubObjectList)->Common.Type) && + if ((ACPI_TYPE_STRING == ACPI_GET_OBJECT_TYPE (*SubObjectList)) || + ((INTERNAL_TYPE_REFERENCE == ACPI_GET_OBJECT_TYPE (*SubObjectList)) && ((*SubObjectList)->Reference.Opcode == AML_INT_NAMEPATH_OP))) { NameFound = TRUE; @@ -910,9 +910,9 @@ /* * Was a String type found? */ - if (TRUE == NameFound) + if (NameFound) { - if (ACPI_TYPE_STRING == (*SubObjectList)->Common.Type) + if (ACPI_GET_OBJECT_TYPE (*SubObjectList) == ACPI_TYPE_STRING) { /* * The length String.Length field includes the Index: rscreate.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rscreate.c,v retrieving revision 1.3 diff -u -r1.3 rscreate.c --- rscreate.c 23 Feb 2002 05:16:34 -0000 1.3 +++ rscreate.c 1 Jul 2002 21:39:53 -0000 @@ -172,11 +172,11 @@ * Pass the ByteStreamBuffer into a module that can calculate * the buffer size needed for the linked list */ - Status = AcpiRsCalculateListLength (ByteStreamStart, ByteStreamBufferLength, + Status = AcpiRsGetListLength (ByteStreamStart, ByteStreamBufferLength, &ListSizeNeeded); ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "Status=%X ListSizeNeeded=%X\n", - Status, ListSizeNeeded)); + Status, (UINT32) ListSizeNeeded)); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); @@ -200,7 +200,7 @@ } ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "OutputBuffer %p Length %X\n", - OutputBuffer->Pointer, OutputBuffer->Length)); + OutputBuffer->Pointer, (UINT32) OutputBuffer->Length)); return_ACPI_STATUS (AE_OK); } @@ -253,14 +253,14 @@ /* * Get the required buffer length */ - Status = AcpiRsCalculatePciRoutingTableLength (PackageObject, + Status = AcpiRsGetPciRoutingTableLength (PackageObject, &BufferSizeNeeded); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); } - ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "BufferSizeNeeded = %X\n", BufferSizeNeeded)); + ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "BufferSizeNeeded = %X\n", (UINT32) BufferSizeNeeded)); /* Validate/Allocate/Clear caller buffer */ @@ -277,7 +277,7 @@ TopObjectList = PackageObject->Package.Elements; NumberOfElements = PackageObject->Package.Count; Buffer = OutputBuffer->Pointer; - UserPrt = (ACPI_PCI_ROUTING_TABLE *) Buffer; + UserPrt = ACPI_CAST_PTR (ACPI_PCI_ROUTING_TABLE, Buffer); for (Index = 0; Index < NumberOfElements; Index++) { @@ -288,7 +288,7 @@ * be zero because we cleared the return buffer earlier */ Buffer += UserPrt->Length; - UserPrt = (ACPI_PCI_ROUTING_TABLE *) Buffer; + UserPrt = ACPI_CAST_PTR (ACPI_PCI_ROUTING_TABLE, Buffer); /* * Fill in the Length field with the information we have at this point. @@ -311,14 +311,14 @@ /* * 1) First subobject: Dereference the Address */ - if (ACPI_TYPE_INTEGER == (*SubObjectList)->Common.Type) + if (ACPI_GET_OBJECT_TYPE (*SubObjectList) == ACPI_TYPE_INTEGER) { UserPrt->Address = (*SubObjectList)->Integer.Value; } else { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Need Integer, found %s\n", - AcpiUtGetTypeName ((*SubObjectList)->Common.Type))); + AcpiUtGetObjectTypeName (*SubObjectList))); return_ACPI_STATUS (AE_BAD_DATA); } @@ -327,14 +327,14 @@ */ SubObjectList++; - if (ACPI_TYPE_INTEGER == (*SubObjectList)->Common.Type) + if (ACPI_GET_OBJECT_TYPE (*SubObjectList) == ACPI_TYPE_INTEGER) { UserPrt->Pin = (UINT32) (*SubObjectList)->Integer.Value; } else { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Need Integer, found %s\n", - AcpiUtGetTypeName ((*SubObjectList)->Common.Type))); + AcpiUtGetObjectTypeName (*SubObjectList))); return_ACPI_STATUS (AE_BAD_DATA); } @@ -343,7 +343,7 @@ */ SubObjectList++; - switch ((*SubObjectList)->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (*SubObjectList)) { case INTERNAL_TYPE_REFERENCE: @@ -362,7 +362,7 @@ (UINT32) ((UINT8 *) UserPrt->Source - (UINT8 *) OutputBuffer->Pointer); PathBuffer.Pointer = UserPrt->Source; - Status = AcpiNsHandleToPathname ((ACPI_HANDLE *) Node, &PathBuffer); + Status = AcpiNsHandleToPathname ((ACPI_HANDLE) Node, &PathBuffer); UserPrt->Length += ACPI_STRLEN (UserPrt->Source) + 1; /* include null terminator */ break; @@ -393,7 +393,7 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Need Integer, found %s\n", - AcpiUtGetTypeName ((*SubObjectList)->Common.Type))); + AcpiUtGetObjectTypeName (*SubObjectList))); return_ACPI_STATUS (AE_BAD_DATA); } @@ -406,14 +406,14 @@ */ SubObjectList++; - if (ACPI_TYPE_INTEGER == (*SubObjectList)->Common.Type) + if (ACPI_GET_OBJECT_TYPE (*SubObjectList) == ACPI_TYPE_INTEGER) { UserPrt->SourceIndex = (UINT32) (*SubObjectList)->Integer.Value; } else { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Need Integer, found %s\n", - AcpiUtGetTypeName ((*SubObjectList)->Common.Type))); + AcpiUtGetObjectTypeName (*SubObjectList))); return_ACPI_STATUS (AE_BAD_DATA); } @@ -423,7 +423,7 @@ } ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "OutputBuffer %p Length %X\n", - OutputBuffer->Pointer, OutputBuffer->Length)); + OutputBuffer->Pointer, (UINT32) OutputBuffer->Length)); return_ACPI_STATUS (AE_OK); } @@ -466,11 +466,11 @@ * Pass the LinkedListBuffer into a module that calculates * the buffer size needed for the byte stream. */ - Status = AcpiRsCalculateByteStreamLength (LinkedListBuffer, + Status = AcpiRsGetByteStreamLength (LinkedListBuffer, &ByteStreamSizeNeeded); ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "ByteStreamSizeNeeded=%X, %s\n", - ByteStreamSizeNeeded, AcpiFormatException (Status))); + (UINT32) ByteStreamSizeNeeded, AcpiFormatException (Status))); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); @@ -494,7 +494,7 @@ } ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "OutputBuffer %p Length %X\n", - OutputBuffer->Pointer, OutputBuffer->Length)); + OutputBuffer->Pointer, (UINT32) OutputBuffer->Length)); return_ACPI_STATUS (AE_OK); } Index: rsdump.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rsdump.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 rsdump.c --- rsdump.c 23 Feb 2002 05:10:40 -0000 1.1.1.11 +++ rsdump.c 1 Jul 2002 21:39:53 -0000 @@ -124,7 +124,7 @@ ACPI_MODULE_NAME ("rsdump") -#ifdef ACPI_DEBUG +#if defined(ACPI_DEBUG) || defined(ENABLE_DEBUGGER) /******************************************************************************* * @@ -269,9 +269,9 @@ void AcpiRsDumpStartDependFns ( - ACPI_RESOURCE_DATA *Data) + ACPI_RESOURCE_DATA *Data) { - ACPI_RESOURCE_START_DPF *SdfData = (ACPI_RESOURCE_START_DPF *) Data; + ACPI_RESOURCE_START_DPF *SdfData = (ACPI_RESOURCE_START_DPF *) Data; ACPI_FUNCTION_ENTRY (); @@ -1093,7 +1093,7 @@ { while (!Done) { - AcpiOsPrintf ("Resource structure %x.\n", Count++); + AcpiOsPrintf ("Resource structure %X.\n", Count++); switch (Resource->Id) { @@ -1200,7 +1200,7 @@ if (AcpiDbgLevel & ACPI_LV_RESOURCES && _COMPONENT & AcpiDbgLayer) { - PrtElement = (ACPI_PCI_ROUTING_TABLE *) Buffer; + PrtElement = ACPI_CAST_PTR (ACPI_PCI_ROUTING_TABLE, Buffer); while (!Done) { @@ -1219,7 +1219,7 @@ Buffer += PrtElement->Length; - PrtElement = (ACPI_PCI_ROUTING_TABLE *) Buffer; + PrtElement = ACPI_CAST_PTR (ACPI_PCI_ROUTING_TABLE, Buffer); if(0 == PrtElement->Length) { Index: rsio.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rsio.c,v retrieving revision 1.1.1.6 diff -u -r1.1.1.6 rsio.c --- rsio.c 23 Feb 2002 05:10:40 -0000 1.1.1.6 +++ rsio.c 1 Jul 2002 21:39:53 -0000 @@ -152,7 +152,7 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT16 Temp16 = 0; UINT8 Temp8 = 0; ACPI_SIZE StructSize = ACPI_SIZEOF_RESOURCE (ACPI_RESOURCE_IO); @@ -211,7 +211,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -250,7 +250,7 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT16 Temp16 = 0; UINT8 Temp8 = 0; ACPI_SIZE StructSize = ACPI_SIZEOF_RESOURCE (ACPI_RESOURCE_FIXED_IO); @@ -285,7 +285,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -469,7 +469,7 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT8 Temp8 = 0; UINT8 Index; UINT8 i; @@ -501,13 +501,19 @@ i++; } } + if (i == 0) + { + /* Zero channels is invalid! */ + + return_ACPI_STATUS (AE_BAD_DATA); + } OutputStruct->Data.Dma.NumberOfChannels = i; /* * Calculate the structure size based upon the number of interrupts */ - StructSize += (OutputStruct->Data.Dma.NumberOfChannels - 1) * 4; + StructSize += ((ACPI_SIZE) OutputStruct->Data.Dma.NumberOfChannels - 1) * 4; /* * Point to Byte 2 @@ -538,7 +544,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure Index: rsirq.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rsirq.c,v retrieving revision 1.1.1.8 diff -u -r1.1.1.8 rsirq.c --- rsirq.c 23 Feb 2002 05:10:40 -0000 1.1.1.8 +++ rsirq.c 1 Jul 2002 21:39:53 -0000 @@ -152,7 +152,7 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT16 Temp16 = 0; UINT8 Temp8 = 0; UINT8 Index; @@ -183,18 +183,25 @@ for (i = 0, Index = 0; Index < 16; Index++) { - if((Temp16 >> Index) & 0x01) + if ((Temp16 >> Index) & 0x01) { OutputStruct->Data.Irq.Interrupts[i] = Index; i++; } } + + if (i == 0) + { + /* Zero interrupts is invalid! */ + + return_ACPI_STATUS (AE_BAD_DATA); + } OutputStruct->Data.Irq.NumberOfInterrupts = i; /* * Calculate the structure size based upon the number of interrupts */ - StructSize += (OutputStruct->Data.Irq.NumberOfInterrupts - 1) * 4; + StructSize += ((ACPI_SIZE) OutputStruct->Data.Irq.NumberOfInterrupts - 1) * 4; /* * Point to Byte 3 if it is used @@ -249,7 +256,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -385,10 +392,10 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT16 Temp16 = 0; UINT8 Temp8 = 0; - NATIVE_CHAR *TempPtr; + UINT8 *TempPtr; UINT8 Index; ACPI_SIZE StructSize = ACPI_SIZEOF_RESOURCE (ACPI_RESOURCE_EXT_IRQ); @@ -458,8 +465,8 @@ */ for (Index = 0; Index < Temp8; Index++) { - OutputStruct->Data.ExtendedIrq.Interrupts[Index] = - (UINT32)*Buffer; + ACPI_MOVE_UNALIGNED32_TO_32 ( + &OutputStruct->Data.ExtendedIrq.Interrupts[Index], Buffer); /* Point to the next IRQ */ @@ -474,7 +481,7 @@ * stream that are default. */ if (*BytesConsumed > - (UINT32)(OutputStruct->Data.ExtendedIrq.NumberOfInterrupts * 4) + 5) + ((ACPI_SIZE) OutputStruct->Data.ExtendedIrq.NumberOfInterrupts * 4) + 5) { /* Dereference the Index */ @@ -491,7 +498,7 @@ OutputStruct->Data.ExtendedIrq.ResourceSource.StringPtr = (NATIVE_CHAR *)(OutputStruct + StructSize); - TempPtr = OutputStruct->Data.ExtendedIrq.ResourceSource.StringPtr; + TempPtr = (UINT8 *) OutputStruct->Data.ExtendedIrq.ResourceSource.StringPtr; /* Copy the string into the buffer */ @@ -529,7 +536,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -580,7 +587,7 @@ /* * Set a pointer to the Length field - to be filled in later */ - LengthField = (UINT16 *)Buffer; + LengthField = ACPI_CAST_PTR (UINT16, Buffer); Buffer += 2; /* Index: rslist.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rslist.c,v retrieving revision 1.1.1.7 diff -u -r1.1.1.7 rslist.c --- rslist.c 23 Feb 2002 05:10:40 -0000 1.1.1.7 +++ rslist.c 1 Jul 2002 21:39:53 -0000 @@ -163,6 +163,11 @@ * Large Resource Type -- All bits are valid */ return (ResourceStartByte); + + + default: + /* No other types of resource descriptor */ + break; } return (0xFF); @@ -192,7 +197,7 @@ UINT8 *OutputBuffer) { ACPI_STATUS Status; - UINT32 BytesParsed = 0; + ACPI_SIZE BytesParsed = 0; UINT8 ResourceType = 0; ACPI_SIZE BytesConsumed = 0; UINT8 *Buffer = OutputBuffer; @@ -204,7 +209,7 @@ while (BytesParsed < ByteStreamBufferLength && - FALSE == EndTagProcessed) + !EndTagProcessed) { /* * The next byte in the stream is the resource type @@ -360,9 +365,9 @@ default: /* - * Invalid/Unknowns resource type + * Invalid/Unknown resource type */ - Status = AE_AML_ERROR; + Status = AE_AML_INVALID_RESOURCE_TYPE; break; } @@ -384,7 +389,7 @@ /* * Set the Buffer to the next structure */ - Resource = (ACPI_RESOURCE *)Buffer; + Resource = ACPI_CAST_PTR (ACPI_RESOURCE, Buffer); Resource->Length = ACPI_ALIGN_RESOURCE_SIZE(Resource->Length); Buffer += ACPI_ALIGN_RESOURCE_SIZE(StructureSize); @@ -393,9 +398,9 @@ /* * Check the reason for exiting the while loop */ - if (TRUE != EndTagProcessed) + if (!EndTagProcessed) { - return_ACPI_STATUS (AE_AML_ERROR); + return_ACPI_STATUS (AE_AML_NO_RESOURCE_END_TAG); } return_ACPI_STATUS (AE_OK); @@ -409,7 +414,7 @@ * PARAMETERS: LinkedList - Pointer to the resource linked list * ByteSteamSizeNeeded - Calculated size of the byte stream * needed from calling - * AcpiRsCalculateByteStreamLength() + * AcpiRsGetByteStreamLength() * The size of the OutputBuffer is * guaranteed to be >= * ByteStreamSizeNeeded @@ -426,7 +431,7 @@ ACPI_STATUS AcpiRsListToByteStream ( ACPI_RESOURCE *LinkedList, - UINT32 ByteStreamSizeNeeded, + ACPI_SIZE ByteStreamSizeNeeded, UINT8 *OutputBuffer) { ACPI_STATUS Status; Index: rsmemory.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rsmemory.c,v retrieving revision 1.1.1.6 diff -u -r1.1.1.6 rsmemory.c --- rsmemory.c 23 Feb 2002 05:10:40 -0000 1.1.1.6 +++ rsmemory.c 1 Jul 2002 21:39:53 -0000 @@ -152,7 +152,7 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT16 Temp16 = 0; UINT8 Temp8 = 0; ACPI_SIZE StructSize = ACPI_SIZEOF_RESOURCE (ACPI_RESOURCE_MEM24); @@ -168,7 +168,7 @@ ACPI_MOVE_UNALIGNED16_TO_16 (&Temp16, Buffer); Buffer += 2; - *BytesConsumed = Temp16 + 3; + *BytesConsumed = (ACPI_SIZE) Temp16 + 3; OutputStruct->Id = ACPI_RSTYPE_MEM24; /* @@ -208,7 +208,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -329,7 +329,7 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT16 Temp16 = 0; UINT8 Temp8 = 0; ACPI_SIZE StructSize = ACPI_SIZEOF_RESOURCE (ACPI_RESOURCE_MEM32); @@ -345,7 +345,7 @@ ACPI_MOVE_UNALIGNED16_TO_16 (&Temp16, Buffer); Buffer += 2; - *BytesConsumed = Temp16 + 3; + *BytesConsumed = (ACPI_SIZE) Temp16 + 3; OutputStruct->Id = ACPI_RSTYPE_MEM32; @@ -395,7 +395,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -434,7 +434,7 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT16 Temp16 = 0; UINT8 Temp8 = 0; ACPI_SIZE StructSize = ACPI_SIZEOF_RESOURCE (ACPI_RESOURCE_FIXED_MEM32); @@ -450,7 +450,7 @@ ACPI_MOVE_UNALIGNED16_TO_16 (&Temp16, Buffer); Buffer += 2; - *BytesConsumed = Temp16 + 3; + *BytesConsumed = (ACPI_SIZE) Temp16 + 3; OutputStruct->Id = ACPI_RSTYPE_FIXED_MEM32; @@ -477,7 +477,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure Index: rsmisc.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rsmisc.c,v retrieving revision 1.1.1.8 diff -u -r1.1.1.8 rsmisc.c --- rsmisc.c 23 Feb 2002 05:10:40 -0000 1.1.1.8 +++ rsmisc.c 1 Jul 2002 21:39:53 -0000 @@ -151,7 +151,7 @@ UINT8 **OutputBuffer, ACPI_SIZE *StructureSize) { - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; ACPI_SIZE StructSize = ACPI_RESOURCE_LENGTH; @@ -262,7 +262,7 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT16 Temp16 = 0; UINT8 Temp8 = 0; UINT8 Index; @@ -290,7 +290,7 @@ /* Calculate bytes consumed */ - *BytesConsumed = Temp16 + 3; + *BytesConsumed = (ACPI_SIZE) Temp16 + 3; /* Point to the first vendor byte */ @@ -305,7 +305,7 @@ /* Calculate bytes consumed */ - *BytesConsumed = Temp16 + 1; + *BytesConsumed = (ACPI_SIZE) Temp16 + 1; /* Point to the first vendor byte */ @@ -331,7 +331,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -394,7 +394,7 @@ * Small Item, Set the descriptor field */ Temp8 = 0x70; - Temp8 |= LinkedList->Data.VendorSpecific.Length; + Temp8 |= (UINT8) LinkedList->Data.VendorSpecific.Length; *Buffer = Temp8; Buffer += 1; @@ -448,7 +448,7 @@ ACPI_SIZE *StructureSize) { UINT8 *Buffer = ByteStreamBuffer; - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; UINT8 Temp8 = 0; ACPI_SIZE StructSize = ACPI_SIZEOF_RESOURCE (ACPI_RESOURCE_START_DPF); @@ -480,7 +480,7 @@ if (3 == OutputStruct->Data.StartDpf.CompatibilityPriority) { - return_ACPI_STATUS (AE_AML_ERROR); + return_ACPI_STATUS (AE_AML_BAD_RESOURCE_VALUE); } /* @@ -490,7 +490,7 @@ if (3 == OutputStruct->Data.StartDpf.PerformanceRobustness) { - return_ACPI_STATUS (AE_AML_ERROR); + return_ACPI_STATUS (AE_AML_BAD_RESOURCE_VALUE); } } else @@ -505,7 +505,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure @@ -543,7 +543,7 @@ UINT8 **OutputBuffer, ACPI_SIZE *StructureSize) { - ACPI_RESOURCE *OutputStruct = (ACPI_RESOURCE *) *OutputBuffer; + ACPI_RESOURCE *OutputStruct = (void *) *OutputBuffer; ACPI_SIZE StructSize = ACPI_RESOURCE_LENGTH; @@ -563,7 +563,7 @@ /* * Set the Length parameter */ - OutputStruct->Length = StructSize; + OutputStruct->Length = (UINT32) StructSize; /* * Return the final size of the structure Index: rsutils.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rsutils.c,v retrieving revision 1.1.1.9 diff -u -r1.1.1.9 rsutils.c --- rsutils.c 23 Feb 2002 05:10:40 -0000 1.1.1.9 +++ rsutils.c 1 Jul 2002 21:39:53 -0000 @@ -149,7 +149,7 @@ ACPI_HANDLE Handle, ACPI_BUFFER *RetBuffer) { - ACPI_OPERAND_OBJECT *RetObj; + ACPI_OPERAND_OBJECT *ObjDesc; ACPI_STATUS Status; @@ -161,13 +161,13 @@ /* * Execute the method, no parameters */ - Status = AcpiNsEvaluateRelative (Handle, "_PRT", NULL, &RetObj); + Status = AcpiNsEvaluateRelative (Handle, "_PRT", NULL, &ObjDesc); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); } - if (!RetObj) + if (!ObjDesc) { /* Return object is required */ @@ -176,14 +176,14 @@ } /* - * The return object will be a package, so check the parameters. If the + * The return object must be a package, so check the parameters. If the * return object is not a package, then the underlying AML code is corrupt * or improperly written. */ - if (ACPI_TYPE_PACKAGE != RetObj->Common.Type) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_PACKAGE) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "_PRT did not return a Package, returned %s\n", - AcpiUtGetTypeName (RetObj->Common.Type))); + AcpiUtGetObjectTypeName (ObjDesc))); Status = AE_AML_OPERAND_TYPE; goto Cleanup; } @@ -192,13 +192,13 @@ * Create a resource linked list from the byte stream buffer that comes * back from the _CRS method execution. */ - Status = AcpiRsCreatePciRoutingTable (RetObj, RetBuffer); + Status = AcpiRsCreatePciRoutingTable (ObjDesc, RetBuffer); /* On exit, we must delete the object returned by EvaluateObject */ Cleanup: - AcpiUtRemoveReference (RetObj); + AcpiUtRemoveReference (ObjDesc); return_ACPI_STATUS (Status); } @@ -226,7 +226,7 @@ ACPI_HANDLE Handle, ACPI_BUFFER *RetBuffer) { - ACPI_OPERAND_OBJECT *RetObj; + ACPI_OPERAND_OBJECT *ObjDesc; ACPI_STATUS Status; @@ -238,13 +238,13 @@ /* * Execute the method, no parameters */ - Status = AcpiNsEvaluateRelative (Handle, "_CRS", NULL, &RetObj); + Status = AcpiNsEvaluateRelative (Handle, "_CRS", NULL, &ObjDesc); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); } - if (!RetObj) + if (!ObjDesc) { /* Return object is required */ @@ -258,10 +258,10 @@ * then the underlying AML code is corrupt or improperly * written. */ - if (ACPI_TYPE_BUFFER != RetObj->Common.Type) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_BUFFER) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "_CRS did not return a Buffer, returned %s\n", - AcpiUtGetTypeName (RetObj->Common.Type))); + AcpiUtGetObjectTypeName (ObjDesc))); Status = AE_AML_OPERAND_TYPE; goto Cleanup; } @@ -271,13 +271,13 @@ * byte stream buffer that comes back from the _CRS method * execution. */ - Status = AcpiRsCreateResourceList (RetObj, RetBuffer); + Status = AcpiRsCreateResourceList (ObjDesc, RetBuffer); /* On exit, we must delete the object returned by evaluateObject */ Cleanup: - AcpiUtRemoveReference (RetObj); + AcpiUtRemoveReference (ObjDesc); return_ACPI_STATUS (Status); } @@ -305,7 +305,7 @@ ACPI_HANDLE Handle, ACPI_BUFFER *RetBuffer) { - ACPI_OPERAND_OBJECT *RetObj; + ACPI_OPERAND_OBJECT *ObjDesc; ACPI_STATUS Status; @@ -317,13 +317,13 @@ /* * Execute the method, no parameters */ - Status = AcpiNsEvaluateRelative (Handle, "_PRS", NULL, &RetObj); + Status = AcpiNsEvaluateRelative (Handle, "_PRS", NULL, &ObjDesc); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); } - if (!RetObj) + if (!ObjDesc) { /* Return object is required */ @@ -337,10 +337,10 @@ * then the underlying AML code is corrupt or improperly * written.. */ - if (ACPI_TYPE_BUFFER != RetObj->Common.Type) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_BUFFER) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "_PRS did not return a Buffer, returned %s\n", - AcpiUtGetTypeName (RetObj->Common.Type))); + AcpiUtGetObjectTypeName (ObjDesc))); Status = AE_AML_OPERAND_TYPE; goto Cleanup; } @@ -350,13 +350,13 @@ * byte stream buffer that comes back from the _CRS method * execution. */ - Status = AcpiRsCreateResourceList (RetObj, RetBuffer); + Status = AcpiRsCreateResourceList (ObjDesc, RetBuffer); /* On exit, we must delete the object returned by evaluateObject */ Cleanup: - AcpiUtRemoveReference (RetObj); + AcpiUtRemoveReference (ObjDesc); return_ACPI_STATUS (Status); } @@ -421,8 +421,9 @@ /* * Set up the parameter object */ - Params[0]->Buffer.Length = Buffer.Length; + Params[0]->Buffer.Length = (UINT32) Buffer.Length; Params[0]->Buffer.Pointer = Buffer.Pointer; + Params[0]->Common.Flags = AOPOBJ_DATA_VALID; Params[1] = NULL; /* Index: rsxface.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/rsxface.c,v retrieving revision 1.1.1.7 diff -u -r1.1.1.7 rsxface.c --- rsxface.c 23 Feb 2002 05:10:40 -0000 1.1.1.7 +++ rsxface.c 1 Jul 2002 21:39:53 -0000 @@ -118,8 +118,6 @@ #define __RSXFACE_C__ #include "acpi.h" -#include "acinterp.h" -#include "acnamesp.h" #include "acresrc.h" #define _COMPONENT ACPI_RESOURCES Index: tbconvrt.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/tbconvrt.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 tbconvrt.c --- tbconvrt.c 23 Feb 2002 05:10:40 -0000 1.1.1.11 +++ tbconvrt.c 1 Jul 2002 21:39:53 -0000 @@ -147,7 +147,7 @@ ACPI_FUNCTION_ENTRY (); -#ifndef _IA64 +#if ACPI_MACHINE_WIDTH != 64 if (RSDP->Revision < 2) { @@ -186,7 +186,7 @@ ACPI_TABLE_DESC *TableInfo, UINT32 *NumberOfTables) { - UINT32 TableSize; + ACPI_SIZE TableSize; UINT32 i; XSDT_DESCRIPTOR *NewTable; @@ -200,7 +200,7 @@ /* Compute size of the converted XSDT */ - TableSize = (*NumberOfTables * sizeof (UINT64)) + sizeof (ACPI_TABLE_HEADER); + TableSize = ((ACPI_SIZE) *NumberOfTables * sizeof (UINT64)) + sizeof (ACPI_TABLE_HEADER); /* Allocate an XSDT */ @@ -213,7 +213,7 @@ /* Copy the header and set the length */ ACPI_MEMCPY (NewTable, TableInfo->Pointer, sizeof (ACPI_TABLE_HEADER)); - NewTable->Header.Length = TableSize; + NewTable->Header.Length = (UINT32) TableSize; /* Copy the table pointers */ @@ -246,6 +246,176 @@ } + +/******************************************************************************* + * + * FUNCTION: AcpiTbConvertFadt1 + * + * PARAMETERS: LocalFadt - Pointer to new FADT + * OriginalFadt - Pointer to old FADT + * + * RETURN: Populates LocalFadt + * + * DESCRIPTION: Convert an ACPI 1.0 FADT to common internal format + * + ******************************************************************************/ + +static void +AcpiTbConvertFadt1 ( + FADT_DESCRIPTOR_REV2 *LocalFadt, + FADT_DESCRIPTOR_REV1 *OriginalFadt) +{ + + + /* ACPI 1.0 FACS */ + /* The BIOS stored FADT should agree with Revision 1.0 */ + + /* + * Copy the table header and the common part of the tables. + * + * The 2.0 table is an extension of the 1.0 table, so the entire 1.0 + * table can be copied first, then expand some fields to 64 bits. + */ + ACPI_MEMCPY (LocalFadt, OriginalFadt, sizeof (FADT_DESCRIPTOR_REV1)); + + /* Convert table pointers to 64-bit fields */ + + ACPI_STORE_ADDRESS (LocalFadt->XFirmwareCtrl, LocalFadt->V1_FirmwareCtrl); + ACPI_STORE_ADDRESS (LocalFadt->XDsdt, LocalFadt->V1_Dsdt); + + /* + * System Interrupt Model isn't used in ACPI 2.0 (LocalFadt->Reserved1 = 0;) + */ + + /* + * This field is set by the OEM to convey the preferred power management + * profile to OSPM. It doesn't have any 1.0 equivalence. Since we don't + * know what kind of 32-bit system this is, we will use "unspecified". + */ + LocalFadt->Prefer_PM_Profile = PM_UNSPECIFIED; + + /* + * Processor Performance State Control. This is the value OSPM writes to + * the SMI_CMD register to assume processor performance state control + * responsibility. There isn't any equivalence in 1.0, leave it zeroed. + */ + LocalFadt->PstateCnt = 0; + + /* + * Support for the _CST object and C States change notification. + * This data item hasn't any 1.0 equivalence so leave it zero. + */ + LocalFadt->CstCnt = 0; + + /* + * Since there isn't any equivalence in 1.0 and since it highly likely + * that a 1.0 system has legacy support. + */ + LocalFadt->IapcBootArch = BAF_LEGACY_DEVICES; + + /* + * Convert the V1.0 block addresses to V2.0 GAS structures + */ + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPm1aEvtBlk, LocalFadt->Pm1EvtLen, LocalFadt->V1_Pm1aEvtBlk); + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPm1bEvtBlk, LocalFadt->Pm1EvtLen, LocalFadt->V1_Pm1bEvtBlk); + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPm1aCntBlk, LocalFadt->Pm1CntLen, LocalFadt->V1_Pm1aCntBlk); + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPm1bCntBlk, LocalFadt->Pm1CntLen, LocalFadt->V1_Pm1bCntBlk); + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPm2CntBlk, LocalFadt->Pm2CntLen, LocalFadt->V1_Pm2CntBlk); + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPmTmrBlk, LocalFadt->PmTmLen, LocalFadt->V1_PmTmrBlk); + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XGpe0Blk, LocalFadt->Gpe0BlkLen, LocalFadt->V1_Gpe0Blk); + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XGpe1Blk, LocalFadt->Gpe1BlkLen, LocalFadt->V1_Gpe1Blk); + +} + + +/******************************************************************************* + * + * FUNCTION: AcpiTbConvertFadt2 + * + * PARAMETERS: LocalFadt - Pointer to new FADT + * OriginalFadt - Pointer to old FADT + * + * RETURN: Populates LocalFadt + * + * DESCRIPTION: Convert an ACPI 2.0 FADT to common internal format. + * Handles optional "X" fields. + * + ******************************************************************************/ + +static void +AcpiTbConvertFadt2 ( + FADT_DESCRIPTOR_REV2 *LocalFadt, + FADT_DESCRIPTOR_REV2 *OriginalFadt) +{ + + /* We have an ACPI 2.0 FADT but we must copy it to our local buffer */ + + ACPI_MEMCPY (LocalFadt, OriginalFadt, sizeof (FADT_DESCRIPTOR_REV2)); + + /* + * "X" fields are optional extensions to the original V1.0 fields, so + * we must selectively expand V1.0 fields if the corresponding X field + * is zero. + */ + if (!(ACPI_GET_ADDRESS (LocalFadt->XFirmwareCtrl))) + { + ACPI_STORE_ADDRESS (LocalFadt->XFirmwareCtrl, LocalFadt->V1_FirmwareCtrl); + } + + if (!(ACPI_GET_ADDRESS (LocalFadt->XDsdt))) + { + ACPI_STORE_ADDRESS (LocalFadt->XDsdt, LocalFadt->V1_Dsdt); + } + + if (!(ACPI_GET_ADDRESS (LocalFadt->XPm1aEvtBlk.Address))) + { + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPm1aEvtBlk, + LocalFadt->Pm1EvtLen, LocalFadt->V1_Pm1aEvtBlk); + } + + if (!(ACPI_GET_ADDRESS (LocalFadt->XPm1bEvtBlk.Address))) + { + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPm1bEvtBlk, + LocalFadt->Pm1EvtLen, LocalFadt->V1_Pm1bEvtBlk); + } + + if (!(ACPI_GET_ADDRESS (LocalFadt->XPm1aCntBlk.Address))) + { + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPm1aCntBlk, + LocalFadt->Pm1CntLen, LocalFadt->V1_Pm1aCntBlk); + } + + if (!(ACPI_GET_ADDRESS (LocalFadt->XPm1bCntBlk.Address))) + { + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPm1bCntBlk, + LocalFadt->Pm1CntLen, LocalFadt->V1_Pm1bCntBlk); + } + + if (!(ACPI_GET_ADDRESS (LocalFadt->XPm2CntBlk.Address))) + { + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPm2CntBlk, + LocalFadt->Pm2CntLen, LocalFadt->V1_Pm2CntBlk); + } + + if (!(ACPI_GET_ADDRESS (LocalFadt->XPmTmrBlk.Address))) + { + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XPmTmrBlk, + LocalFadt->PmTmLen, LocalFadt->V1_PmTmrBlk); + } + + if (!(ACPI_GET_ADDRESS (LocalFadt->XGpe0Blk.Address))) + { + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XGpe0Blk, + LocalFadt->Gpe0BlkLen, LocalFadt->V1_Gpe0Blk); + } + + if (!(ACPI_GET_ADDRESS (LocalFadt->XGpe1Blk.Address))) + { + ASL_BUILD_GAS_FROM_V1_ENTRY (LocalFadt->XGpe1Blk, + LocalFadt->Gpe1BlkLen, LocalFadt->V1_Gpe1Blk); + } +} + /******************************************************************************* * * FUNCTION: AcpiTbConvertTableFadt @@ -267,8 +437,7 @@ ACPI_STATUS AcpiTbConvertTableFadt (void) { - FADT_DESCRIPTOR_REV1 *FADT1; - FADT_DESCRIPTOR_REV2 *FADT2; + FADT_DESCRIPTOR_REV2 *LocalFadt; ACPI_TABLE_DESC *TableDesc; @@ -279,100 +448,51 @@ * AcpiGbl_FADT is valid * Allocate and zero the 2.0 FADT buffer */ - FADT2 = ACPI_MEM_CALLOCATE (sizeof (FADT_DESCRIPTOR_REV2)); - if (FADT2 == NULL) + LocalFadt = ACPI_MEM_CALLOCATE (sizeof (FADT_DESCRIPTOR_REV2)); + if (LocalFadt == NULL) { return_ACPI_STATUS (AE_NO_MEMORY); } - + /* - * The ACPI FADT revision number is FADT2_REVISION_ID=3 - * So, if the current table revision is less than 3 it is type 1.0 + * FADT length and version validation. The table must be at least as + * long as the version 1.0 FADT */ + if (AcpiGbl_FADT->Header.Length < sizeof (FADT_DESCRIPTOR_REV1)) + { + ACPI_REPORT_ERROR (("Invalid FADT table length: 0x%X\n", AcpiGbl_FADT->Header.Length)); + return_ACPI_STATUS (AE_INVALID_TABLE_LENGTH); + } + if (AcpiGbl_FADT->Header.Revision >= FADT2_REVISION_ID) { - /* We have an ACPI 2.0 FADT but we must copy it to our local buffer */ + if (AcpiGbl_FADT->Header.Length < sizeof (FADT_DESCRIPTOR_REV2)) + { + /* Length is too short to be a V2.0 table */ - *FADT2 = *((FADT_DESCRIPTOR_REV2*) AcpiGbl_FADT); + ACPI_REPORT_WARNING (("Inconsistent FADT length (0x%X) and revision (0x%X), using FADT V1.0 portion of table\n", + AcpiGbl_FADT->Header.Length, AcpiGbl_FADT->Header.Revision)); + + AcpiTbConvertFadt1 (LocalFadt, (void *) AcpiGbl_FADT); + } + else + { + /* Valid V2.0 table */ + + AcpiTbConvertFadt2 (LocalFadt, AcpiGbl_FADT); + } } else { - /* ACPI 1.0 FACS */ - - /* The BIOS stored FADT should agree with Revision 1.0 */ + /* Valid V1.0 table */ - FADT1 = (FADT_DESCRIPTOR_REV1*) AcpiGbl_FADT; - - /* - * Copy the table header and the common part of the tables. - * - * The 2.0 table is an extension of the 1.0 table, so the entire 1.0 - * table can be copied first, then expand some fields to 64 bits. - */ - ACPI_MEMCPY (FADT2, FADT1, sizeof (FADT_DESCRIPTOR_REV1)); - - /* Convert table pointers to 64-bit fields */ - - ACPI_STORE_ADDRESS (FADT2->XFirmwareCtrl, FADT1->FirmwareCtrl); - ACPI_STORE_ADDRESS (FADT2->XDsdt, FADT1->Dsdt); - - /* - * System Interrupt Model isn't used in ACPI 2.0 (FADT2->Reserved1 = 0;) - */ - - /* - * This field is set by the OEM to convey the preferred power management - * profile to OSPM. It doesn't have any 1.0 equivalence. Since we don't - * know what kind of 32-bit system this is, we will use "unspecified". - */ - FADT2->Prefer_PM_Profile = PM_UNSPECIFIED; - - /* - * Processor Performance State Control. This is the value OSPM writes to - * the SMI_CMD register to assume processor performance state control - * responsibility. There isn't any equivalence in 1.0, leave it zeroed. - */ - FADT2->PstateCnt = 0; - - /* - * Support for the _CST object and C States change notification. - * This data item hasn't any 1.0 equivalence so leave it zero. - */ - FADT2->CstCnt = 0; - - /* - * Since there isn't any equivalence in 1.0 and since it highly likely - * that a 1.0 system has legacy support. - */ - FADT2->IapcBootArch = BAF_LEGACY_DEVICES; - - /* - * Convert the V1.0 block addresses to V2.0 GAS structures - * in this order: - * - * PM 1A Events - * PM 1B Events - * PM 1A Control - * PM 1B Control - * PM 2 Control - * PM Timer Control - * GPE Block 0 - * GPE Block 1 - */ - ASL_BUILD_GAS_FROM_V1_ENTRY (FADT2->XPm1aEvtBlk, FADT1->Pm1EvtLen, FADT1->Pm1aEvtBlk); - ASL_BUILD_GAS_FROM_V1_ENTRY (FADT2->XPm1bEvtBlk, FADT1->Pm1EvtLen, FADT1->Pm1bEvtBlk); - ASL_BUILD_GAS_FROM_V1_ENTRY (FADT2->XPm1aCntBlk, FADT1->Pm1CntLen, FADT1->Pm1aCntBlk); - ASL_BUILD_GAS_FROM_V1_ENTRY (FADT2->XPm1bCntBlk, FADT1->Pm1CntLen, FADT1->Pm1bCntBlk); - ASL_BUILD_GAS_FROM_V1_ENTRY (FADT2->XPm2CntBlk, FADT1->Pm2CntLen, FADT1->Pm2CntBlk); - ASL_BUILD_GAS_FROM_V1_ENTRY (FADT2->XPmTmrBlk, FADT1->PmTmLen, FADT1->PmTmrBlk); - ASL_BUILD_GAS_FROM_V1_ENTRY (FADT2->XGpe0Blk, FADT1->Gpe0BlkLen, FADT1->Gpe0Blk); - ASL_BUILD_GAS_FROM_V1_ENTRY (FADT2->XGpe1Blk, FADT1->Gpe1BlkLen, FADT1->Gpe1Blk); + AcpiTbConvertFadt1 (LocalFadt, (void *) AcpiGbl_FADT); } /* - * Global FADT pointer will point to the common V2.0 FADT + * Global FADT pointer will point to the new common V2.0 FADT */ - AcpiGbl_FADT = FADT2; + AcpiGbl_FADT = LocalFadt; AcpiGbl_FADT->Header.Length = sizeof (FADT_DESCRIPTOR); /* Free the original table */ @@ -382,10 +502,10 @@ /* Install the new table */ - TableDesc->Pointer = (ACPI_TABLE_HEADER *) AcpiGbl_FADT; - TableDesc->BasePointer = AcpiGbl_FADT; - TableDesc->Allocation = ACPI_MEM_ALLOCATED; - TableDesc->Length = sizeof (FADT_DESCRIPTOR_REV2); + TableDesc->Pointer = (ACPI_TABLE_HEADER *) AcpiGbl_FADT; + TableDesc->BasePointer = AcpiGbl_FADT; + TableDesc->Allocation = ACPI_MEM_ALLOCATED; + TableDesc->Length = sizeof (FADT_DESCRIPTOR_REV2); /* Dump the entire FADT */ @@ -415,37 +535,46 @@ AcpiTbBuildCommonFacs ( ACPI_TABLE_DESC *TableInfo) { - FACS_DESCRIPTOR_REV1 *FACS1; - FACS_DESCRIPTOR_REV2 *FACS2; - ACPI_FUNCTION_TRACE ("TbBuildCommonFacs"); - /* Copy fields to the new FACS */ + /* Absolute minimum length is 24, but the ACPI spec says 64 */ - if (AcpiGbl_RSDP->Revision < 2) + if (AcpiGbl_FACS->Length < 24) { - /* ACPI 1.0 FACS */ + ACPI_REPORT_ERROR (("Invalid FACS table length: 0x%X\n", AcpiGbl_FACS->Length)); + return_ACPI_STATUS (AE_INVALID_TABLE_LENGTH); + } - FACS1 = (FACS_DESCRIPTOR_REV1 *) AcpiGbl_FACS; + if (AcpiGbl_FACS->Length < 64) + { + ACPI_REPORT_WARNING (("FACS is shorter than the ACPI specification allows: 0x%X, using anyway\n", + AcpiGbl_FACS->Length)); + } - AcpiGbl_CommonFACS.GlobalLock = &(FACS1->GlobalLock); - AcpiGbl_CommonFACS.FirmwareWakingVector = (UINT64 *) &FACS1->FirmwareWakingVector; + /* Copy fields to the new FACS */ + + AcpiGbl_CommonFACS.GlobalLock = &(AcpiGbl_FACS->GlobalLock); + + if ((AcpiGbl_RSDP->Revision < 2) || + (AcpiGbl_FACS->Length < 32) || + (!(ACPI_GET_ADDRESS (AcpiGbl_FACS->XFirmwareWakingVector)))) + { + /* ACPI 1.0 FACS or short table or optional X_ field is zero */ + + AcpiGbl_CommonFACS.FirmwareWakingVector = ACPI_CAST_PTR (UINT64, &(AcpiGbl_FACS->FirmwareWakingVector)); AcpiGbl_CommonFACS.VectorWidth = 32; } else { - /* ACPI 2.0 FACS */ - - FACS2 = (FACS_DESCRIPTOR_REV2 *) AcpiGbl_FACS; + /* ACPI 2.0 FACS with valid X_ field */ - AcpiGbl_CommonFACS.GlobalLock = &(FACS2->GlobalLock); - AcpiGbl_CommonFACS.FirmwareWakingVector = &FACS2->XFirmwareWakingVector; + AcpiGbl_CommonFACS.FirmwareWakingVector = &AcpiGbl_FACS->XFirmwareWakingVector; AcpiGbl_CommonFACS.VectorWidth = 64; } - return_ACPI_STATUS (AE_OK); + return_ACPI_STATUS (AE_OK); } Index: tbget.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/tbget.c,v retrieving revision 1.5 diff -u -r1.5 tbget.c --- tbget.c 30 Jun 2002 17:53:04 -0000 1.5 +++ tbget.c 1 Jul 2002 21:39:53 -0000 @@ -126,6 +126,128 @@ /******************************************************************************* * + * FUNCTION: AcpiTbTableOverride + * + * PARAMETERS: *TableInfo - Info for current table + * + * RETURN: None + * + * DESCRIPTION: Attempts override of current table with a new one if provided + * by the host OS. + * + ******************************************************************************/ + +void +AcpiTbTableOverride ( + ACPI_TABLE_DESC *TableInfo) +{ + ACPI_TABLE_HEADER *NewTable; + ACPI_STATUS Status; + ACPI_POINTER Address; + ACPI_TABLE_DESC NewTableInfo; + + + ACPI_FUNCTION_TRACE ("AcpiTbTableOverride"); + + + Status = AcpiOsTableOverride (TableInfo->Pointer, &NewTable); + if (ACPI_FAILURE (Status)) + { + /* Some severe error from the OSL, but we basically ignore it */ + + ACPI_REPORT_ERROR (("Could not override ACPI table, %s\n", + AcpiFormatException (Status))); + return_VOID; + } + + if (!NewTable) + { + /* No table override */ + + return_VOID; + } + + /* + * We have a new table to override the old one. Get a copy of + * the new one. We know that the new table has a logical pointer. + */ + Address.PointerType = ACPI_LOGICAL_POINTER; + Address.Pointer.Logical = NewTable; + + Status = AcpiTbGetTable (&Address, &NewTableInfo); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("Could not copy ACPI table override\n")); + return_VOID; + } + + /* + * Delete the original table + */ + AcpiTbDeleteSingleTable (TableInfo); + + /* Copy the table info */ + + ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "Successful table override [%4.4s]\n", + ((ACPI_TABLE_HEADER *) NewTableInfo.Pointer)->Signature)); + + ACPI_MEMCPY (TableInfo, &NewTableInfo, sizeof (ACPI_TABLE_DESC)); + return_VOID; +} + + +/******************************************************************************* + * + * FUNCTION: AcpiTbGetTableWithOverride + * + * PARAMETERS: Address - Physical or logical address of table + * *TableInfo - Where the table info is returned + * + * RETURN: Status + * + * DESCRIPTION: Gets and installs the table with possible table override by OS. + * + ******************************************************************************/ + +ACPI_STATUS +AcpiTbGetTableWithOverride ( + ACPI_POINTER *Address, + ACPI_TABLE_DESC *TableInfo) +{ + ACPI_STATUS Status; + + + ACPI_FUNCTION_TRACE ("AcpiTbGetTableWithOverride"); + + + Status = AcpiTbGetTable (Address, TableInfo); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("Could not get ACPI table, %s\n", + AcpiFormatException (Status))); + return_ACPI_STATUS (Status); + } + + /* + * Attempt override. It either happens or it doesn't, no status + */ + AcpiTbTableOverride (TableInfo); + + /* Install the table */ + + Status = AcpiTbInstallTable (TableInfo); + if (ACPI_FAILURE (Status)) + { + ACPI_REPORT_ERROR (("Could not install ACPI table, %s\n", + AcpiFormatException (Status))); + } + + return_ACPI_STATUS (Status); +} + + +/******************************************************************************* + * * FUNCTION: AcpiTbGetTablePtr * * PARAMETERS: TableType - one of the defined table types @@ -209,10 +331,8 @@ * * FUNCTION: AcpiTbGetTable * - * PARAMETERS: PhysicalAddress - Physical address of table to retrieve - * *BufferPtr - If BufferPtr is valid, read data from - * buffer rather than searching memory - * *TableInfo - Where the table info is returned + * PARAMETERS: Address - Physical address of table to retrieve + * *TableInfo - Where the table info is returned * * RETURN: Status * @@ -227,7 +347,7 @@ { ACPI_TABLE_HEADER *TableHeader = NULL; ACPI_TABLE_HEADER *FullTable = NULL; - UINT32 Size; + ACPI_SIZE Size; UINT8 Allocation; ACPI_STATUS Status = AE_OK; @@ -259,7 +379,7 @@ /* Copy the entire table (including header) to the local buffer */ - Size = TableHeader->Length; + Size = (ACPI_SIZE) TableHeader->Length; ACPI_MEMCPY (FullTable, TableHeader, Size); /* Save allocation type */ @@ -314,7 +434,6 @@ * FUNCTION: AcpiTbGetAllTables * * PARAMETERS: NumberOfTables - Number of tables to get - * TablePtr - Input buffer pointer, optional * * RETURN: Status * @@ -331,8 +450,7 @@ ACPI_STATUS AcpiTbGetAllTables ( - UINT32 NumberOfTables, - ACPI_TABLE_HEADER *TablePtr) + UINT32 NumberOfTables) { ACPI_STATUS Status = AE_OK; UINT32 Index; @@ -371,7 +489,7 @@ /* Recognize and install the table */ - Status = AcpiTbInstallTable (TablePtr, &TableInfo); + Status = AcpiTbInstallTable (&TableInfo); if (ACPI_FAILURE (Status)) { /* @@ -379,11 +497,17 @@ * error. Just get as many tables as we can, later we will * determine if there are enough tables to continue. */ - AcpiTbUninstallTable (&TableInfo); + (void) AcpiTbUninstallTable (&TableInfo); Status = AE_OK; } } + if (!AcpiGbl_FADT) + { + ACPI_REPORT_ERROR (("No FADT present in R/XSDT\n")); + return_ACPI_STATUS (AE_NO_ACPI_TABLES); + } + /* * Convert the FADT to a common format. This allows earlier revisions of the * table to coexist with newer versions, using common access code. @@ -405,16 +529,18 @@ Status = AcpiTbGetTable (&Address, &TableInfo); if (ACPI_FAILURE (Status)) { - ACPI_REPORT_ERROR (("Could not get the FACS\n")); + ACPI_REPORT_ERROR (("Could not get the FACS, %s\n", + AcpiFormatException (Status))); return_ACPI_STATUS (Status); } /* Install the FACS */ - Status = AcpiTbInstallTable (TablePtr, &TableInfo); + Status = AcpiTbInstallTable (&TableInfo); if (ACPI_FAILURE (Status)) { - ACPI_REPORT_ERROR (("Could not install the FACS\n")); + ACPI_REPORT_ERROR (("Could not install the FACS, %s\n", + AcpiFormatException (Status))); return_ACPI_STATUS (Status); } @@ -425,42 +551,31 @@ Status = AcpiTbBuildCommonFacs (&TableInfo); if (ACPI_FAILURE (Status)) { - ACPI_REPORT_ERROR (("Could not convert FACS to common internal format\n")); return_ACPI_STATUS (Status); } /* - * Get the DSDT (We know that the FADT is valid now) + * Get/install the DSDT (We know that the FADT is valid now) */ Address.PointerType = AcpiGbl_TableFlags; Address.Pointer.Value = ACPI_GET_ADDRESS (AcpiGbl_FADT->XDsdt); - if (AcpiGbl_DSDT != NULL) - { - Address.PointerType = ACPI_LOGICAL_POINTER; - Address.Pointer.Value = ACPI_GET_ADDRESS ((NATIVE_UINT)AcpiGbl_DSDT); - } - Status = AcpiTbGetTable (&Address, &TableInfo); + Status = AcpiTbGetTableWithOverride (&Address, &TableInfo); if (ACPI_FAILURE (Status)) { ACPI_REPORT_ERROR (("Could not get the DSDT\n")); return_ACPI_STATUS (Status); } - /* Install the DSDT */ + /* Set Integer Width (32/64) based upon DSDT revision */ - Status = AcpiTbInstallTable (TablePtr, &TableInfo); - if (ACPI_FAILURE (Status)) - { - ACPI_REPORT_ERROR (("Could not install the DSDT\n")); - return_ACPI_STATUS (Status); - } + AcpiUtSetIntegerWidth (AcpiGbl_DSDT->Revision); /* Dump the entire DSDT */ ACPI_DEBUG_PRINT ((ACPI_DB_TABLES, - "Hex dump of entire DSDT, size %d (0x%X)\n", - AcpiGbl_DSDT->Length, AcpiGbl_DSDT->Length)); + "Hex dump of entire DSDT, size %d (0x%X), Integer width = %d\n", + AcpiGbl_DSDT->Length, AcpiGbl_DSDT->Length, AcpiGbl_IntegerBitWidth)); ACPI_DUMP_BUFFER ((UINT8 *) AcpiGbl_DSDT, AcpiGbl_DSDT->Length); /* Always delete the RSDP mapping, we are done with it */ @@ -549,7 +664,7 @@ /* The RSDP supplied is OK */ - TableInfo.Pointer = (ACPI_TABLE_HEADER *) Rsdp; + TableInfo.Pointer = ACPI_CAST_PTR (ACPI_TABLE_HEADER, Rsdp); TableInfo.Length = sizeof (RSDP_DESCRIPTOR); TableInfo.Allocation = ACPI_MEM_MAPPED; TableInfo.BasePointer = Rsdp; @@ -564,7 +679,7 @@ /* Save the RSDP in a global for easy access */ - AcpiGbl_RSDP = (RSDP_DESCRIPTOR *) TableInfo.Pointer; + AcpiGbl_RSDP = ACPI_CAST_PTR (RSDP_DESCRIPTOR, TableInfo.Pointer); return_ACPI_STATUS (Status); @@ -633,7 +748,7 @@ AcpiTbValidateRsdt ( ACPI_TABLE_HEADER *TablePtr) { - UINT32 NoMatch; + int NoMatch; ACPI_FUNCTION_NAME ("TbValidateRsdt"); @@ -663,8 +778,9 @@ ACPI_DUMP_BUFFER (AcpiGbl_RSDP, 20); ACPI_DEBUG_PRINT_RAW ((ACPI_DB_ERROR, - "RSDT/XSDT signature at %X is invalid\n", - AcpiGbl_RSDP->RsdtPhysicalAddress)); + "RSDT/XSDT signature at %X (%p) is invalid\n", + AcpiGbl_RSDP->RsdtPhysicalAddress, + (void *) (NATIVE_UINT) AcpiGbl_RSDP->RsdtPhysicalAddress)); return (AE_BAD_SIGNATURE); } @@ -691,7 +807,7 @@ AcpiTbGetTablePointer ( ACPI_POINTER *Address, UINT32 Flags, - UINT32 *Size, + ACPI_SIZE *Size, ACPI_TABLE_HEADER **TablePtr) { ACPI_STATUS Status = AE_OK; @@ -720,6 +836,9 @@ *TablePtr = Address->Pointer.Logical; *Size = 0; break; + + default: + return (AE_BAD_PARAMETER); } } else @@ -737,6 +856,9 @@ Status = AE_BAD_PARAMETER; break; + + default: + return (AE_BAD_PARAMETER); } } @@ -768,26 +890,22 @@ ACPI_FUNCTION_TRACE ("TbGetTableRsdt"); - /* - * Get the RSDT from the RSDP - */ - ACPI_DEBUG_PRINT ((ACPI_DB_INFO, - "RSDP located at %p, RSDT physical=%8.8X%8.8X \n", - AcpiGbl_RSDP, - ACPI_HIDWORD (AcpiGbl_RSDP->RsdtPhysicalAddress), - ACPI_LODWORD (AcpiGbl_RSDP->RsdtPhysicalAddress))); - - - /* Get the RSDT/XSDT */ + /* Get the RSDT/XSDT from the RSDP */ AcpiTbGetRsdtAddress (&Address); Status = AcpiTbGetTable (&Address, &TableInfo); if (ACPI_FAILURE (Status)) { - ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Could not get the RSDT, %s\n", + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Could not get the R/XSDT, %s\n", AcpiFormatException (Status))); return_ACPI_STATUS (Status); } + + ACPI_DEBUG_PRINT ((ACPI_DB_INFO, + "RSDP located at %p, RSDT physical=%8.8X%8.8X \n", + AcpiGbl_RSDP, + ACPI_HIDWORD (Address.Pointer.Value), + ACPI_LODWORD (Address.Pointer.Value))); /* Check the RSDT or XSDT signature */ Index: tbinstal.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/tbinstal.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 tbinstal.c --- tbinstal.c 30 Jun 2002 17:50:46 -0000 1.1.1.14 +++ tbinstal.c 1 Jul 2002 21:39:53 -0000 @@ -180,8 +180,7 @@ * * FUNCTION: AcpiTbInstallTable * - * PARAMETERS: TablePtr - Input buffer pointer, optional - * TableInfo - Return value from AcpiTbGetTable + * PARAMETERS: TableInfo - Return value from AcpiTbGetTable * * RETURN: Status * @@ -193,7 +192,6 @@ ACPI_STATUS AcpiTbInstallTable ( - ACPI_TABLE_HEADER *TablePtr, ACPI_TABLE_DESC *TableInfo) { ACPI_STATUS Status; @@ -205,7 +203,7 @@ * Check the table signature and make sure it is recognized * Also checks the header checksum */ - Status = AcpiTbRecognizeTable (TablePtr, TableInfo); + Status = AcpiTbRecognizeTable (TableInfo); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); @@ -235,8 +233,7 @@ * * FUNCTION: AcpiTbRecognizeTable * - * PARAMETERS: TablePtr - Input buffer pointer, optional - * TableInfo - Return value from AcpiTbGetTable + * PARAMETERS: TableInfo - Return value from AcpiTbGetTable * * RETURN: Status * @@ -254,7 +251,6 @@ ACPI_STATUS AcpiTbRecognizeTable ( - ACPI_TABLE_HEADER *TablePtr, ACPI_TABLE_DESC *TableInfo) { ACPI_TABLE_HEADER *TableHeader; @@ -294,7 +290,7 @@ /* Return the table type and length via the info struct */ - TableInfo->Length = TableHeader->Length; + TableInfo->Length = (ACPI_SIZE) TableHeader->Length; /* * Validate checksum for _most_ tables, @@ -303,13 +299,15 @@ if (TableInfo->Type != ACPI_TABLE_FACS) { Status = AcpiTbVerifyTableChecksum (TableHeader); - if (ACPI_FAILURE (Status) && - (!ACPI_CHECKSUM_ABORT)) + +#if (!ACPI_CHECKSUM_ABORT) + if (ACPI_FAILURE (Status)) { /* Ignore the error if configuration says so */ Status = AE_OK; } +#endif } return_ACPI_STATUS (Status); @@ -615,6 +613,9 @@ AcpiOsUnmapMemory (TableDesc->BasePointer, TableDesc->Length); break; + + default: + break; } } } @@ -626,7 +627,7 @@ * * PARAMETERS: TableInfo - A table info struct * - * RETURN: None. + * RETURN: Pointer to the next table in the list (of same type) * * DESCRIPTION: Free the memory associated with an internal ACPI table that * is either installed or has never been installed. @@ -641,7 +642,7 @@ ACPI_TABLE_DESC *NextDesc; - ACPI_FUNCTION_TRACE_PTR ("TbDeleteSingleTable", TableDesc); + ACPI_FUNCTION_TRACE_PTR ("AcpiTbUninstallTable", TableDesc); if (!TableDesc) Index: tbutils.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/tbutils.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 tbutils.c --- tbutils.c 30 Jun 2002 17:50:46 -0000 1.1.1.13 +++ tbutils.c 1 Jul 2002 21:39:53 -0000 @@ -118,7 +118,6 @@ #include "acpi.h" #include "actables.h" -#include "acinterp.h" #define _COMPONENT ACPI_TABLES @@ -187,7 +186,7 @@ * name * 3) Table must be readable for length specified in the header * 4) Table checksum must be valid (with the exception of the FACS - * which has no checksum for some odd reason) + * which has no checksum because it contains variable fields) * ******************************************************************************/ @@ -212,7 +211,7 @@ /* Ensure that the signature is 4 ASCII characters */ - ACPI_MOVE_UNALIGNED32_TO_32 (&Signature, &TableHeader->Signature); + ACPI_MOVE_UNALIGNED32_TO_32 (&Signature, TableHeader->Signature); if (!AcpiUtValidAcpiName (Signature)) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, @@ -260,11 +259,11 @@ ACPI_STATUS AcpiTbMapAcpiTable ( ACPI_PHYSICAL_ADDRESS PhysicalAddress, - UINT32 *Size, + ACPI_SIZE *Size, ACPI_TABLE_HEADER **LogicalAddress) { ACPI_TABLE_HEADER *Table; - UINT32 TableSize = *Size; + ACPI_SIZE TableSize = *Size; ACPI_STATUS Status = AE_OK; @@ -286,24 +285,29 @@ /* Extract the full table length before we delete the mapping */ - TableSize = Table->Length; + TableSize = (ACPI_SIZE) Table->Length; +#if 0 +/* We don't want to validate the header here. */ /* * Validate the header and delete the mapping. * We will create a mapping for the full table below. */ Status = AcpiTbValidateTableHeader (Table); +#endif /* Always unmap the memory for the header */ AcpiOsUnmapMemory (Table, sizeof (ACPI_TABLE_HEADER)); +#if 0 /* Exit if header invalid */ if (ACPI_FAILURE (Status)) { return (Status); } +#endif } /* Map the physical memory for the correct length */ @@ -358,7 +362,7 @@ if (Checksum) { ACPI_REPORT_WARNING (("Invalid checksum (%X) in table %4.4s\n", - Checksum, (char *) &TableHeader->Signature)); + Checksum, TableHeader->Signature)); Status = AE_BAD_CHECKSUM; } Index: tbxface.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/tbxface.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 tbxface.c --- tbxface.c 30 Jun 2002 17:50:46 -0000 1.1.1.12 +++ tbxface.c 1 Jul 2002 21:39:53 -0000 @@ -119,7 +119,6 @@ #include "acpi.h" #include "acnamesp.h" -#include "acinterp.h" #include "actables.h" @@ -186,7 +185,7 @@ /* Now get the rest of the tables */ - Status = AcpiTbGetAllTables (NumberOfTables, NULL); + Status = AcpiTbGetAllTables (NumberOfTables); if (ACPI_FAILURE (Status)) { ACPI_REPORT_ERROR (("AcpiLoadTables: Error getting required tables (DSDT/FADT/FACS): %s\n", @@ -264,7 +263,7 @@ /* Install the new table into the local data structures */ - Status = AcpiTbInstallTable (NULL, &TableInfo); + Status = AcpiTbInstallTable (&TableInfo); if (ACPI_FAILURE (Status)) { /* Free table allocated by AcpiTbGetTable */ @@ -298,7 +297,7 @@ { /* Uninstall table and free the buffer */ - AcpiTbUninstallTable (TableInfo.InstalledDesc); + (void) AcpiTbUninstallTable (TableInfo.InstalledDesc); } return_ACPI_STATUS (Status); @@ -466,7 +465,7 @@ { ACPI_TABLE_HEADER *TblPtr; ACPI_STATUS Status; - UINT32 TableLength; + ACPI_SIZE TableLength; ACPI_FUNCTION_TRACE ("AcpiGetTable"); @@ -523,7 +522,7 @@ } else { - TableLength = TblPtr->Length; + TableLength = (ACPI_SIZE) TblPtr->Length; } /* Validate/Allocate/Clear caller buffer */ Index: tbxfroot.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/tbxfroot.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 tbxfroot.c --- tbxfroot.c 30 Jun 2002 17:50:46 -0000 1.1.1.13 +++ tbxfroot.c 1 Jul 2002 21:39:53 -0000 @@ -218,8 +218,8 @@ ACPI_TABLE_HEADER *RsdtPtr = NULL; ACPI_TABLE_HEADER *TablePtr; ACPI_STATUS Status; - UINT32 RsdtSize = 0; - UINT32 TableSize; + ACPI_SIZE RsdtSize = 0; + ACPI_SIZE TableSize; UINT32 TableCount; UINT32 i; UINT32 j; @@ -290,16 +290,16 @@ } } - ACPI_DEBUG_PRINT ((ACPI_DB_INFO, - "RSDP located at %p, RSDT physical=%8.8X%8.8X \n", - AcpiGbl_RSDP, - ACPI_HIDWORD (AcpiGbl_RSDP->RsdtPhysicalAddress), - ACPI_LODWORD (AcpiGbl_RSDP->RsdtPhysicalAddress))); - /* Get the RSDT and validate it */ AcpiTbGetRsdtAddress (&Address); + ACPI_DEBUG_PRINT ((ACPI_DB_INFO, + "RSDP located at %p, RSDT physical=%8.8X%8.8X \n", + AcpiGbl_RSDP, + ACPI_HIDWORD (Address.Pointer.Value), + ACPI_LODWORD (Address.Pointer.Value))); + Status = AcpiTbGetTablePointer (&Address, Flags, &RsdtSize, &RsdtPtr); if (ACPI_FAILURE (Status)) { @@ -385,7 +385,7 @@ /* TBD: Move to a new file */ -#ifndef _IA16 +#if ACPI_MACHINE_WIDTH != 16 /******************************************************************************* * @@ -536,7 +536,7 @@ /* Found it, return the physical address */ PhysAddr = LO_RSDP_WINDOW_BASE; - PhysAddr += (MemRover - TablePtr); + PhysAddr += ACPI_PTR_DIFF (MemRover,TablePtr); TableInfo->PhysicalAddress = PhysAddr; return_ACPI_STATUS (AE_OK); @@ -560,7 +560,7 @@ /* Found it, return the physical address */ PhysAddr = HI_RSDP_WINDOW_BASE; - PhysAddr += (MemRover - TablePtr); + PhysAddr += ACPI_PTR_DIFF (MemRover, TablePtr); TableInfo->PhysicalAddress = PhysAddr; return_ACPI_STATUS (AE_OK); Index: utalloc.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utalloc.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 utalloc.c --- utalloc.c 23 Feb 2002 05:10:40 -0000 1.1.1.13 +++ utalloc.c 1 Jul 2002 21:39:53 -0000 @@ -117,10 +117,6 @@ #define __UTALLOC_C__ #include "acpi.h" -#include "acparser.h" -#include "acinterp.h" -#include "acnamesp.h" -#include "acglobal.h" #define _COMPONENT ACPI_UTILITIES ACPI_MODULE_NAME ("utalloc") @@ -172,11 +168,11 @@ /* Mark the object as cached */ ACPI_MEMSET (Object, 0xCA, CacheInfo->ObjectSize); - ACPI_SET_DESCRIPTOR_TYPE (Object, ACPI_CACHED_OBJECT); + ACPI_SET_DESCRIPTOR_TYPE (Object, ACPI_DESC_TYPE_CACHED); /* Put the object at the head of the cache list */ - * (char **) (((char *) Object) + CacheInfo->LinkOffset) = CacheInfo->ListHead; + * (ACPI_CAST_INDIRECT_PTR (char, &(((char *) Object)[CacheInfo->LinkOffset]))) = CacheInfo->ListHead; CacheInfo->ListHead = Object; CacheInfo->CacheDepth++; @@ -225,7 +221,7 @@ /* There is an object available, use it */ Object = CacheInfo->ListHead; - CacheInfo->ListHead = * (char **) (((char *) Object) + CacheInfo->LinkOffset); + CacheInfo->ListHead = *(ACPI_CAST_INDIRECT_PTR (char, &(((char *) Object)[CacheInfo->LinkOffset]))); ACPI_MEM_TRACKING (CacheInfo->CacheHits++); CacheInfo->CacheDepth--; @@ -292,7 +288,7 @@ { /* Delete one cached state object */ - Next = * (char **) (((char *) CacheInfo->ListHead) + CacheInfo->LinkOffset); + Next = *(ACPI_CAST_INDIRECT_PTR (char, &(((char *) CacheInfo->ListHead)[CacheInfo->LinkOffset]))); ACPI_MEM_FREE (CacheInfo->ListHead); CacheInfo->ListHead = Next; @@ -472,7 +468,7 @@ /* Report allocation error */ _ACPI_REPORT_ERROR (Module, Line, Component, - ("UtAllocate: Could not allocate size %X\n", Size)); + ("UtAllocate: Could not allocate size %X\n", (UINT32) Size)); return_PTR (NULL); } @@ -524,7 +520,7 @@ /* Report allocation error */ _ACPI_REPORT_ERROR (Module, Line, Component, - ("UtCallocate: Could not allocate size %X\n", Size)); + ("UtCallocate: Could not allocate size %X\n", (UINT32) Size)); return_PTR (NULL); } @@ -629,7 +625,7 @@ /* Report allocation error */ _ACPI_REPORT_ERROR (Module, Line, Component, - ("UtCallocate: Could not allocate size %X\n", Size)); + ("UtCallocate: Could not allocate size %X\n", (UINT32) Size)); return (NULL); } @@ -671,6 +667,7 @@ UINT32 Line) { ACPI_DEBUG_MEM_BLOCK *DebugBlock; + ACPI_STATUS Status; ACPI_FUNCTION_TRACE_PTR ("UtFree", Allocation); @@ -684,14 +681,20 @@ return_VOID; } - DebugBlock = (ACPI_DEBUG_MEM_BLOCK *) - (((char *) Allocation) - sizeof (ACPI_DEBUG_MEM_HEADER)); + DebugBlock = ACPI_CAST_PTR (ACPI_DEBUG_MEM_BLOCK, + (((char *) Allocation) - sizeof (ACPI_DEBUG_MEM_HEADER))); AcpiGbl_MemoryLists[ACPI_MEM_LIST_GLOBAL].TotalFreed++; AcpiGbl_MemoryLists[ACPI_MEM_LIST_GLOBAL].CurrentTotalSize -= DebugBlock->Size; - AcpiUtRemoveAllocation (ACPI_MEM_LIST_GLOBAL, DebugBlock, - Component, Module, Line); + Status = AcpiUtRemoveAllocation (ACPI_MEM_LIST_GLOBAL, DebugBlock, + Component, Module, Line); + if (ACPI_FAILURE (Status)) + { + ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Could not free memory, %s\n", + AcpiFormatException (Status))); + } + AcpiOsFree (DebugBlock); ACPI_DEBUG_PRINT ((ACPI_DB_ALLOCATIONS, "%p freed\n", Allocation)); @@ -994,6 +997,7 @@ NATIVE_CHAR *Module) { ACPI_DEBUG_MEM_BLOCK *Element; + ACPI_DESCRIPTOR *Descriptor; UINT32 NumOutstanding = 0; @@ -1016,30 +1020,31 @@ { /* Ignore allocated objects that are in a cache */ - if (((ACPI_OPERAND_OBJECT *)(&Element->UserSpace))->Common.Type != ACPI_CACHED_OBJECT) + Descriptor = ACPI_CAST_PTR (ACPI_DESCRIPTOR, &Element->UserSpace); + if (Descriptor->DescriptorId != ACPI_DESC_TYPE_CACHED) { AcpiOsPrintf ("%p Len %04X %9.9s-%d ", - &Element->UserSpace, Element->Size, Element->Module, + Descriptor, Element->Size, Element->Module, Element->Line); /* Most of the elements will be internal objects. */ - switch (ACPI_GET_DESCRIPTOR_TYPE (&Element->UserSpace)) + switch (ACPI_GET_DESCRIPTOR_TYPE (Descriptor)) { - case ACPI_DESC_TYPE_INTERNAL: - AcpiOsPrintf ("ObjType %12.12s R%d", - AcpiUtGetTypeName (((ACPI_OPERAND_OBJECT *)(&Element->UserSpace))->Common.Type), - ((ACPI_OPERAND_OBJECT *)(&Element->UserSpace))->Common.ReferenceCount); + case ACPI_DESC_TYPE_OPERAND: + AcpiOsPrintf ("ObjType %12.12s R%hd", + AcpiUtGetTypeName (Descriptor->Object.Common.Type), + Descriptor->Object.Common.ReferenceCount); break; case ACPI_DESC_TYPE_PARSER: - AcpiOsPrintf ("ParseObj Opcode %04X", - ((ACPI_PARSE_OBJECT *)(&Element->UserSpace))->Opcode); + AcpiOsPrintf ("ParseObj AmlOpcode %04hX", + Descriptor->Op.Asl.AmlOpcode); break; case ACPI_DESC_TYPE_NAMED: AcpiOsPrintf ("Node %4.4s", - (char *) &((ACPI_NAMESPACE_NODE *)(&Element->UserSpace))->Name); + Descriptor->Node.Name.Ascii); break; case ACPI_DESC_TYPE_STATE: @@ -1081,6 +1086,10 @@ case ACPI_DESC_TYPE_STATE_THREAD: AcpiOsPrintf ("THREAD StateObj"); break; + + default: + /* All types should appear above */ + break; } AcpiOsPrintf ( "\n"); @@ -1097,7 +1106,7 @@ if (!NumOutstanding) { ACPI_DEBUG_PRINT ((ACPI_DB_OK, - "No outstanding allocations.\n")); + "No outstanding allocations.\n")); } else { Index: utclib.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utclib.c,v retrieving revision 1.1.1.7 diff -u -r1.1.1.7 utclib.c --- utclib.c 23 Feb 2002 05:10:40 -0000 1.1.1.7 +++ utclib.c 1 Jul 2002 21:39:53 -0000 @@ -118,11 +118,6 @@ #define __CMCLIB_C__ #include "acpi.h" -#include "acevents.h" -#include "achware.h" -#include "acnamesp.h" -#include "acinterp.h" -#include "amlcode.h" /* * These implementations of standard C Library routines can optionally be @@ -130,7 +125,7 @@ * than an inline or assembly implementation */ -#define _COMPONENT MISCELLANEOUS +#define _COMPONENT ACPI_UTILITIES ACPI_MODULE_NAME ("cmclib") @@ -295,7 +290,7 @@ * ******************************************************************************/ -UINT32 +int AcpiUtStrncmp ( const NATIVE_CHAR *String1, const NATIVE_CHAR *String2, @@ -472,19 +467,7 @@ #define NEGATIVE 1 #define POSITIVE 0 - -#define _ACPI_XA 0x00 /* extra alphabetic - not supported */ -#define _ACPI_XS 0x40 /* extra space */ -#define _ACPI_BB 0x00 /* BEL, BS, etc. - not supported */ -#define _ACPI_CN 0x20 /* CR, FF, HT, NL, VT */ -#define _ACPI_DI 0x04 /* '0'-'9' */ -#define _ACPI_LO 0x02 /* 'a'-'z' */ -#define _ACPI_PU 0x10 /* punctuation */ -#define _ACPI_SP 0x08 /* space */ -#define _ACPI_UP 0x01 /* 'A'-'Z' */ -#define _ACPI_XD 0x80 /* '0'-'9', 'A'-'F', 'a'-'f' */ - -static const UINT8 _acpi_ctype[257] = { +const UINT8 _acpi_ctype[257] = { _ACPI_CN, /* 0x0 0. */ _ACPI_CN, /* 0x1 1. */ _ACPI_CN, /* 0x2 2. */ @@ -643,9 +626,9 @@ * ******************************************************************************/ -UINT32 +int AcpiUtToUpper ( - UINT32 c) + int c) { return (IS_LOWER(c) ? ((c)-0x20) : (c)); @@ -664,9 +647,9 @@ * ******************************************************************************/ -UINT32 +int AcpiUtToLower ( - UINT32 c) + int c) { return (IS_UPPER(c) ? ((c)+0x20) : (c)); @@ -832,11 +815,11 @@ { if (IS_DIGIT (*String)) { - index = *String - '0'; + index = (UINT32) ((UINT8) *String - '0'); } else { - index = AcpiUtToUpper (*String); + index = (UINT32) AcpiUtToUpper (*String); if (IS_UPPER (index)) { index = index - 'A' + 10; Index: utcopy.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utcopy.c,v retrieving revision 1.1.1.15 diff -u -r1.1.1.15 utcopy.c --- utcopy.c 30 Jun 2002 17:50:46 -0000 1.1.1.15 +++ utcopy.c 1 Jul 2002 21:39:53 -0000 @@ -117,7 +117,6 @@ #define __UTCOPY_C__ #include "acpi.h" -#include "acinterp.h" #include "acnamesp.h" #include "amlcode.h" @@ -150,7 +149,6 @@ UINT8 *DataSpace, ACPI_SIZE *BufferSpaceUsed) { - ACPI_BUFFER Buffer; ACPI_STATUS Status = AE_OK; @@ -161,7 +159,7 @@ /* * Check for NULL object case (could be an uninitialized - * package element + * package element) */ if (!InternalObject) { @@ -176,20 +174,20 @@ * In general, the external object will be the same type as * the internal object */ - ExternalObject->Type = InternalObject->Common.Type; + ExternalObject->Type = ACPI_GET_OBJECT_TYPE (InternalObject); /* However, only a limited number of external types are supported */ - switch (InternalObject->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (InternalObject)) { case ACPI_TYPE_STRING: ExternalObject->String.Pointer = (NATIVE_CHAR *) DataSpace; ExternalObject->String.Length = InternalObject->String.Length; - *BufferSpaceUsed = ACPI_ROUND_UP_TO_NATIVE_WORD (InternalObject->String.Length + 1); + *BufferSpaceUsed = ACPI_ROUND_UP_TO_NATIVE_WORD ((ACPI_SIZE) InternalObject->String.Length + 1); ACPI_MEMCPY ((void *) DataSpace, (void *) InternalObject->String.Pointer, - InternalObject->String.Length + 1); + (ACPI_SIZE) InternalObject->String.Length + 1); break; @@ -217,45 +215,9 @@ */ switch (InternalObject->Reference.Opcode) { - case AML_ZERO_OP: - ExternalObject->Type = ACPI_TYPE_INTEGER; - ExternalObject->Integer.Value = 0; - break; - - case AML_ONE_OP: - ExternalObject->Type = ACPI_TYPE_INTEGER; - ExternalObject->Integer.Value = 1; - break; - - case AML_ONES_OP: - ExternalObject->Type = ACPI_TYPE_INTEGER; - ExternalObject->Integer.Value = ACPI_INTEGER_MAX; - break; - - case AML_REVISION_OP: - ExternalObject->Type = ACPI_TYPE_INTEGER; - ExternalObject->Integer.Value = ACPI_CA_SUPPORT_LEVEL; - break; - case AML_INT_NAMEPATH_OP: - /* - * This is a named reference, get the string. We already know that - * we have room for it, use max length - */ - ExternalObject->Type = ACPI_TYPE_STRING; - ExternalObject->String.Pointer = (NATIVE_CHAR *) DataSpace; - - Buffer.Length = MAX_STRING_LENGTH; - Buffer.Pointer = DataSpace; - Status = AcpiNsHandleToPathname ((ACPI_HANDLE *) InternalObject->Reference.Node, - &Buffer); - - /* Converted (external) string length is returned from above */ - - ExternalObject->String.Length = Buffer.Length; - *BufferSpaceUsed = ACPI_ROUND_UP_TO_NATIVE_WORD (Buffer.Length); - break; + /* For namepath, return the object handle ("reference") */ default: /* @@ -271,9 +233,9 @@ case ACPI_TYPE_PROCESSOR: - ExternalObject->Processor.ProcId = InternalObject->Processor.ProcId; + ExternalObject->Processor.ProcId = InternalObject->Processor.ProcId; ExternalObject->Processor.PblkAddress = InternalObject->Processor.Address; - ExternalObject->Processor.PblkLength = InternalObject->Processor.Length; + ExternalObject->Processor.PblkLength = InternalObject->Processor.Length; break; @@ -354,7 +316,7 @@ */ TargetObject->Type = ACPI_TYPE_PACKAGE; TargetObject->Package.Count = SourceObject->Package.Count; - TargetObject->Package.Elements = (ACPI_OBJECT *) Info->FreeSpace; + TargetObject->Package.Elements = ACPI_CAST_PTR (ACPI_OBJECT, Info->FreeSpace); /* * Pass the new package object back to the package walk routine @@ -366,7 +328,7 @@ * update the buffer length counter */ ObjectSpace = ACPI_ROUND_UP_TO_NATIVE_WORD ( - TargetObject->Package.Count * sizeof (ACPI_OBJECT)); + (ACPI_SIZE) TargetObject->Package.Count * sizeof (ACPI_OBJECT)); break; @@ -416,7 +378,7 @@ /* * First package at head of the buffer */ - ExternalObject = (ACPI_OBJECT *) Buffer; + ExternalObject = ACPI_CAST_PTR (ACPI_OBJECT, Buffer); /* * Free space begins right after the first package @@ -426,9 +388,9 @@ Info.NumPackages = 1; Info.FreeSpace = Buffer + ACPI_ROUND_UP_TO_NATIVE_WORD (sizeof (ACPI_OBJECT)); - ExternalObject->Type = InternalObject->Common.Type; + ExternalObject->Type = ACPI_GET_OBJECT_TYPE (InternalObject); ExternalObject->Package.Count = InternalObject->Package.Count; - ExternalObject->Package.Elements = (ACPI_OBJECT *) Info.FreeSpace; + ExternalObject->Package.Elements = ACPI_CAST_PTR (ACPI_OBJECT, Info.FreeSpace); /* * Build an array of ACPI_OBJECTS in the buffer @@ -470,7 +432,7 @@ ACPI_FUNCTION_TRACE ("UtCopyIobjectToEobject"); - if (InternalObject->Common.Type == ACPI_TYPE_PACKAGE) + if (ACPI_GET_OBJECT_TYPE (InternalObject) == ACPI_TYPE_PACKAGE) { /* * Package object: Copy all subobjects (including @@ -558,7 +520,7 @@ case ACPI_TYPE_STRING: - InternalObject->String.Pointer = ACPI_MEM_CALLOCATE (ExternalObject->String.Length + 1); + InternalObject->String.Pointer = ACPI_MEM_CALLOCATE ((ACPI_SIZE) ExternalObject->String.Length + 1); if (!InternalObject->String.Pointer) { return_ACPI_STATUS (AE_NO_MEMORY); @@ -592,6 +554,10 @@ InternalObject->Integer.Value = ExternalObject->Integer.Value; break; + + default: + /* Other types can't get here */ + break; } *RetInternalObject = InternalObject; @@ -651,7 +617,7 @@ FreeSpace = Buffer + sizeof(ACPI_OBJECT); - ExternalObject->Type = InternalObject->Common.Type; + ExternalObject->Type = ACPI_GET_OBJECT_TYPE (InternalObject); ExternalObject->Package.Count = InternalObject->Package.Count; ExternalObject->Package.Elements = (ACPI_OBJECT *)FreeSpace; @@ -756,7 +722,7 @@ /* Handle the objects with extra data */ - switch (DestDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (DestDesc)) { case ACPI_TYPE_BUFFER: @@ -764,6 +730,7 @@ DestDesc->Common.Flags = SourceDesc->Common.Flags; /* Fall through to common string/buffer case */ + /*lint -fallthrough */ case ACPI_TYPE_STRING: @@ -786,6 +753,10 @@ SourceDesc->String.Length); } break; + + default: + /* Nothing to do for other simple objects */ + break; } return (AE_OK); @@ -831,7 +802,7 @@ /* * This is a simple object, just copy it */ - TargetObject = AcpiUtCreateInternalObject (SourceObject->Common.Type); + TargetObject = AcpiUtCreateInternalObject (ACPI_GET_OBJECT_TYPE (SourceObject)); if (!TargetObject) { return (AE_NO_MEMORY); @@ -908,16 +879,16 @@ ACPI_FUNCTION_TRACE ("UtCopyIpackageToIpackage"); - DestObj->Common.Type = SourceObj->Common.Type; + DestObj->Common.Type = ACPI_GET_OBJECT_TYPE (SourceObj); DestObj->Common.Flags = SourceObj->Common.Flags; DestObj->Package.Count = SourceObj->Package.Count; - /* * Create the object array and walk the source package tree */ - DestObj->Package.Elements = ACPI_MEM_CALLOCATE ((SourceObj->Package.Count + 1) * - sizeof (void *)); + DestObj->Package.Elements = ACPI_MEM_CALLOCATE ( + ((ACPI_SIZE) SourceObj->Package.Count + 1) * + sizeof (void *)); if (!DestObj->Package.Elements) { ACPI_REPORT_ERROR ( @@ -970,7 +941,7 @@ /* Create the top level object */ - *DestDesc = AcpiUtCreateInternalObject (SourceDesc->Common.Type); + *DestDesc = AcpiUtCreateInternalObject (ACPI_GET_OBJECT_TYPE (SourceDesc)); if (!*DestDesc) { return_ACPI_STATUS (AE_NO_MEMORY); @@ -978,7 +949,7 @@ /* Copy the object and possible subobjects */ - if (SourceDesc->Common.Type == ACPI_TYPE_PACKAGE) + if (ACPI_GET_OBJECT_TYPE (SourceDesc) == ACPI_TYPE_PACKAGE) { Status = AcpiUtCopyIpackageToIpackage (SourceDesc, *DestDesc, WalkState); Index: utdebug.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utdebug.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 utdebug.c --- utdebug.c 30 Jun 2002 17:50:46 -0000 1.1.1.14 +++ utdebug.c 1 Jul 2002 21:39:53 -0000 @@ -122,13 +122,12 @@ ACPI_MODULE_NAME ("utdebug") -UINT32 AcpiGbl_PrevThreadId = 0xFFFFFFFF; -char *AcpiGbl_FnEntryStr = "----Entry"; -char *AcpiGbl_FnExitStr = "----Exit-"; - - #ifdef ACPI_DEBUG +static UINT32 AcpiGbl_PrevThreadId = 0xFFFFFFFF; +static char *AcpiGbl_FnEntryStr = "----Entry"; +static char *AcpiGbl_FnExitStr = "----Exit-"; + /***************************************************************************** * @@ -227,7 +226,6 @@ return; } - /* * Thread tracking and context switch notification */ @@ -248,15 +246,14 @@ * Display the module name, current line number, thread ID (if requested), * current procedure nesting level, and the current procedure name */ - AcpiOsPrintf ("%8s-%04d ", DbgInfo->ModuleName, LineNumber); + AcpiOsPrintf ("%8s-%04ld ", DbgInfo->ModuleName, LineNumber); if (ACPI_LV_THREADS & AcpiDbgLevel) { - AcpiOsPrintf ("[%04X] ", ThreadId, AcpiGbl_NestingLevel, DbgInfo->ProcName); + AcpiOsPrintf ("[%04lX] ", ThreadId, AcpiGbl_NestingLevel, DbgInfo->ProcName); } - AcpiOsPrintf ("[%02d] %-22.22s: ", AcpiGbl_NestingLevel, DbgInfo->ProcName); - + AcpiOsPrintf ("[%02ld] %-22.22s: ", AcpiGbl_NestingLevel, DbgInfo->ProcName); va_start (args, Format); AcpiOsVprintf (Format, args); @@ -301,7 +298,6 @@ } va_start (args, Format); - AcpiOsVprintf (Format, args); } @@ -596,8 +592,8 @@ UINT32 Display, UINT32 ComponentId) { - UINT32 i = 0; - UINT32 j; + NATIVE_UINT i = 0; + NATIVE_UINT j; UINT32 Temp32; UINT8 BufChar; @@ -626,7 +622,6 @@ AcpiOsPrintf ("%05X ", i); - /* Print 16 hex chars */ for (j = 0; j < 16;) @@ -683,12 +678,10 @@ } } - /* * Print the ASCII equivalent characters * But watch out for the bad unprintable ones... */ - for (j = 0; j < 16; j++) { if (i + j >= Count) Index: utdelete.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utdelete.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 utdelete.c --- utdelete.c 30 Jun 2002 17:50:46 -0000 1.1.1.14 +++ utdelete.c 1 Jul 2002 21:39:53 -0000 @@ -119,8 +119,6 @@ #include "acpi.h" #include "acinterp.h" #include "acnamesp.h" -#include "actables.h" -#include "acparser.h" #define _COMPONENT ACPI_UTILITIES ACPI_MODULE_NAME ("utdelete") @@ -160,7 +158,7 @@ * Must delete or free any pointers within the object that are not * actual ACPI objects (for example, a raw buffer pointer). */ - switch (Object->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (Object)) { case ACPI_TYPE_STRING: @@ -209,7 +207,7 @@ Object, Object->Mutex.Semaphore)); AcpiExUnlinkMutex (Object); - AcpiOsDeleteSemaphore (Object->Mutex.Semaphore); + (void) AcpiOsDeleteSemaphore (Object->Mutex.Semaphore); break; @@ -218,7 +216,7 @@ ACPI_DEBUG_PRINT ((ACPI_DB_ALLOCATIONS, "***** Event %p, Semaphore %p\n", Object, Object->Event.Semaphore)); - AcpiOsDeleteSemaphore (Object->Event.Semaphore); + (void) AcpiOsDeleteSemaphore (Object->Event.Semaphore); Object->Event.Semaphore = NULL; break; @@ -231,7 +229,7 @@ if (Object->Method.Semaphore) { - AcpiOsDeleteSemaphore (Object->Method.Semaphore); + (void) AcpiOsDeleteSemaphore (Object->Method.Semaphore); Object->Method.Semaphore = NULL; } break; @@ -292,7 +290,7 @@ /* Now the object can be safely deleted */ ACPI_DEBUG_PRINT ((ACPI_DB_ALLOCATIONS, "Deleting Object %p [%s]\n", - Object, AcpiUtGetTypeName (Object->Common.Type))); + Object, AcpiUtGetObjectTypeName (Object))); AcpiUtDeleteObjectDesc (Object); return_VOID; @@ -305,14 +303,14 @@ * * PARAMETERS: *ObjList - Pointer to the list to be deleted * - * RETURN: Status - the status of the call + * RETURN: None * * DESCRIPTION: This function deletes an internal object list, including both * simple objects and package objects * ******************************************************************************/ -ACPI_STATUS +void AcpiUtDeleteInternalObjectList ( ACPI_OPERAND_OBJECT **ObjList) { @@ -332,7 +330,7 @@ /* Free the combined parameter pointer list and object array */ ACPI_MEM_FREE (ObjList); - return_ACPI_STATUS (AE_OK); + return_VOID; } @@ -402,7 +400,7 @@ Object, NewCount)); } - if (Object->Common.Type == ACPI_TYPE_METHOD) + if (ACPI_GET_OBJECT_TYPE (Object) == ACPI_TYPE_METHOD) { ACPI_DEBUG_PRINT ((ACPI_DB_ALLOCATIONS, "Method Obj %p Refs=%X, [Decremented]\n", Object, NewCount)); @@ -516,7 +514,7 @@ * All sub-objects must have their reference count incremented also. * Different object types have different subobjects. */ - switch (Object->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (Object)) { case ACPI_TYPE_DEVICE: @@ -524,7 +522,7 @@ Action, &StateList); if (ACPI_FAILURE (Status)) { - return_ACPI_STATUS (Status); + goto ErrorExit; } AcpiUtUpdateRefCount (Object->Device.SysHandler, Action); @@ -564,7 +562,7 @@ Object->Package.Elements[i], Action, &StateList); if (ACPI_FAILURE (Status)) { - return_ACPI_STATUS (Status); + goto ErrorExit; } } break; @@ -574,10 +572,9 @@ Status = AcpiUtCreateUpdateStateAndPush ( Object->BufferField.BufferObj, Action, &StateList); - if (ACPI_FAILURE (Status)) { - return_ACPI_STATUS (Status); + goto ErrorExit; } break; @@ -588,7 +585,7 @@ Object->Field.RegionObj, Action, &StateList); if (ACPI_FAILURE (Status)) { - return_ACPI_STATUS (Status); + goto ErrorExit; } break; @@ -599,14 +596,14 @@ Object->BankField.BankObj, Action, &StateList); if (ACPI_FAILURE (Status)) { - return_ACPI_STATUS (Status); + goto ErrorExit; } Status = AcpiUtCreateUpdateStateAndPush ( Object->BankField.RegionObj, Action, &StateList); if (ACPI_FAILURE (Status)) { - return_ACPI_STATUS (Status); + goto ErrorExit; } break; @@ -617,20 +614,21 @@ Object->IndexField.IndexObj, Action, &StateList); if (ACPI_FAILURE (Status)) { - return_ACPI_STATUS (Status); + goto ErrorExit; } Status = AcpiUtCreateUpdateStateAndPush ( Object->IndexField.DataObj, Action, &StateList); if (ACPI_FAILURE (Status)) { - return_ACPI_STATUS (Status); + goto ErrorExit; } break; case ACPI_TYPE_REGION: case INTERNAL_TYPE_REFERENCE: + default: /* No subobjects */ break; @@ -649,6 +647,14 @@ } return_ACPI_STATUS (AE_OK); + + +ErrorExit: + + ACPI_REPORT_ERROR (("Could not update object reference count, %s\n", + AcpiFormatException (Status))); + + return_ACPI_STATUS (Status); } @@ -684,7 +690,7 @@ /* * We have a valid ACPI internal object, now increment the reference count */ - AcpiUtUpdateObjectReference (Object, REF_INCREMENT); + (void) AcpiUtUpdateObjectReference (Object, REF_INCREMENT); return_VOID; } @@ -736,7 +742,7 @@ * if the reference count becomes 0. (Must also decrement the ref count * of all subobjects!) */ - AcpiUtUpdateObjectReference (Object, REF_DECREMENT); + (void) AcpiUtUpdateObjectReference (Object, REF_DECREMENT); return_VOID; } Index: uteval.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/uteval.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 uteval.c --- uteval.c 30 Jun 2002 17:50:46 -0000 1.1.1.12 +++ uteval.c 1 Jul 2002 21:39:53 -0000 @@ -163,12 +163,12 @@ if (Status == AE_NOT_FOUND) { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%s on %4.4s was not found\n", - ObjectName, (char *) &DeviceNode->Name)); + ObjectName, DeviceNode->Name.Ascii)); } else { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "%s on %4.4s failed with status %s\n", - ObjectName, (char *) &DeviceNode->Name, + ObjectName, DeviceNode->Name.Ascii, AcpiFormatException (Status))); } @@ -187,12 +187,12 @@ /* Is the return object of the correct type? */ - if (ObjDesc->Common.Type != ACPI_TYPE_INTEGER) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_INTEGER) { Status = AE_TYPE; ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, - "Type returned from %s was not a number: %X \n", - ObjectName, ObjDesc->Common.Type)); + "Type returned from %s was not an Integer: %X \n", + ObjectName, ACPI_GET_OBJECT_TYPE (ObjDesc))); } else { @@ -248,12 +248,12 @@ if (Status == AE_NOT_FOUND) { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "_HID on %4.4s was not found\n", - (char *) &DeviceNode->Name)); + DeviceNode->Name.Ascii)); } else { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "_HID on %4.4s failed %s\n", - (char *) &DeviceNode->Name, AcpiFormatException (Status))); + DeviceNode->Name.Ascii, AcpiFormatException (Status))); } return_ACPI_STATUS (Status); @@ -271,17 +271,18 @@ * A _HID can return either a Number (32 bit compressed EISA ID) or * a string */ - if ((ObjDesc->Common.Type != ACPI_TYPE_INTEGER) && - (ObjDesc->Common.Type != ACPI_TYPE_STRING)) + if ((ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_INTEGER) && + (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_STRING)) { Status = AE_TYPE; ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Type returned from _HID not a number or string: %s(%X) \n", - AcpiUtGetTypeName (ObjDesc->Common.Type), ObjDesc->Common.Type)); + AcpiUtGetObjectTypeName (ObjDesc), + ACPI_GET_OBJECT_TYPE (ObjDesc))); } else { - if (ObjDesc->Common.Type == ACPI_TYPE_INTEGER) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) == ACPI_TYPE_INTEGER) { /* Convert the Numeric HID to string */ @@ -339,12 +340,12 @@ if (Status == AE_NOT_FOUND) { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "_CID on %4.4s was not found\n", - (char *)&DeviceNode->Name)); + DeviceNode->Name.Ascii)); } else { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "_CID on %4.4s failed %s\n", - (char *)&DeviceNode->Name, AcpiFormatException (Status))); + DeviceNode->Name.Ascii, AcpiFormatException (Status))); } return_ACPI_STATUS (Status); @@ -363,7 +364,7 @@ * IDs. Each compatible ID can be a Number (32 bit compressed EISA ID) or * string (PCI ID format, e.g. "PCI\VEN_vvvv&DEV_dddd&SUBSYS_ssssssss"). */ - switch (ObjDesc->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (ObjDesc)) { case ACPI_TYPE_INTEGER: @@ -389,7 +390,8 @@ Status = AE_TYPE; ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Type returned from _CID not a number, string, or package: %s(%X) \n", - AcpiUtGetTypeName (ObjDesc->Common.Type), ObjDesc->Common.Type)); + AcpiUtGetObjectTypeName (ObjDesc), + ACPI_GET_OBJECT_TYPE (ObjDesc))); break; } @@ -438,13 +440,13 @@ if (Status == AE_NOT_FOUND) { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "_UID on %4.4s was not found\n", - (char *) &DeviceNode->Name)); + DeviceNode->Name.Ascii)); } else { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "_UID on %4.4s failed %s\n", - (char *) &DeviceNode->Name, AcpiFormatException (Status))); + DeviceNode->Name.Ascii, AcpiFormatException (Status))); } return (Status); @@ -462,17 +464,17 @@ * A _UID can return either a Number (32 bit compressed EISA ID) or * a string */ - if ((ObjDesc->Common.Type != ACPI_TYPE_INTEGER) && - (ObjDesc->Common.Type != ACPI_TYPE_STRING)) + if ((ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_INTEGER) && + (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_STRING)) { Status = AE_TYPE; ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Type returned from _UID was not a number or string: %X \n", - ObjDesc->Common.Type)); + ACPI_GET_OBJECT_TYPE (ObjDesc))); } else { - if (ObjDesc->Common.Type == ACPI_TYPE_INTEGER) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) == ACPI_TYPE_INTEGER) { /* Convert the Numeric UID to string */ @@ -531,7 +533,7 @@ { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "_STA on %4.4s was not found, assuming present.\n", - (char *) &DeviceNode->Name)); + DeviceNode->Name.Ascii)); *Flags = 0x0F; Status = AE_OK; @@ -540,7 +542,7 @@ else if (ACPI_FAILURE (Status)) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "_STA on %4.4s failed %s\n", - (char *) &DeviceNode->Name, + DeviceNode->Name.Ascii, AcpiFormatException (Status))); } @@ -556,12 +558,12 @@ /* Is the return object of the correct type? */ - if (ObjDesc->Common.Type != ACPI_TYPE_INTEGER) + if (ACPI_GET_OBJECT_TYPE (ObjDesc) != ACPI_TYPE_INTEGER) { Status = AE_TYPE; ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Type returned from _STA was not a number: %X \n", - ObjDesc->Common.Type)); + ACPI_GET_OBJECT_TYPE (ObjDesc))); } else { Index: utglobal.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utglobal.c,v retrieving revision 1.3 diff -u -r1.3 utglobal.c --- utglobal.c 30 Jun 2002 17:53:04 -0000 1.3 +++ utglobal.c 1 Jul 2002 21:39:53 -0000 @@ -118,11 +118,7 @@ #define DEFINE_ACPI_GLOBALS #include "acpi.h" -#include "acevents.h" #include "acnamesp.h" -#include "acinterp.h" -#include "amlcode.h" - #define _COMPONENT ACPI_UTILITIES ACPI_MODULE_NAME ("utglobal") @@ -245,7 +241,6 @@ BOOLEAN AcpiGbl_DbTerminateThreads = FALSE; BOOLEAN AcpiGbl_MethodExecuting = FALSE; NATIVE_CHAR *AcpiGbl_DbDisasmIndent = "...."; -ACPI_TABLE_HEADER *AcpiGbl_DbTablePtr = NULL; /* System flags */ @@ -282,15 +277,15 @@ const ACPI_PREDEFINED_NAMES AcpiGbl_PreDefinedNames[] = { - {"_GPE", INTERNAL_TYPE_DEF_ANY}, - {"_PR_", INTERNAL_TYPE_DEF_ANY}, - {"_SB_", ACPI_TYPE_DEVICE}, - {"_SI_", INTERNAL_TYPE_DEF_ANY}, - {"_TZ_", INTERNAL_TYPE_DEF_ANY}, + {"_GPE", INTERNAL_TYPE_DEF_ANY, NULL}, + {"_PR_", INTERNAL_TYPE_DEF_ANY, NULL}, + {"_SB_", ACPI_TYPE_DEVICE, NULL}, + {"_SI_", INTERNAL_TYPE_DEF_ANY, NULL}, + {"_TZ_", INTERNAL_TYPE_DEF_ANY, NULL}, {"_REV", ACPI_TYPE_INTEGER, "2"}, {"_OS_", ACPI_TYPE_STRING, ACPI_OS_NAME}, {"_GL_", ACPI_TYPE_MUTEX, "0"}, - {NULL, ACPI_TYPE_ANY} /* Table terminator */ + {NULL, ACPI_TYPE_ANY, NULL} /* Table terminator */ }; @@ -345,9 +340,9 @@ /* Hex to ASCII conversion table */ -const NATIVE_CHAR AcpiGbl_HexToAscii[] = +static const NATIVE_CHAR AcpiGbl_HexToAscii[] = {'0','1','2','3','4','5','6','7', - '8','9','A','B','C','D','E','F'}; + '8','9','A','B','C','D','E','F'}; /***************************************************************************** * @@ -363,7 +358,7 @@ * ****************************************************************************/ -UINT8 +char AcpiUtHexToAsciiChar ( ACPI_INTEGER Integer, UINT32 Position) @@ -463,7 +458,7 @@ /* Region type decoding */ -const NATIVE_CHAR *AcpiGbl_RegionTypes[ACPI_NUM_PREDEFINED_REGIONS] = +static const NATIVE_CHAR *AcpiGbl_RegionTypes[ACPI_NUM_PREDEFINED_REGIONS] = { "SystemMemory", "SystemIO", @@ -509,7 +504,7 @@ /* Event type decoding */ -const NATIVE_CHAR *AcpiGbl_EventTypes[ACPI_NUM_FIXED_EVENTS] = +static const NATIVE_CHAR *AcpiGbl_EventTypes[ACPI_NUM_FIXED_EVENTS] = { "PM_Timer", "GlobalLock", @@ -533,7 +528,7 @@ } -#ifdef ACPI_DEBUG +#if defined(ACPI_DEBUG) || defined(ENABLE_DEBUGGER) /* * Strings and procedures used for debug only @@ -566,6 +561,8 @@ return (AcpiGbl_MutexNames[MutexId]); } +#endif + /***************************************************************************** * @@ -647,16 +644,35 @@ } +NATIVE_CHAR * +AcpiUtGetObjectTypeName ( + ACPI_OPERAND_OBJECT *ObjDesc) +{ + + if (!ObjDesc) + { + return ("[NULL Object Descriptor]"); + } + + return (AcpiUtGetTypeName (ACPI_GET_OBJECT_TYPE (ObjDesc))); +} + + +/* Various strings for future use */ + +#if 0 +#include "amlcode.h" + /* Data used in keeping track of fields */ -const NATIVE_CHAR *AcpiGbl_FENames[NUM_FIELD_NAMES] = +static const NATIVE_CHAR *AcpiGbl_FENames[NUM_FIELD_NAMES] = { "skip", "?access?" }; /* FE = Field Element */ -const NATIVE_CHAR *AcpiGbl_MatchOps[NUM_MATCH_OPS] = +static const NATIVE_CHAR *AcpiGbl_MatchOps[NUM_MATCH_OPS] = { "Error", "MTR", @@ -670,7 +686,7 @@ /* Access type decoding */ -const NATIVE_CHAR *AcpiGbl_AccessTypes[NUM_ACCESS_TYPES] = +static const NATIVE_CHAR *AcpiGbl_AccessTypes[NUM_ACCESS_TYPES] = { "AnyAcc", "ByteAcc", @@ -683,14 +699,13 @@ /* Update rule decoding */ -const NATIVE_CHAR *AcpiGbl_UpdateRules[NUM_UPDATE_RULES] = +static const NATIVE_CHAR *AcpiGbl_UpdateRules[NUM_UPDATE_RULES] = { "Preserve", "WriteAsOnes", "WriteAsZeros" }; - -#endif +#endif /* Future use */ /***************************************************************************** @@ -772,6 +787,9 @@ AcpiGbl_NextMethodOwnerId = ACPI_FIRST_METHOD_ID; } break; + + default: + break; } (void) AcpiUtReleaseMutex (ACPI_MTX_CACHES); @@ -804,15 +822,15 @@ ACPI_MEMSET (AcpiGbl_MemoryLists, 0, sizeof (ACPI_MEMORY_LIST) * ACPI_NUM_MEM_LISTS); AcpiGbl_MemoryLists[ACPI_MEM_LIST_STATE].LinkOffset = (UINT16) ACPI_PTR_DIFF (&(((ACPI_GENERIC_STATE *) NULL)->Common.Next), NULL); - AcpiGbl_MemoryLists[ACPI_MEM_LIST_PSNODE].LinkOffset = (UINT16) ACPI_PTR_DIFF (&(((ACPI_PARSE_OBJECT *) NULL)->Next), NULL); - AcpiGbl_MemoryLists[ACPI_MEM_LIST_PSNODE_EXT].LinkOffset = (UINT16) ACPI_PTR_DIFF (&(((ACPI_PARSE2_OBJECT *) NULL)->Next), NULL); + AcpiGbl_MemoryLists[ACPI_MEM_LIST_PSNODE].LinkOffset = (UINT16) ACPI_PTR_DIFF (&(((ACPI_PARSE_OBJECT *) NULL)->Common.Next), NULL); + AcpiGbl_MemoryLists[ACPI_MEM_LIST_PSNODE_EXT].LinkOffset = (UINT16) ACPI_PTR_DIFF (&(((ACPI_PARSE_OBJECT *) NULL)->Common.Next), NULL); AcpiGbl_MemoryLists[ACPI_MEM_LIST_OPERAND].LinkOffset = (UINT16) ACPI_PTR_DIFF (&(((ACPI_OPERAND_OBJECT *) NULL)->Cache.Next), NULL); AcpiGbl_MemoryLists[ACPI_MEM_LIST_WALK].LinkOffset = (UINT16) ACPI_PTR_DIFF (&(((ACPI_WALK_STATE *) NULL)->Next), NULL); AcpiGbl_MemoryLists[ACPI_MEM_LIST_NSNODE].ObjectSize = sizeof (ACPI_NAMESPACE_NODE); AcpiGbl_MemoryLists[ACPI_MEM_LIST_STATE].ObjectSize = sizeof (ACPI_GENERIC_STATE); - AcpiGbl_MemoryLists[ACPI_MEM_LIST_PSNODE].ObjectSize = sizeof (ACPI_PARSE_OBJECT); - AcpiGbl_MemoryLists[ACPI_MEM_LIST_PSNODE_EXT].ObjectSize = sizeof (ACPI_PARSE2_OBJECT); + AcpiGbl_MemoryLists[ACPI_MEM_LIST_PSNODE].ObjectSize = sizeof (ACPI_PARSE_OBJ_COMMON); + AcpiGbl_MemoryLists[ACPI_MEM_LIST_PSNODE_EXT].ObjectSize = sizeof (ACPI_PARSE_OBJ_NAMED); AcpiGbl_MemoryLists[ACPI_MEM_LIST_OPERAND].ObjectSize = sizeof (ACPI_OPERAND_OBJECT); AcpiGbl_MemoryLists[ACPI_MEM_LIST_WALK].ObjectSize = sizeof (ACPI_WALK_STATE); @@ -855,6 +873,7 @@ AcpiGbl_SysNotify.Handler = NULL; AcpiGbl_DrvNotify.Handler = NULL; + AcpiGbl_InitHandler = NULL; /* Global "typed" ACPI table pointers */ @@ -904,7 +923,7 @@ #ifdef ACPI_DEBUG - AcpiGbl_LowestStackPointer = ACPI_UINT32_MAX; + AcpiGbl_LowestStackPointer = ACPI_SIZE_MAX; #endif return_VOID; Index: utinit.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utinit.c,v retrieving revision 1.1.1.12 diff -u -r1.1.1.12 utinit.c --- utinit.c 23 Feb 2002 05:10:40 -0000 1.1.1.12 +++ utinit.c 1 Jul 2002 21:39:53 -0000 @@ -118,7 +118,6 @@ #define __UTINIT_C__ #include "acpi.h" -#include "achware.h" #include "acnamesp.h" #include "acevents.h" @@ -149,7 +148,7 @@ { ACPI_REPORT_WARNING ( - ("Invalid FADT value %s=%lX at offset %lX FADT=%p\n", + ("Invalid FADT value %s=%X at offset %X FADT=%p\n", RegisterName, Value, Offset, AcpiGbl_FADT)); } @@ -283,7 +282,7 @@ * ******************************************************************************/ -ACPI_STATUS +void AcpiUtSubsystemShutdown (void) { @@ -294,7 +293,7 @@ if (AcpiGbl_Shutdown) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "ACPI Subsystem is already terminated\n")); - return_ACPI_STATUS (AE_OK); + return_VOID; } /* Subsystem appears active, go ahead and shut it down */ @@ -316,7 +315,7 @@ /* Purge the local caches */ - AcpiPurgeCachedObjects (); + (void) AcpiPurgeCachedObjects (); /* Debug only - display leftover memory allocation, if any */ @@ -324,7 +323,7 @@ AcpiUtDumpAllocations (ACPI_UINT32_MAX, NULL); #endif - return_ACPI_STATUS (AE_OK); + return_VOID; } Index: utmath.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utmath.c,v retrieving revision 1.1.1.4 diff -u -r1.1.1.4 utmath.c --- utmath.c 23 Feb 2002 05:10:40 -0000 1.1.1.4 +++ utmath.c 1 Jul 2002 21:39:53 -0000 @@ -293,7 +293,7 @@ */ Partial1 = Quotient.Part.Lo * Divisor.Part.Hi; Partial2.Full = (ACPI_INTEGER) Quotient.Part.Lo * Divisor.Part.Lo; - Partial3.Full = Partial2.Part.Hi + Partial1; + Partial3.Full = (ACPI_INTEGER) Partial2.Part.Hi + Partial1; Remainder.Part.Hi = Partial3.Part.Lo; Remainder.Part.Lo = Partial2.Part.Lo; @@ -318,8 +318,8 @@ } Remainder.Full = Remainder.Full - Dividend.Full; - Remainder.Part.Hi = -((INT32) Remainder.Part.Hi); - Remainder.Part.Lo = -((INT32) Remainder.Part.Lo); + Remainder.Part.Hi = (UINT32) -((INT32) Remainder.Part.Hi); + Remainder.Part.Lo = (UINT32) -((INT32) Remainder.Part.Lo); if (Remainder.Part.Lo) { Index: utmisc.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utmisc.c,v retrieving revision 1.1.1.11 diff -u -r1.1.1.11 utmisc.c --- utmisc.c 23 Feb 2002 05:10:40 -0000 1.1.1.11 +++ utmisc.c 1 Jul 2002 21:39:53 -0000 @@ -118,18 +118,90 @@ #define __UTMISC_C__ #include "acpi.h" -#include "acevents.h" -#include "achware.h" #include "acnamesp.h" -#include "acinterp.h" #include "amlcode.h" -#include "acdebug.h" +#include "acinterp.h" #define _COMPONENT ACPI_UTILITIES ACPI_MODULE_NAME ("utmisc") +/******************************************************************************* + * + * FUNCTION: AcpiUtDwordByteSwap + * + * PARAMETERS: Value - Value to be converted + * + * DESCRIPTION: Convert a 32-bit value to big-endian (swap the bytes) + * + ******************************************************************************/ + +UINT32 +AcpiUtDwordByteSwap ( + UINT32 Value) +{ + union + { + UINT32 Value; + UINT8 Bytes[4]; + } Out; + + union + { + UINT32 Value; + UINT8 Bytes[4]; + } In; + + + ACPI_FUNCTION_ENTRY (); + + + In.Value = Value; + + Out.Bytes[0] = In.Bytes[3]; + Out.Bytes[1] = In.Bytes[2]; + Out.Bytes[2] = In.Bytes[1]; + Out.Bytes[3] = In.Bytes[0]; + + return (Out.Value); +} + + +/******************************************************************************* + * + * FUNCTION: AcpiUtSetIntegerWidth + * + * PARAMETERS: Revision From DSDT header + * + * RETURN: None + * + * DESCRIPTION: Set the global integer bit width based upon the revision + * of the DSDT. For Revision 1 and 0, Integers are 32 bits. + * For Revision 2 and above, Integers are 64 bits. Yes, this + * makes a difference. + * + ******************************************************************************/ + +void +AcpiUtSetIntegerWidth ( + UINT8 Revision) +{ + + if (Revision <= 1) + { + AcpiGbl_IntegerBitWidth = 32; + AcpiGbl_IntegerByteWidth = 4; + } + else + { + AcpiGbl_IntegerBitWidth = 64; + AcpiGbl_IntegerByteWidth = 8; + } +} + + + #ifdef ACPI_DEBUG /******************************************************************************* * @@ -243,6 +315,169 @@ /******************************************************************************* * + * FUNCTION: AcpiUtStrtoul64 + * + * PARAMETERS: String - Null terminated string + * Terminater - Where a pointer to the terminating byte is returned + * Base - Radix of the string + * + * RETURN: Converted value + * + * DESCRIPTION: Convert a string into an unsigned value. + * + ******************************************************************************/ +#define NEGATIVE 1 +#define POSITIVE 0 + +ACPI_STATUS +AcpiUtStrtoul64 ( + NATIVE_CHAR *String, + UINT32 Base, + ACPI_INTEGER *RetInteger) +{ + UINT32 Index; + ACPI_INTEGER ReturnValue = 0; + ACPI_STATUS Status = AE_OK; + ACPI_INTEGER Dividend; + ACPI_INTEGER Quotient; + + + *RetInteger = 0; + + switch (Base) + { + case 0: + case 8: + case 10: + case 16: + break; + + default: + /* + * The specified Base parameter is not in the domain of + * this function: + */ + return (AE_BAD_PARAMETER); + } + + /* + * skip over any white space in the buffer: + */ + while (ACPI_IS_SPACE (*String) || *String == '\t') + { + ++String; + } + + /* + * If the input parameter Base is zero, then we need to + * determine if it is octal, decimal, or hexadecimal: + */ + if (Base == 0) + { + if (*String == '0') + { + if (ACPI_TOLOWER (*(++String)) == 'x') + { + Base = 16; + ++String; + } + else + { + Base = 8; + } + } + else + { + Base = 10; + } + } + + /* + * For octal and hexadecimal bases, skip over the leading + * 0 or 0x, if they are present. + */ + if (Base == 8 && *String == '0') + { + String++; + } + + if (Base == 16 && + *String == '0' && + ACPI_TOLOWER (*(++String)) == 'x') + { + String++; + } + + /* Main loop: convert the string to an unsigned long */ + + while (*String) + { + if (ACPI_IS_DIGIT (*String)) + { + Index = ((UINT8) *String) - '0'; + } + else + { + Index = (UINT8) ACPI_TOUPPER (*String); + if (ACPI_IS_UPPER ((char) Index)) + { + Index = Index - 'A' + 10; + } + else + { + goto ErrorExit; + } + } + + if (Index >= Base) + { + goto ErrorExit; + } + + /* Check to see if value is out of range: */ + + Dividend = ACPI_INTEGER_MAX - (ACPI_INTEGER) Index; + (void) AcpiUtShortDivide (&Dividend, Base, &Quotient, NULL); + if (ReturnValue > Quotient) + { + goto ErrorExit; + } + + ReturnValue *= Base; + ReturnValue += Index; + ++String; + } + + *RetInteger = ReturnValue; + return (Status); + + +ErrorExit: + switch (Base) + { + case 8: + Status = AE_BAD_OCTAL_CONSTANT; + break; + + case 10: + Status = AE_BAD_DECIMAL_CONSTANT; + break; + + case 16: + Status = AE_BAD_HEX_CONSTANT; + break; + + default: + /* Base validated above */ + break; + } + + return (Status); +} + + +/******************************************************************************* + * * FUNCTION: AcpiUtStrupr * * PARAMETERS: SrcString - The source string to convert to @@ -341,7 +576,7 @@ */ for (i = 0; i < NUM_MTX; i++) { - AcpiUtDeleteMutex (i); + (void) AcpiUtDeleteMutex (i); } return_VOID; @@ -1015,116 +1250,6 @@ /******************************************************************************* * - * FUNCTION: AcpiUtResolveReference - * - * PARAMETERS: ACPI_PKG_CALLBACK - * - * RETURN: Status - the status of the call - * - * DESCRIPTION: Resolve a reference object to an actual value - * - ******************************************************************************/ - -ACPI_STATUS -AcpiUtResolveReference ( - UINT8 ObjectType, - ACPI_OPERAND_OBJECT *SourceObject, - ACPI_GENERIC_STATE *State, - void *Context) -{ - ACPI_PKG_INFO *Info = (ACPI_PKG_INFO *) Context; - - - switch (ObjectType) - { - case ACPI_COPY_TYPE_SIMPLE: - - /* - * Simple object - check for a reference - */ - if (SourceObject->Common.Type == INTERNAL_TYPE_REFERENCE) - { - switch (SourceObject->Reference.Opcode) - { - case AML_ZERO_OP: - - SourceObject->Common.Type = ACPI_TYPE_INTEGER; - SourceObject->Integer.Value = 0; - break; - - case AML_ONE_OP: - - SourceObject->Common.Type = ACPI_TYPE_INTEGER; - SourceObject->Integer.Value = 1; - break; - - case AML_ONES_OP: - - SourceObject->Common.Type = ACPI_TYPE_INTEGER; - SourceObject->Integer.Value = ACPI_INTEGER_MAX; - break; - } - } - break; - - - case ACPI_COPY_TYPE_PACKAGE: - - /* Package object - nothing much to do here, let the walk handle it */ - - Info->NumPackages++; - State->Pkg.ThisTargetObj = NULL; - break; - } - - return (AE_OK); -} - - -/******************************************************************************* - * - * FUNCTION: AcpiUtResolvePackageReferences - * - * PARAMETERS: ObjDesc - The Package object on which to resolve refs - * - * RETURN: Status - * - * DESCRIPTION: Walk through a package and turn internal references into values - * - ******************************************************************************/ - -ACPI_STATUS -AcpiUtResolvePackageReferences ( - ACPI_OPERAND_OBJECT *ObjDesc) -{ - ACPI_PKG_INFO Info; - ACPI_STATUS Status; - - - ACPI_FUNCTION_TRACE ("UtResolvePackageReferences"); - - - if (ObjDesc->Common.Type != ACPI_TYPE_PACKAGE) - { - /* The object must be a package */ - - ACPI_REPORT_ERROR (("Expecting a Package object\n")); - return_ACPI_STATUS (AE_TYPE); - } - - Info.Length = 0; - Info.ObjectSpace = 0; - Info.NumPackages = 1; - - Status = AcpiUtWalkPackageTree (ObjDesc, NULL, - AcpiUtResolveReference, &Info); - - return_ACPI_STATUS (Status); -} - - -/******************************************************************************* - * * FUNCTION: AcpiUtWalkPackageTree * * PARAMETERS: ObjDesc - The Package object on which to resolve refs @@ -1173,8 +1298,8 @@ * case below. */ if ((!ThisSourceObj) || - (ACPI_GET_DESCRIPTOR_TYPE (ThisSourceObj) != ACPI_DESC_TYPE_INTERNAL) || - (ThisSourceObj->Common.Type != ACPI_TYPE_PACKAGE)) + (ACPI_GET_DESCRIPTOR_TYPE (ThisSourceObj) != ACPI_DESC_TYPE_OPERAND) || + (ACPI_GET_OBJECT_TYPE (ThisSourceObj) != ACPI_TYPE_PACKAGE)) { Status = WalkCallback (ACPI_COPY_TYPE_SIMPLE, ThisSourceObj, State, Context); Index: utobject.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utobject.c,v retrieving revision 1.1.1.14 diff -u -r1.1.1.14 utobject.c --- utobject.c 23 Feb 2002 05:10:40 -0000 1.1.1.14 +++ utobject.c 1 Jul 2002 21:39:53 -0000 @@ -117,9 +117,7 @@ #define __UTOBJECT_C__ #include "acpi.h" -#include "acinterp.h" #include "acnamesp.h" -#include "actables.h" #include "amlcode.h" @@ -131,10 +129,9 @@ * * FUNCTION: AcpiUtCreateInternalObjectDbg * - * PARAMETERS: Address - Address of the memory to deallocate - * Component - Component type of caller - * Module - Source file name of caller - * Line - Line number of caller + * PARAMETERS: ModuleName - Source file name of caller + * LineNumber - Line number of caller + * ComponentId - Component type of caller * Type - ACPI Type of the new object * * RETURN: Object - The new object. Null on failure @@ -192,6 +189,10 @@ Object->Common.NextObject = SecondObject; break; + + default: + /* All others have no secondary object */ + break; } /* Save the object type in the object descriptor */ @@ -212,7 +213,7 @@ * * FUNCTION: AcpiUtValidInternalObject * - * PARAMETERS: Operand - Object to be validated + * PARAMETERS: Object - Object to be validated * * RETURN: Validate a pointer to be an ACPI_OPERAND_OBJECT * @@ -239,7 +240,7 @@ switch (ACPI_GET_DESCRIPTOR_TYPE (Object)) { - case ACPI_DESC_TYPE_INTERNAL: + case ACPI_DESC_TYPE_OPERAND: /* The object appears to be a valid ACPI_OPERAND_OBJECT */ @@ -275,7 +276,6 @@ * PARAMETERS: ModuleName - Caller's module name (for error output) * LineNumber - Caller's line number (for error output) * ComponentId - Caller's component ID (for error output) - * Message - Error message to use on failure * * RETURN: Pointer to newly allocated object descriptor. Null on error * @@ -305,13 +305,12 @@ return_PTR (NULL); } - /* Mark the descriptor type */ - ACPI_SET_DESCRIPTOR_TYPE (Object, ACPI_DESC_TYPE_INTERNAL); + ACPI_SET_DESCRIPTOR_TYPE (Object, ACPI_DESC_TYPE_OPERAND); ACPI_DEBUG_PRINT ((ACPI_DB_ALLOCATIONS, "%p Size %X\n", - Object, sizeof (ACPI_OPERAND_OBJECT))); + Object, (UINT32) sizeof (ACPI_OPERAND_OBJECT))); return_PTR (Object); } @@ -321,7 +320,7 @@ * * FUNCTION: AcpiUtDeleteObjectDesc * - * PARAMETERS: Object - Acpi internal object to be deleted + * PARAMETERS: Object - An Acpi internal object to be deleted * * RETURN: None. * @@ -338,7 +337,7 @@ /* Object must be an ACPI_OPERAND_OBJECT */ - if (ACPI_GET_DESCRIPTOR_TYPE (Object) != ACPI_DESC_TYPE_INTERNAL) + if (ACPI_GET_DESCRIPTOR_TYPE (Object) != ACPI_DESC_TYPE_OPERAND) { ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Obj %p is not an ACPI object\n", Object)); @@ -357,7 +356,7 @@ * * PARAMETERS: None * - * RETURN: Status + * RETURN: None * * DESCRIPTION: Purge the global state object cache. Used during subsystem * termination. @@ -381,12 +380,12 @@ * FUNCTION: AcpiUtGetSimpleObjectSize * * PARAMETERS: *InternalObject - Pointer to the object we are examining - * *RetLength - Where the length is returned + * *ObjLength - Where the length is returned * * RETURN: Status * * DESCRIPTION: This function is called to determine the space required to - * contain a simple object for return to an API user. + * contain a simple object for return to an external user. * * The length includes the object structure plus any additional * needed space. @@ -413,7 +412,6 @@ return_ACPI_STATUS (AE_OK); } - /* Start with the length of the Acpi object */ Length = sizeof (ACPI_OBJECT); @@ -426,26 +424,23 @@ return_ACPI_STATUS (Status); } - /* * The final length depends on the object type * Strings and Buffers are packed right up against the parent object and * must be accessed bytewise or there may be alignment problems on * certain processors */ - - switch (InternalObject->Common.Type) + switch (ACPI_GET_OBJECT_TYPE (InternalObject)) { - case ACPI_TYPE_STRING: - Length += InternalObject->String.Length + 1; + Length += (ACPI_SIZE) InternalObject->String.Length + 1; break; case ACPI_TYPE_BUFFER: - Length += InternalObject->Buffer.Length; + Length += (ACPI_SIZE) InternalObject->Buffer.Length; break; @@ -463,15 +458,6 @@ switch (InternalObject->Reference.Opcode) { - case AML_ZERO_OP: - case AML_ONE_OP: - case AML_ONES_OP: - case AML_REVISION_OP: - - /* These Constant opcodes will be resolved to Integers */ - - break; - case AML_INT_NAMEPATH_OP: /* @@ -485,7 +471,7 @@ /* * No other reference opcodes are supported. - * Notably, Locals and Args are not supported, by this may be + * Notably, Locals and Args are not supported, but this may be * required eventually. */ ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, @@ -500,12 +486,11 @@ default: ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Unsupported type=%X in object %p\n", - InternalObject->Common.Type, InternalObject)); + ACPI_GET_OBJECT_TYPE (InternalObject), InternalObject)); Status = AE_TYPE; break; } - /* * Account for the space required by the object rounded up to the next * multiple of the machine word size. This keeps each object aligned @@ -523,7 +508,7 @@ * * PARAMETERS: ACPI_PKG_CALLBACK * - * RETURN: Status - the status of the call + * RETURN: Status * * DESCRIPTION: Get the length of one package element. * @@ -566,6 +551,13 @@ Info->NumPackages++; State->Pkg.ThisTargetObj = NULL; break; + + + default: + + /* No other types allowed */ + + return (AE_BAD_PARAMETER); } return (Status); @@ -577,12 +569,12 @@ * FUNCTION: AcpiUtGetPackageObjectSize * * PARAMETERS: *InternalObject - Pointer to the object we are examining - * *RetLength - Where the length is returned + * *ObjLength - Where the length is returned * * RETURN: Status * * DESCRIPTION: This function is called to determine the space required to - * contain a package object for return to an API user. + * contain a package object for return to an external user. * * This is moderately complex since a package contains other * objects including packages. @@ -618,7 +610,7 @@ * Round up to the next machine word. */ Info.Length += ACPI_ROUND_UP_TO_NATIVE_WORD (sizeof (ACPI_OBJECT)) * - Info.NumPackages; + (ACPI_SIZE) Info.NumPackages; /* Return the total package length */ @@ -632,7 +624,7 @@ * FUNCTION: AcpiUtGetObjectSize * * PARAMETERS: *InternalObject - Pointer to the object we are examining - * *RetLength - Where the length will be returned + * *ObjLength - Where the length will be returned * * RETURN: Status * @@ -652,8 +644,8 @@ ACPI_FUNCTION_ENTRY (); - if ((ACPI_GET_DESCRIPTOR_TYPE (InternalObject) == ACPI_DESC_TYPE_INTERNAL) && - (InternalObject->Common.Type == ACPI_TYPE_PACKAGE)) + if ((ACPI_GET_DESCRIPTOR_TYPE (InternalObject) == ACPI_DESC_TYPE_OPERAND) && + (ACPI_GET_OBJECT_TYPE (InternalObject) == ACPI_TYPE_PACKAGE)) { Status = AcpiUtGetPackageObjectSize (InternalObject, ObjLength); } Index: utxface.c =================================================================== RCS file: /home/ncvs/src/sys/contrib/dev/acpica/utxface.c,v retrieving revision 1.1.1.13 diff -u -r1.1.1.13 utxface.c --- utxface.c 23 Feb 2002 05:10:40 -0000 1.1.1.13 +++ utxface.c 1 Jul 2002 21:39:53 -0000 @@ -119,15 +119,10 @@ #include "acpi.h" #include "acevents.h" -#include "achware.h" #include "acnamesp.h" -#include "acinterp.h" -#include "amlcode.h" -#include "acdebug.h" -#include "acexcep.h" #include "acparser.h" #include "acdispat.h" - +#include "acdebug.h" #define _COMPONENT ACPI_UTILITIES ACPI_MODULE_NAME ("utxface") @@ -198,7 +193,7 @@ /* If configured, initialize the AML debugger */ - ACPI_DEBUGGER_EXEC (AcpiDbInitialize ()); + ACPI_DEBUGGER_EXEC (Status = AcpiDbInitialize ()); return_ACPI_STATUS (Status); } @@ -236,7 +231,7 @@ { ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "[Init] Installing default address space handlers\n")); - Status = AcpiEvInstallDefaultAddressSpaceHandlers (); + Status = AcpiEvInitAddressSpaces (); if (ACPI_FAILURE (Status)) { return_ACPI_STATUS (Status); @@ -361,6 +356,9 @@ ACPI_STATUS AcpiTerminate (void) { + ACPI_STATUS Status; + + ACPI_FUNCTION_TRACE ("AcpiTerminate"); @@ -387,10 +385,8 @@ /* Now we can shutdown the OS-dependent layer */ - AcpiOsTerminate (); - - - return_ACPI_STATUS (AE_OK); + Status = AcpiOsTerminate (); + return_ACPI_STATUS (Status); } @@ -514,6 +510,41 @@ } return_ACPI_STATUS (AE_OK); +} + + +/***************************************************************************** + * + * FUNCTION: AcpiInstallInitializationHandler + * + * PARAMETERS: Handler - Callback procedure + * + * RETURN: Status + * + * DESCRIPTION: Install an initialization handler + * + * TBD: When a second function is added, must save the Function also. + * + ****************************************************************************/ + +ACPI_STATUS +AcpiInstallInitializationHandler ( + ACPI_INIT_HANDLER Handler, + UINT32 Function) +{ + + if (!Handler) + { + return (AE_BAD_PARAMETER); + } + + if (AcpiGbl_InitHandler) + { + return (AE_ALREADY_EXISTS); + } + + AcpiGbl_InitHandler = Handler; + return AE_OK; }