PERFORCE change 15222 for review

Robert Watson rwatson at freebsd.org
Tue Jul 30 20:55:21 GMT 2002


http://people.freebsd.org/~peter/p4db/chv.cgi?CH=15222

Change 15222 by rwatson at rwatson_tislabs on 2002/07/30 13:54:48

	Further integ.  Apparently I previously integ'd in the middle
	of an ACPI import, so we got a broken ACPI build since it was
	before the conflicts were resolved.  Try again.

Affected files ...

.. //depot/projects/trustedbsd/base/sys/conf/files#24 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acconfig.h#6 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acenv.h#5 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acfreebsd.h#4 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acpiosxf.h#6 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acpixf.h#5 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acutils.h#6 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/dbcmds.c#6 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/dbdisasm.c#5 delete
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/dbfileio.c#5 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/dbxface.c#6 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/psparse.c#5 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/rscreate.c#5 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/tbget.c#5 integrate
.. //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/utglobal.c#5 integrate
.. //depot/projects/trustedbsd/base/sys/dev/acpica/Osd/OsdTable.c#2 integrate
.. //depot/projects/trustedbsd/base/sys/dev/acpica/acpi.c#13 integrate
.. //depot/projects/trustedbsd/base/sys/i386/include/acpica_machdep.h#1 branch
.. //depot/projects/trustedbsd/base/sys/ia64/include/acpica_machdep.h#1 branch
.. //depot/projects/trustedbsd/base/sys/kern/kern_condvar.c#11 integrate
.. //depot/projects/trustedbsd/base/sys/kern/vfs_bio.c#13 integrate
.. //depot/projects/trustedbsd/base/sys/modules/acpi/Makefile#5 integrate
.. //depot/projects/trustedbsd/base/usr.bin/sed/main.c#7 integrate

Differences ...

==== //depot/projects/trustedbsd/base/sys/conf/files#24 (text+ko) ====

@@ -1,4 +1,4 @@
-# $FreeBSD: src/sys/conf/files,v 1.676 2002/07/30 17:44:28 joe Exp $
+# $FreeBSD: src/sys/conf/files,v 1.677 2002/07/30 19:35:20 iwasaki Exp $
 #
 # The long compile-with and dependency lines are required because of
 # limitations in config: backslash-newline doesn't work in strings, and
@@ -56,7 +56,6 @@
 coda/coda_vnops.c	optional vcoda
 compat/linprocfs/linprocfs.c	 optional linprocfs
 contrib/dev/acpica/dbcmds.c	 optional acpica acpi_debug nowerror
-contrib/dev/acpica/dbdisasm.c	 optional acpica acpi_debug nowerror
 contrib/dev/acpica/dbdisply.c	 optional acpica acpi_debug nowerror
 contrib/dev/acpica/dbexec.c	 optional acpica acpi_debug nowerror
 contrib/dev/acpica/dbfileio.c	 optional acpica acpi_debug nowerror
@@ -65,6 +64,14 @@
 contrib/dev/acpica/dbstats.c	 optional acpica acpi_debug nowerror
 contrib/dev/acpica/dbutils.c	 optional acpica acpi_debug nowerror
 contrib/dev/acpica/dbxface.c	 optional acpica acpi_debug nowerror
+contrib/dev/acpica/dmbuffer.c	 optional acpica acpi_debug nowerror
+contrib/dev/acpica/dmnames.c	 optional acpica acpi_debug nowerror
+contrib/dev/acpica/dmopcode.c	 optional acpica acpi_debug nowerror
+contrib/dev/acpica/dmresrc.c	 optional acpica acpi_debug nowerror
+contrib/dev/acpica/dmresrcl.c	 optional acpica acpi_debug nowerror
+contrib/dev/acpica/dmresrcs.c	 optional acpica acpi_debug nowerror
+contrib/dev/acpica/dmutils.c	 optional acpica acpi_debug nowerror
+contrib/dev/acpica/dmwalk.c	 optional acpica acpi_debug nowerror
 contrib/dev/acpica/dsfield.c	 optional acpica nowerror
 contrib/dev/acpica/dsmethod.c	 optional acpica
 contrib/dev/acpica/dsmthdat.c	 optional acpica
@@ -122,8 +129,9 @@
 contrib/dev/acpica/nssearch.c	 optional acpica
 contrib/dev/acpica/nsutils.c	 optional acpica
 contrib/dev/acpica/nswalk.c	 optional acpica
+contrib/dev/acpica/nsxfeval.c	 optional acpica nowerror
 contrib/dev/acpica/nsxfname.c	 optional acpica nowerror
-contrib/dev/acpica/nsxfobj.c	 optional acpica
+contrib/dev/acpica/nsxfobj.c	 optional acpica nowerror
 contrib/dev/acpica/psargs.c	 optional acpica
 contrib/dev/acpica/psfind.c	 optional acpica
 contrib/dev/acpica/psopcode.c	 optional acpica
@@ -146,7 +154,9 @@
 contrib/dev/acpica/rsxface.c	 optional acpica
 contrib/dev/acpica/tbconvrt.c	 optional acpica
 contrib/dev/acpica/tbget.c	 optional acpica
+contrib/dev/acpica/tbgetall.c	 optional acpica
 contrib/dev/acpica/tbinstal.c	 optional acpica
+contrib/dev/acpica/tbrsdt.c	 optional acpica
 contrib/dev/acpica/tbutils.c	 optional acpica
 contrib/dev/acpica/tbxface.c	 optional acpica
 contrib/dev/acpica/tbxfroot.c	 optional acpica

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acconfig.h#6 (text+ko) ====

@@ -145,7 +145,7 @@
 
 /* Version string */
 
-#define ACPI_CA_VERSION                 0x20020611
+#define ACPI_CA_VERSION                 0x20020725
 
 /* Version of ACPI supported */
 
@@ -243,6 +243,15 @@
 
 #define ACPI_MAX_ADDRESS_SPACE          255
 
+/* Array sizes.  Used for range checking also */
+
+#define NUM_ACCESS_TYPES                6
+#define NUM_UPDATE_RULES                3
+#define NUM_LOCK_RULES                  2
+#define NUM_MATCH_OPS                   6
+#define NUM_OPCODES                     256
+#define NUM_FIELD_NAMES                 2
+
 /* RSDP checksums */
 
 #define ACPI_RSDP_CHECKSUM_LENGTH       20

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acenv.h#5 (text+ko) ====

@@ -123,11 +123,13 @@
  */
 
 #ifdef _ACPI_DUMP_APP
+#ifndef MSDOS
 #define ACPI_DEBUG
+#endif
 #define ACPI_APPLICATION
-#define ENABLE_DEBUGGER
+#define ACPI_DISASSEMBLER
+#define ACPI_NO_METHOD_EXECUTION
 #define ACPI_USE_SYSTEM_CLIBRARY
-#define PARSER_ONLY
 #endif
 
 #ifdef _ACPI_EXEC_APP
@@ -136,13 +138,15 @@
 #define ACPI_DEBUG
 #define ACPI_APPLICATION
 #define ENABLE_DEBUGGER
+#define ACPI_DISASSEMBLER
 #define ACPI_USE_SYSTEM_CLIBRARY
 #endif
 
 #ifdef _ACPI_ASL_COMPILER
 #define ACPI_DEBUG
 #define ACPI_APPLICATION
-/* #define ENABLE_DEBUGGER */
+#define ACPI_DISASSEMBLER
+#define ACPI_CONSTANT_EVAL_ONLY
 #define ACPI_USE_SYSTEM_CLIBRARY
 #endif
 
@@ -276,7 +280,6 @@
 /*
  * Use the standard C library headers.
  * We want to keep these to a minimum.
- *
  */
 
 #ifdef ACPI_USE_STANDARD_HEADERS
@@ -306,12 +309,16 @@
 #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
+#define ACPI_IS_PRINT           isprint
+#define ACPI_IS_ALPHA           isalpha
+#define ACPI_IS_ASCII           isascii
 
 /******************************************************************************
  *

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acfreebsd.h#4 (text+ko) ====

@@ -126,6 +126,7 @@
 /* FreeBSD uses GCC */
 
 #include "acgcc.h"
+#include <machine/acpica_machdep.h>
 
 #ifdef _KERNEL
 #include "opt_acpi.h"
@@ -136,160 +137,6 @@
 #include <sys/libkern.h>
 #include <machine/stdarg.h>
 
-#ifdef __ia64__
-#define _IA64
-
-/*
- * 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() disable_intr()
-#define ACPI_ENABLE_IRQS()  enable_intr()
-
-#define ACPI_FLUSH_CPU_CACHE()	/* XXX ia64_fc()? */
-
-/*! [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 */
-
-/*
- * 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() disable_intr()
-#define ACPI_ENABLE_IRQS()  enable_intr()
-
-#define ACPI_FLUSH_CPU_CACHE()	wbinvd()
-
-#define asm         __asm
-/*! [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 */
-
 #ifdef DEBUGGER_THREADING
 #undef DEBUGGER_THREADING
 #endif /* DEBUGGER_THREADING */
@@ -349,15 +196,4 @@
 }
 #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__ */

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acpiosxf.h#6 (text+ko) ====

@@ -296,7 +296,6 @@
     void                    *Value,
     UINT32                  Width);
 
-
 ACPI_STATUS
 AcpiOsWritePort (
     ACPI_IO_ADDRESS         Address,
@@ -314,7 +313,6 @@
     void                    *Value,
     UINT32                  Width);
 
-
 ACPI_STATUS
 AcpiOsWriteMemory (
     ACPI_PHYSICAL_ADDRESS   Address,
@@ -333,7 +331,6 @@
     void                    *Value,
     UINT32                  Width);
 
-
 ACPI_STATUS
 AcpiOsWritePciConfiguration (
     ACPI_PCI_ID             *PciId,
@@ -351,7 +348,6 @@
     void                    *Pointer,
     UINT32                  Length);
 
-
 BOOLEAN
 AcpiOsWritable (
     void                    *Pointer,
@@ -380,6 +376,10 @@
     const NATIVE_CHAR       *Format,
     va_list                 Args);
 
+void
+AcpiOsRedirectOutput (
+    void                    *Destination);
+
 
 /*
  * Debug input

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acpixf.h#5 (text+ko) ====

@@ -135,6 +135,10 @@
     UINT32                  Flags);
 
 ACPI_STATUS
+AcpiInitializeObjects (
+    UINT32                  Flags);
+
+ACPI_STATUS
 AcpiTerminate (
     void);
 

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/acutils.h#6 (text+ko) ====

@@ -193,7 +193,6 @@
 
 #endif
 
-
 NATIVE_CHAR *
 AcpiUtGetTypeName (
     ACPI_OBJECT_TYPE        Type);
@@ -316,6 +315,9 @@
 #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))
+#define ACPI_IS_PRINT(c)  (_acpi_ctype[(unsigned char)(c)] & (_ACPI_LO | _ACPI_UP | _ACPI_DI | _ACPI_SP | _ACPI_PU))
+#define ACPI_IS_ALPHA(c)  (_acpi_ctype[(unsigned char)(c)] & (_ACPI_LO | _ACPI_UP))
+#define ACPI_IS_ASCII(c)  ((c) < 0x80)
 
 #endif /* ACPI_USE_SYSTEM_CLIBRARY */
 

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/dbcmds.c#6 (text+ko) ====

@@ -449,7 +449,9 @@
         NumStatements = ACPI_STRTOUL (Statements, NULL, 0);
     }
 
+#ifdef ACPI_DISASSEMBLER
     AcpiDmDisassemble (NULL, Op, NumStatements);
+#endif
 }
 
 

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/dbfileio.c#5 (text+ko) ====

@@ -121,7 +121,7 @@
 #include "acnamesp.h"
 #include "actables.h"
 
-#ifdef ENABLE_DEBUGGER
+#if (defined ENABLE_DEBUGGER || defined ACPI_DISASSEMBLER)
 
 #define _COMPONENT          ACPI_DEBUGGER
         ACPI_MODULE_NAME    ("dbfileio")
@@ -177,6 +177,7 @@
 }
 
 
+#ifdef ENABLE_DEBUGGER
 /*******************************************************************************
  *
  * FUNCTION:    AcpiDbCloseDebugFile
@@ -242,6 +243,7 @@
 
 #endif
 }
+#endif
 
 
 #ifdef ACPI_APPLICATION
@@ -285,7 +287,7 @@
 
     Status = AcpiTbValidateTableHeader (&TableHeader);
     if ((ACPI_FAILURE (Status)) ||
-        (TableHeader.Length > 524288))  /* 1/2 Mbyte should be enough */
+        (TableHeader.Length > 0x800000))  /* 8 Mbyte should be enough */
     {
         AcpiOsPrintf ("Table header is invalid!\n");
         return (AE_ERROR);
@@ -380,10 +382,15 @@
         return_ACPI_STATUS (AE_BAD_PARAMETER);
     }
 
+    TableInfo.Pointer = TablePtr;
+    Status = AcpiTbRecognizeTable (&TableInfo, ACPI_TABLE_SECONDARY);
+    if (ACPI_FAILURE (Status))
+    {
+        return_ACPI_STATUS (Status);
+    }
+
     /* Install the new table into the local data structures */
 
-    TableInfo.Pointer = TablePtr;
-
     Status = AcpiTbInstallTable (&TableInfo);
     if (ACPI_FAILURE (Status))
     {
@@ -394,7 +401,7 @@
     }
 
 
-#ifndef PARSER_ONLY
+#if (!defined (ACPI_NO_METHOD_EXECUTION) && !defined (ACPI_CONSTANT_EVAL_ONLY))
     Status = AcpiNsLoadTable (TableInfo.InstalledDesc, AcpiGbl_RootNode);
     if (ACPI_FAILURE (Status))
     {
@@ -430,7 +437,7 @@
 
     /* Get the entire file */
 
-    AcpiOsPrintf ("Loading Acpi table from file %s\n", Filename);
+    fprintf (stderr, "Loading Acpi table from file %s\n", Filename);
     Status = AcpiDbLoadTable (fp, &AcpiGbl_DbTablePtr, &TableLength);
     fclose(fp);
 
@@ -489,8 +496,8 @@
         return (Status);
     }
 
-    AcpiOsPrintf ("%4.4s at %p successfully installed and loaded\n",
-                                AcpiGbl_DbTablePtr->Signature, AcpiGbl_DbTablePtr);
+    fprintf (stderr, "Acpi table [%4.4s] successfully installed and loaded\n",
+                                AcpiGbl_DbTablePtr->Signature);
 
     AcpiGbl_AcpiHardwarePresent = FALSE;
 

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/dbxface.c#6 (text+ko) ====

@@ -269,7 +269,9 @@
 
         /* Now we can display it */
 
+#ifdef ACPI_DISASSEMBLER
         AcpiDmDisassemble (WalkState, DisplayOp, ACPI_UINT32_MAX);
+#endif
 
         if ((Op->Common.AmlOpcode == AML_IF_OP) ||
             (Op->Common.AmlOpcode == AML_WHILE_OP))
@@ -425,9 +427,11 @@
     AcpiGbl_DbOutputFlags       = ACPI_DB_CONSOLE_OUTPUT;
 
     AcpiGbl_DbOpt_tables        = FALSE;
+    AcpiGbl_DbOpt_stats         = FALSE;
+#ifdef ACPI_DISASSEMBLER
     AcpiGbl_DbOpt_disasm        = FALSE;
-    AcpiGbl_DbOpt_stats         = FALSE;
     AcpiGbl_DbOpt_verbose       = TRUE;
+#endif
     AcpiGbl_DbOpt_ini_methods   = TRUE;
 
     AcpiGbl_DbBuffer = AcpiOsAllocate (ACPI_DEBUG_BUFFER_SIZE);
@@ -475,11 +479,13 @@
         }
     }
 
+#ifdef ACPI_DISASSEMBLER
     if (!AcpiGbl_DbOpt_verbose)
     {
         AcpiGbl_DbOpt_disasm = TRUE;
         AcpiGbl_DbOpt_stats = FALSE;
     }
+#endif
 
     return (AE_OK);
 }

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/psparse.c#5 (text+ko) ====

@@ -590,7 +590,7 @@
     ParserState = &WalkState->ParserState;
     WalkState->ArgTypes = 0;
 
-#ifndef PARSER_ONLY
+#if (!defined (ACPI_NO_METHOD_EXECUTION) && !defined (ACPI_CONSTANT_EVAL_ONLY))
     if (WalkState->WalkType & ACPI_WALK_METHOD_RESTART)
     {
         /* We are restarting a preempted control method */
@@ -708,6 +708,10 @@
                 PreOp.Common.Value.Arg = NULL;
                 PreOp.Common.AmlOpcode = WalkState->Opcode;
 
+                /*
+                 * Get and append arguments until we find the node that contains
+                 * the name (the type ARGP_NAME).
+                 */
                 while (GET_CURRENT_ARG_TYPE (WalkState->ArgTypes) != ARGP_NAME)
                 {
                     Arg = AcpiPsGetNextArg (ParserState,
@@ -1297,7 +1301,6 @@
         /* We are done with this walk, move on to the parent if any */
 
         WalkState = AcpiDsPopWalkState (Thread);
-
         /* Save the last effective return value */
 
         if (CallerReturnDesc && WalkState->ReturnDesc)

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/rscreate.c#5 (text+ko) ====

@@ -132,7 +132,6 @@
  *
  * PARAMETERS:  ByteStreamBuffer        - Pointer to the resource byte stream
  *              OutputBuffer            - Pointer to the user's buffer
- *              OutputBufferLength      - Pointer to the size of OutputBuffer
  *
  * RETURN:      Status  - AE_OK if okay, else a valid ACPI_STATUS code
  *              If OutputBuffer is not large enough, OutputBufferLength
@@ -212,7 +211,6 @@
  * PARAMETERS:  PackageObject           - Pointer to an ACPI_OPERAND_OBJECT
  *                                        package
  *              OutputBuffer            - Pointer to the user's buffer
- *              OutputBufferLength      - Size of OutputBuffer
  *
  * RETURN:      Status  AE_OK if okay, else a valid ACPI_STATUS code.
  *              If the OutputBuffer is too small, the error will be
@@ -349,7 +347,7 @@
 
             if ((*SubObjectList)->Reference.Opcode != AML_INT_NAMEPATH_OP)
             {
-               ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Need name, found reference op %X\n",
+                ACPI_DEBUG_PRINT ((ACPI_DB_ERROR, "Need name, found reference op %X\n",
                     (*SubObjectList)->Reference.Opcode));
                 return_ACPI_STATUS (AE_BAD_DATA);
             }

==== //depot/projects/trustedbsd/base/sys/contrib/dev/acpica/tbget.c#5 (text+ko) ====

@@ -126,233 +126,158 @@
 
 /*******************************************************************************
  *
- * FUNCTION:    AcpiTbTableOverride
+ * FUNCTION:    AcpiTbGetTable
  *
- * PARAMETERS:  *TableInfo          - Info for current table
+ * PARAMETERS:  Address             - Address of table to retrieve.  Can be
+ *                                    Logical or Physical
+ *              TableInfo           - Where table info is returned
  *
  * RETURN:      None
  *
- * DESCRIPTION: Attempts override of current table with a new one if provided
- *              by the host OS.
+ * DESCRIPTION: Get entire table of unknown size.
  *
  ******************************************************************************/
 
-void
-AcpiTbTableOverride (
+ACPI_STATUS
+AcpiTbGetTable (
+    ACPI_POINTER            *Address,
     ACPI_TABLE_DESC         *TableInfo)
 {
-    ACPI_TABLE_HEADER       *NewTable;
     ACPI_STATUS             Status;
-    ACPI_POINTER            Address;
-    ACPI_TABLE_DESC         NewTableInfo;
+    ACPI_TABLE_HEADER       Header;
 
 
-    ACPI_FUNCTION_TRACE ("AcpiTbTableOverride");
+    ACPI_FUNCTION_TRACE ("TbGetTable");
 
 
-    Status = AcpiOsTableOverride (TableInfo->Pointer, &NewTable);
+    /*
+     * Get the header in order to get signature and table size
+     */
+    Status = AcpiTbGetTableHeader (Address, &Header);
     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;
+        return_ACPI_STATUS (Status);
     }
 
-    if (!NewTable)
-    {
-        /* No table override */
+    /* Get the entire table */
 
-        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);
+    Status = AcpiTbGetTableBody (Address, &Header, TableInfo);
     if (ACPI_FAILURE (Status))
     {
-        ACPI_REPORT_ERROR (("Could not copy ACPI table override\n"));
-        return_VOID;
+        ACPI_REPORT_ERROR (("Could not get ACPI table (size %X), %s\n", 
+            Header.Length, AcpiFormatException (Status)));
+        return_ACPI_STATUS (Status);
     }
 
-    /*
-     * 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;
+    return_ACPI_STATUS (AE_OK);
 }
 
 
 /*******************************************************************************
  *
- * FUNCTION:    AcpiTbGetTableWithOverride
+ * FUNCTION:    AcpiTbGetTableHeader
  *
- * PARAMETERS:  Address             - Physical or logical address of table
- *              *TableInfo          - Where the table info is returned
+ * PARAMETERS:  Address             - Address of table to retrieve.  Can be
+ *                                    Logical or Physical
+ *              ReturnHeader        - Where the table header is returned
  *
  * RETURN:      Status
  *
- * DESCRIPTION: Gets and installs the table with possible table override by OS.
+ * DESCRIPTION: Get an ACPI table header.  Works in both physical or virtual
+ *              addressing mode.  Works with both physical or logical pointers.
+ *              Table is either copied or mapped, depending on the pointer 
+ *              type and mode of the processor.
  *
  ******************************************************************************/
 
 ACPI_STATUS
-AcpiTbGetTableWithOverride (
+AcpiTbGetTableHeader (
     ACPI_POINTER            *Address,
-    ACPI_TABLE_DESC         *TableInfo)
+    ACPI_TABLE_HEADER       *ReturnHeader)
 {
-    ACPI_STATUS             Status;
+    ACPI_STATUS             Status = AE_OK;
+    ACPI_TABLE_HEADER       *Header = NULL;
 
 
-    ACPI_FUNCTION_TRACE ("AcpiTbGetTableWithOverride");
-
+    ACPI_FUNCTION_TRACE ("TbGetTableHeader");
 
-    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
+     * Flags contains the current processor mode (Virtual or Physical addressing)
+     * The PointerType is either Logical or Physical
      */
-    AcpiTbTableOverride (TableInfo);
+    switch (Address->PointerType)
+    {
+    case ACPI_PHYSMODE_PHYSPTR:
+    case ACPI_LOGMODE_LOGPTR:
 
-    /* Install the table */
+        /* Pointer matches processor mode, copy the header */
 
-    Status = AcpiTbInstallTable (TableInfo);
-    if (ACPI_FAILURE (Status))
-    {
-        ACPI_REPORT_ERROR (("Could not install ACPI table, %s\n", 
-            AcpiFormatException (Status)));
-    }
+        ACPI_MEMCPY (ReturnHeader, Address->Pointer.Logical, sizeof (ACPI_TABLE_HEADER));
+        break;
 
-    return_ACPI_STATUS (Status);
-}
 
+    case ACPI_LOGMODE_PHYSPTR:
 
-/*******************************************************************************
- *
- * FUNCTION:    AcpiTbGetTablePtr
- *
- * PARAMETERS:  TableType       - one of the defined table types
- *              Instance        - Which table of this type
- *              TablePtrLoc     - pointer to location to place the pointer for
- *                                return
- *
- * RETURN:      Status
- *
- * DESCRIPTION: This function is called to get the pointer to an ACPI table.
- *
- ******************************************************************************/
+        /* Create a logical address for the physical pointer*/
 
-ACPI_STATUS
-AcpiTbGetTablePtr (
-    ACPI_TABLE_TYPE         TableType,
-    UINT32                  Instance,
-    ACPI_TABLE_HEADER       **TablePtrLoc)
-{
-    ACPI_TABLE_DESC         *TableDesc;
-    UINT32                  i;
+        Status = AcpiOsMapMemory (Address->Pointer.Physical, sizeof (ACPI_TABLE_HEADER),
+                                    (void **) &Header);
+        if (ACPI_FAILURE (Status))
+        {
+            ACPI_REPORT_ERROR (("Could not map memory at %p for length %X\n",
+                Address->Pointer.Physical, sizeof (ACPI_TABLE_HEADER)));
+            return_ACPI_STATUS (Status);
+        }
 
+        /* Copy header and delete mapping */
 
-    ACPI_FUNCTION_TRACE ("TbGetTablePtr");
+        ACPI_MEMCPY (ReturnHeader, Header, sizeof (ACPI_TABLE_HEADER));
+        AcpiOsUnmapMemory (Header, sizeof (ACPI_TABLE_HEADER));
+        break;
 
 
-    if (!AcpiGbl_DSDT)
-    {
-        return_ACPI_STATUS (AE_NO_ACPI_TABLES);
-    }
+    default:
 
-    if (TableType > ACPI_TABLE_MAX)
-    {
+        ACPI_REPORT_ERROR (("Invalid address flags %X\n",
+            Address->PointerType));
         return_ACPI_STATUS (AE_BAD_PARAMETER);
     }
 
-    /*
-     * For all table types (Single/Multiple), the first
-     * instance is always in the list head.
-     */
-    if (Instance == 1)
-    {
-        /*
-         * Just pluck the pointer out of the global table!
-         * Will be null if no table is present
-         */
-        *TablePtrLoc = AcpiGbl_AcpiTables[TableType].Pointer;
-        return_ACPI_STATUS (AE_OK);
-    }
-
-    /*
-     * Check for instance out of range
-     */
-    if (Instance > AcpiGbl_AcpiTables[TableType].Count)
-    {
-        return_ACPI_STATUS (AE_NOT_EXIST);
-    }
-
-    /* Walk the list to get the desired table
-     * Since the if (Instance == 1) check above checked for the
-     * first table, setting TableDesc equal to the .Next member
-     * is actually pointing to the second table.  Therefore, we
-     * need to walk from the 2nd table until we reach the Instance
-     * that the user is looking for and return its table pointer.
-     */
-    TableDesc = AcpiGbl_AcpiTables[TableType].Next;
-    for (i = 2; i < Instance; i++)
-    {
-        TableDesc = TableDesc->Next;
-    }
-
-    /* We are now pointing to the requested table's descriptor */
-
-    *TablePtrLoc = TableDesc->Pointer;
-
     return_ACPI_STATUS (AE_OK);
 }
 
 
 /*******************************************************************************
  *
- * FUNCTION:    AcpiTbGetTable
+ * FUNCTION:    AcpiTbGetTableBody
  *
- * PARAMETERS:  Address             - Physical address of table to retrieve
- *              *TableInfo          - Where the table info is returned
+ * PARAMETERS:  Address             - Address of table to retrieve.  Can be
+ *                                    Logical or Physical
+ *              Header              - Header of the table to retrieve
+ *              TableInfo           - Where the table info is returned
  *
  * RETURN:      Status
  *
- * DESCRIPTION: Maps the physical address of table into a logical address
+ * DESCRIPTION: Get an entire ACPI table with support to allow the host OS to
+ *              replace the table with a newer version (table override.)  
+ *              Works in both physical or virtual
+ *              addressing mode.  Works with both physical or logical pointers.
+ *              Table is either copied or mapped, depending on the pointer 
+ *              type and mode of the processor.
  *
  ******************************************************************************/
 
 ACPI_STATUS
-AcpiTbGetTable (
+AcpiTbGetTableBody (
     ACPI_POINTER            *Address,
+    ACPI_TABLE_HEADER       *Header,
     ACPI_TABLE_DESC         *TableInfo)
 {
-    ACPI_TABLE_HEADER       *TableHeader = NULL;
-    ACPI_TABLE_HEADER       *FullTable = NULL;
-    ACPI_SIZE               Size;
-    UINT8                   Allocation;
-    ACPI_STATUS             Status = AE_OK;
+    ACPI_STATUS             Status;
 
 
-    ACPI_FUNCTION_TRACE ("TbGetTable");
+    ACPI_FUNCTION_TRACE ("TbGetTableBody");
 
 
     if (!TableInfo || !Address)
@@ -360,587 +285,298 @@
         return_ACPI_STATUS (AE_BAD_PARAMETER);
     }
 
-    switch (Address->PointerType)
+    /*
+     * Attempt table override.
+     */
+    Status = AcpiTbTableOverride (Header, TableInfo);
+    if (ACPI_SUCCESS (Status))
     {
-    case ACPI_LOGICAL_POINTER:
+        /* Table was overridden by the host OS */
 
-        /*
-         * Getting data from a buffer, not BIOS tables
-         */
-        TableHeader = Address->Pointer.Logical;
-
-        /* Allocate buffer for the entire table */
-
-        FullTable = ACPI_MEM_ALLOCATE (TableHeader->Length);
-        if (!FullTable)
-        {
-            return_ACPI_STATUS (AE_NO_MEMORY);
-        }
-
-        /* Copy the entire table (including header) to the local buffer */
-
-        Size = (ACPI_SIZE) TableHeader->Length;
-        ACPI_MEMCPY (FullTable, TableHeader, Size);
-
-        /* Save allocation type */
-
-        Allocation = ACPI_MEM_ALLOCATED;
-        break;
-
-
-    case ACPI_PHYSICAL_POINTER:
-
-        /*
-         * Not reading from a buffer, just map the table's physical memory
-         * into our address space.
-         */
-        Size = SIZE_IN_HEADER;
-
-        Status = AcpiTbMapAcpiTable (Address->Pointer.Physical, &Size, &FullTable);
-        if (ACPI_FAILURE (Status))

>>> TRUNCATED FOR MAIL (1000 lines) <<<
To Unsubscribe: send mail to majordomo at trustedbsd.org
with "unsubscribe trustedbsd-cvs" in the body of the message



More information about the trustedbsd-cvs mailing list