mirror of
https://github.com/reactos/reactos.git
synced 2025-04-06 05:34:22 +00:00
[ACPICA]
- Update to version 20141107 - Get rid of the ROS diffs in actypes.h by making use of the new ACPI_USE_SYSTEM_INTTYPES define svn path=/trunk/; revision=69866
This commit is contained in:
parent
8283006e8b
commit
95a246ddd5
177 changed files with 4385 additions and 1273 deletions
|
@ -133,11 +133,13 @@ list(APPEND ACPICA_SOURCE
|
|||
acpica/utilities/utcache.c
|
||||
acpica/utilities/utclib.c
|
||||
acpica/utilities/utcopy.c
|
||||
acpica/utilities/utdebug.c
|
||||
# acpica/utilities/utdebug.c
|
||||
acpica/utilities/utdecode.c
|
||||
acpica/utilities/utdelete.c
|
||||
acpica/utilities/uterror.c
|
||||
acpica/utilities/uteval.c
|
||||
# acpica/utilities/utfileio.c
|
||||
acpica/utilities/uthex.c
|
||||
acpica/utilities/utids.c
|
||||
acpica/utilities/utinit.c
|
||||
acpica/utilities/utlock.c
|
||||
|
@ -148,9 +150,11 @@ list(APPEND ACPICA_SOURCE
|
|||
acpica/utilities/utosi.c
|
||||
acpica/utilities/utownerid.c
|
||||
acpica/utilities/utpredef.c
|
||||
# acpica/utilities/utprint.c
|
||||
acpica/utilities/utresrc.c
|
||||
acpica/utilities/utstate.c
|
||||
acpica/utilities/utstring.c
|
||||
# acpica/utilities/utuuid.c
|
||||
acpica/utilities/uttrack.c
|
||||
acpica/utilities/utxface.c
|
||||
acpica/utilities/utxferror.c
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSARGS_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSCONTROL_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "amlcode.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSFIELD_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "amlcode.h"
|
||||
|
@ -463,6 +461,7 @@ AcpiDsGetFieldNames (
|
|||
*/
|
||||
Info->ResourceBuffer = NULL;
|
||||
Info->ConnectionNode = NULL;
|
||||
Info->PinNumberIndex = 0;
|
||||
|
||||
/*
|
||||
* A Connection() is either an actual resource descriptor (buffer)
|
||||
|
@ -538,6 +537,7 @@ AcpiDsGetFieldNames (
|
|||
}
|
||||
|
||||
Info->FieldBitPosition += Info->FieldBitLength;
|
||||
Info->PinNumberIndex++; /* Index relative to previous Connection() */
|
||||
break;
|
||||
|
||||
default:
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSINIT_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acdispat.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSMETHOD_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acdispat.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSMTHDAT_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acdispat.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSOBJECT_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSOPCODE_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSUTILS_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSWEXEC_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSWLOAD_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSWLOAD2_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __DSWSCOPE_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acdispat.h"
|
||||
|
|
|
@ -113,9 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __DSWSTATE_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -120,7 +120,9 @@
|
|||
|
||||
#define _COMPONENT ACPI_EVENTS
|
||||
ACPI_MODULE_NAME ("evglock")
|
||||
|
||||
#if ACPI_REDUCED_HARDWARE
|
||||
#error
|
||||
#endif
|
||||
#if (!ACPI_REDUCED_HARDWARE) /* Entire module */
|
||||
|
||||
/* Local prototypes */
|
||||
|
|
|
@ -504,7 +504,7 @@ AcpiEvGpeDetect (
|
|||
GpeRegisterInfo->EnableForWake))
|
||||
{
|
||||
ACPI_DEBUG_PRINT ((ACPI_DB_INTERRUPTS,
|
||||
"Ignore disabled registers for GPE%02X-GPE%02X: "
|
||||
"Ignore disabled registers for GPE %02X-%02X: "
|
||||
"RunEnable=%02X, WakeEnable=%02X\n",
|
||||
GpeRegisterInfo->BaseGpeNumber,
|
||||
GpeRegisterInfo->BaseGpeNumber + (ACPI_GPE_REGISTER_WIDTH - 1),
|
||||
|
@ -530,7 +530,7 @@ AcpiEvGpeDetect (
|
|||
}
|
||||
|
||||
ACPI_DEBUG_PRINT ((ACPI_DB_INTERRUPTS,
|
||||
"Read registers for GPE%02X-GPE%02X: Status=%02X, Enable=%02X, "
|
||||
"Read registers for GPE %02X-%02X: Status=%02X, Enable=%02X, "
|
||||
"RunEnable=%02X, WakeEnable=%02X\n",
|
||||
GpeRegisterInfo->BaseGpeNumber,
|
||||
GpeRegisterInfo->BaseGpeNumber + (ACPI_GPE_REGISTER_WIDTH - 1),
|
||||
|
@ -832,22 +832,6 @@ AcpiEvGpeDispatch (
|
|||
GpeNumber, AcpiGbl_GlobalEventHandlerContext);
|
||||
}
|
||||
|
||||
/*
|
||||
* If edge-triggered, clear the GPE status bit now. Note that
|
||||
* level-triggered events are cleared after the GPE is serviced.
|
||||
*/
|
||||
if ((GpeEventInfo->Flags & ACPI_GPE_XRUPT_TYPE_MASK) ==
|
||||
ACPI_GPE_EDGE_TRIGGERED)
|
||||
{
|
||||
Status = AcpiHwClearGpe (GpeEventInfo);
|
||||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
ACPI_EXCEPTION ((AE_INFO, Status,
|
||||
"Unable to clear GPE%02X", GpeNumber));
|
||||
return_UINT32 (ACPI_INTERRUPT_NOT_HANDLED);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Always disable the GPE so that it does not keep firing before
|
||||
* any asynchronous activity completes (either from the execution
|
||||
|
@ -861,10 +845,28 @@ AcpiEvGpeDispatch (
|
|||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
ACPI_EXCEPTION ((AE_INFO, Status,
|
||||
"Unable to disable GPE%02X", GpeNumber));
|
||||
"Unable to disable GPE %02X", GpeNumber));
|
||||
return_UINT32 (ACPI_INTERRUPT_NOT_HANDLED);
|
||||
}
|
||||
|
||||
/*
|
||||
* If edge-triggered, clear the GPE status bit now. Note that
|
||||
* level-triggered events are cleared after the GPE is serviced.
|
||||
*/
|
||||
if ((GpeEventInfo->Flags & ACPI_GPE_XRUPT_TYPE_MASK) ==
|
||||
ACPI_GPE_EDGE_TRIGGERED)
|
||||
{
|
||||
Status = AcpiHwClearGpe (GpeEventInfo);
|
||||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
ACPI_EXCEPTION ((AE_INFO, Status,
|
||||
"Unable to clear GPE %02X", GpeNumber));
|
||||
(void) AcpiHwLowSetGpe (GpeEventInfo,
|
||||
ACPI_GPE_CONDITIONAL_ENABLE);
|
||||
return_UINT32 (ACPI_INTERRUPT_NOT_HANDLED);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Dispatch the GPE to either an installed handler or the control
|
||||
* method associated with this GPE (_Lxx or _Exx). If a handler
|
||||
|
@ -901,7 +903,7 @@ AcpiEvGpeDispatch (
|
|||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
ACPI_EXCEPTION ((AE_INFO, Status,
|
||||
"Unable to queue handler for GPE%02X - event disabled",
|
||||
"Unable to queue handler for GPE %02X - event disabled",
|
||||
GpeNumber));
|
||||
}
|
||||
break;
|
||||
|
@ -913,7 +915,7 @@ AcpiEvGpeDispatch (
|
|||
* a GPE to be enabled if it has no handler or method.
|
||||
*/
|
||||
ACPI_ERROR ((AE_INFO,
|
||||
"No handler or method for GPE%02X, disabling event",
|
||||
"No handler or method for GPE %02X, disabling event",
|
||||
GpeNumber));
|
||||
break;
|
||||
}
|
||||
|
|
|
@ -354,17 +354,17 @@ AcpiEvCreateGpeInfoBlocks (
|
|||
{
|
||||
/* Init the RegisterInfo for this GPE register (8 GPEs) */
|
||||
|
||||
ThisRegister->BaseGpeNumber = (UINT8) (GpeBlock->BlockBaseNumber +
|
||||
(i * ACPI_GPE_REGISTER_WIDTH));
|
||||
ThisRegister->BaseGpeNumber = (UINT16)
|
||||
(GpeBlock->BlockBaseNumber + (i * ACPI_GPE_REGISTER_WIDTH));
|
||||
|
||||
ThisRegister->StatusAddress.Address =
|
||||
GpeBlock->BlockAddress.Address + i;
|
||||
GpeBlock->Address + i;
|
||||
|
||||
ThisRegister->EnableAddress.Address =
|
||||
GpeBlock->BlockAddress.Address + i + GpeBlock->RegisterCount;
|
||||
GpeBlock->Address + i + GpeBlock->RegisterCount;
|
||||
|
||||
ThisRegister->StatusAddress.SpaceId = GpeBlock->BlockAddress.SpaceId;
|
||||
ThisRegister->EnableAddress.SpaceId = GpeBlock->BlockAddress.SpaceId;
|
||||
ThisRegister->StatusAddress.SpaceId = GpeBlock->SpaceId;
|
||||
ThisRegister->EnableAddress.SpaceId = GpeBlock->SpaceId;
|
||||
ThisRegister->StatusAddress.BitWidth = ACPI_GPE_REGISTER_WIDTH;
|
||||
ThisRegister->EnableAddress.BitWidth = ACPI_GPE_REGISTER_WIDTH;
|
||||
ThisRegister->StatusAddress.BitOffset = 0;
|
||||
|
@ -437,9 +437,10 @@ ErrorExit:
|
|||
ACPI_STATUS
|
||||
AcpiEvCreateGpeBlock (
|
||||
ACPI_NAMESPACE_NODE *GpeDevice,
|
||||
ACPI_GENERIC_ADDRESS *GpeBlockAddress,
|
||||
UINT64 Address,
|
||||
UINT8 SpaceId,
|
||||
UINT32 RegisterCount,
|
||||
UINT8 GpeBlockBaseNumber,
|
||||
UINT16 GpeBlockBaseNumber,
|
||||
UINT32 InterruptNumber,
|
||||
ACPI_GPE_BLOCK_INFO **ReturnGpeBlock)
|
||||
{
|
||||
|
@ -466,15 +467,14 @@ AcpiEvCreateGpeBlock (
|
|||
|
||||
/* Initialize the new GPE block */
|
||||
|
||||
GpeBlock->Address = Address;
|
||||
GpeBlock->SpaceId = SpaceId;
|
||||
GpeBlock->Node = GpeDevice;
|
||||
GpeBlock->GpeCount = (UINT16) (RegisterCount * ACPI_GPE_REGISTER_WIDTH);
|
||||
GpeBlock->Initialized = FALSE;
|
||||
GpeBlock->RegisterCount = RegisterCount;
|
||||
GpeBlock->BlockBaseNumber = GpeBlockBaseNumber;
|
||||
|
||||
ACPI_MEMCPY (&GpeBlock->BlockAddress, GpeBlockAddress,
|
||||
sizeof (ACPI_GENERIC_ADDRESS));
|
||||
|
||||
/*
|
||||
* Create the RegisterInfo and EventInfo sub-structures
|
||||
* Note: disables and clears all GPEs in the block
|
||||
|
@ -517,11 +517,11 @@ AcpiEvCreateGpeBlock (
|
|||
}
|
||||
|
||||
ACPI_DEBUG_PRINT_RAW ((ACPI_DB_INIT,
|
||||
" Initialized GPE %02X to %02X [%4.4s] %u regs on interrupt 0x%X\n",
|
||||
" Initialized GPE %02X to %02X [%4.4s] %u regs on interrupt 0x%X%s\n",
|
||||
(UINT32) GpeBlock->BlockBaseNumber,
|
||||
(UINT32) (GpeBlock->BlockBaseNumber + (GpeBlock->GpeCount - 1)),
|
||||
GpeDevice->Name.Ascii, GpeBlock->RegisterCount,
|
||||
InterruptNumber));
|
||||
GpeDevice->Name.Ascii, GpeBlock->RegisterCount, InterruptNumber,
|
||||
InterruptNumber == AcpiGbl_FADT.SciInterrupt ? " (SCI)" : ""));
|
||||
|
||||
/* Update global count of currently available GPEs */
|
||||
|
||||
|
|
|
@ -113,7 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acevents.h"
|
||||
|
@ -211,7 +210,9 @@ AcpiEvGpeInitialize (
|
|||
/* Install GPE Block 0 */
|
||||
|
||||
Status = AcpiEvCreateGpeBlock (AcpiGbl_FadtGpeDevice,
|
||||
&AcpiGbl_FADT.XGpe0Block, RegisterCount0, 0,
|
||||
AcpiGbl_FADT.XGpe0Block.Address,
|
||||
AcpiGbl_FADT.XGpe0Block.SpaceId,
|
||||
RegisterCount0, 0,
|
||||
AcpiGbl_FADT.SciInterrupt, &AcpiGbl_GpeFadtBlocks[0]);
|
||||
|
||||
if (ACPI_FAILURE (Status))
|
||||
|
@ -249,7 +250,9 @@ AcpiEvGpeInitialize (
|
|||
/* Install GPE Block 1 */
|
||||
|
||||
Status = AcpiEvCreateGpeBlock (AcpiGbl_FadtGpeDevice,
|
||||
&AcpiGbl_FADT.XGpe1Block, RegisterCount1,
|
||||
AcpiGbl_FADT.XGpe1Block.Address,
|
||||
AcpiGbl_FADT.XGpe1Block.SpaceId,
|
||||
RegisterCount1,
|
||||
AcpiGbl_FADT.Gpe1Base,
|
||||
AcpiGbl_FADT.SciInterrupt, &AcpiGbl_GpeFadtBlocks[1]);
|
||||
|
||||
|
@ -512,6 +515,10 @@ AcpiEvMatchGpeMethod (
|
|||
return_ACPI_STATUS (AE_OK);
|
||||
}
|
||||
|
||||
/* Disable the GPE in case it's been enabled already. */
|
||||
|
||||
(void) AcpiHwLowSetGpe (GpeEventInfo, ACPI_GPE_DISABLE);
|
||||
|
||||
/*
|
||||
* Add the GPE information from above to the GpeEventInfo block for
|
||||
* use during dispatch of this GPE.
|
||||
|
|
|
@ -113,9 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EVHANDLER_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acevents.h"
|
||||
|
|
|
@ -113,9 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EVREGION_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acevents.h"
|
||||
|
@ -231,6 +228,7 @@ AcpiEvAddressSpaceDispatch (
|
|||
ACPI_OPERAND_OBJECT *RegionObj2;
|
||||
void *RegionContext = NULL;
|
||||
ACPI_CONNECTION_INFO *Context;
|
||||
ACPI_PHYSICAL_ADDRESS Address;
|
||||
|
||||
|
||||
ACPI_FUNCTION_TRACE (EvAddressSpaceDispatch);
|
||||
|
@ -320,23 +318,23 @@ AcpiEvAddressSpaceDispatch (
|
|||
/* We have everything we need, we can invoke the address space handler */
|
||||
|
||||
Handler = HandlerDesc->AddressSpace.Handler;
|
||||
|
||||
ACPI_DEBUG_PRINT ((ACPI_DB_OPREGION,
|
||||
"Handler %p (@%p) Address %8.8X%8.8X [%s]\n",
|
||||
&RegionObj->Region.Handler->AddressSpace, Handler,
|
||||
ACPI_FORMAT_NATIVE_UINT (RegionObj->Region.Address + RegionOffset),
|
||||
AcpiUtGetRegionName (RegionObj->Region.SpaceId)));
|
||||
Address = (RegionObj->Region.Address + RegionOffset);
|
||||
|
||||
/*
|
||||
* Special handling for GenericSerialBus and GeneralPurposeIo:
|
||||
* There are three extra parameters that must be passed to the
|
||||
* handler via the context:
|
||||
* 1) Connection buffer, a resource template from Connection() op.
|
||||
* 2) Length of the above buffer.
|
||||
* 3) Actual access length from the AccessAs() op.
|
||||
* 1) Connection buffer, a resource template from Connection() op
|
||||
* 2) Length of the above buffer
|
||||
* 3) Actual access length from the AccessAs() op
|
||||
*
|
||||
* In addition, for GeneralPurposeIo, the Address and BitWidth fields
|
||||
* are defined as follows:
|
||||
* 1) Address is the pin number index of the field (bit offset from
|
||||
* the previous Connection)
|
||||
* 2) BitWidth is the actual bit length of the field (number of pins)
|
||||
*/
|
||||
if (((RegionObj->Region.SpaceId == ACPI_ADR_SPACE_GSBUS) ||
|
||||
(RegionObj->Region.SpaceId == ACPI_ADR_SPACE_GPIO)) &&
|
||||
if ((RegionObj->Region.SpaceId == ACPI_ADR_SPACE_GSBUS) &&
|
||||
Context &&
|
||||
FieldObj)
|
||||
{
|
||||
|
@ -346,6 +344,24 @@ AcpiEvAddressSpaceDispatch (
|
|||
Context->Length = FieldObj->Field.ResourceLength;
|
||||
Context->AccessLength = FieldObj->Field.AccessLength;
|
||||
}
|
||||
if ((RegionObj->Region.SpaceId == ACPI_ADR_SPACE_GPIO) &&
|
||||
Context &&
|
||||
FieldObj)
|
||||
{
|
||||
/* Get the Connection (ResourceTemplate) buffer */
|
||||
|
||||
Context->Connection = FieldObj->Field.ResourceBuffer;
|
||||
Context->Length = FieldObj->Field.ResourceLength;
|
||||
Context->AccessLength = FieldObj->Field.AccessLength;
|
||||
Address = FieldObj->Field.PinNumberIndex;
|
||||
BitWidth = FieldObj->Field.BitLength;
|
||||
}
|
||||
|
||||
ACPI_DEBUG_PRINT ((ACPI_DB_OPREGION,
|
||||
"Handler %p (@%p) Address %8.8X%8.8X [%s]\n",
|
||||
&RegionObj->Region.Handler->AddressSpace, Handler,
|
||||
ACPI_FORMAT_NATIVE_UINT (Address),
|
||||
AcpiUtGetRegionName (RegionObj->Region.SpaceId)));
|
||||
|
||||
if (!(HandlerDesc->AddressSpace.HandlerFlags &
|
||||
ACPI_ADDR_HANDLER_DEFAULT_INSTALLED))
|
||||
|
@ -360,9 +376,8 @@ AcpiEvAddressSpaceDispatch (
|
|||
|
||||
/* Call the handler */
|
||||
|
||||
Status = Handler (Function,
|
||||
(RegionObj->Region.Address + RegionOffset), BitWidth, Value,
|
||||
Context, RegionObj2->Extra.RegionContext);
|
||||
Status = Handler (Function, Address, BitWidth, Value, Context,
|
||||
RegionObj2->Extra.RegionContext);
|
||||
|
||||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
|
|
|
@ -113,9 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EVRGNINI_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acevents.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EVXFACE_C__
|
||||
#define EXPORT_ACPI_INTERFACES
|
||||
|
||||
#include "acpi.h"
|
||||
|
@ -1109,7 +1107,8 @@ AcpiRemoveGpeHandler (
|
|||
* enabled, it should be enabled at this point to restore the
|
||||
* post-initialization configuration.
|
||||
*/
|
||||
if ((Handler->OriginalFlags & ACPI_GPE_DISPATCH_METHOD) &&
|
||||
if (((Handler->OriginalFlags & ACPI_GPE_DISPATCH_METHOD) ||
|
||||
(Handler->OriginalFlags & ACPI_GPE_DISPATCH_NOTIFY)) &&
|
||||
Handler->OriginallyEnabled)
|
||||
{
|
||||
(void) AcpiEvAddGpeReference (GpeEventInfo);
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EVXFEVNT_C__
|
||||
#define EXPORT_ACPI_INTERFACES
|
||||
|
||||
#include "acpi.h"
|
||||
|
@ -437,7 +435,9 @@ AcpiGetEventStatus (
|
|||
UINT32 Event,
|
||||
ACPI_EVENT_STATUS *EventStatus)
|
||||
{
|
||||
ACPI_STATUS Status = AE_OK;
|
||||
ACPI_STATUS Status;
|
||||
ACPI_EVENT_STATUS LocalEventStatus = 0;
|
||||
UINT32 InByte;
|
||||
|
||||
|
||||
ACPI_FUNCTION_TRACE (AcpiGetEventStatus);
|
||||
|
@ -455,12 +455,43 @@ AcpiGetEventStatus (
|
|||
return_ACPI_STATUS (AE_BAD_PARAMETER);
|
||||
}
|
||||
|
||||
/* Get the status of the requested fixed event */
|
||||
/* Fixed event currently can be dispatched? */
|
||||
|
||||
if (AcpiGbl_FixedEventHandlers[Event].Handler)
|
||||
{
|
||||
LocalEventStatus |= ACPI_EVENT_FLAG_HAS_HANDLER;
|
||||
}
|
||||
|
||||
/* Fixed event currently enabled? */
|
||||
|
||||
Status = AcpiReadBitRegister (
|
||||
AcpiGbl_FixedEventInfo[Event].StatusRegisterId, EventStatus);
|
||||
AcpiGbl_FixedEventInfo[Event].EnableRegisterId, &InByte);
|
||||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
return_ACPI_STATUS (Status);
|
||||
}
|
||||
|
||||
return_ACPI_STATUS (Status);
|
||||
if (InByte)
|
||||
{
|
||||
LocalEventStatus |= ACPI_EVENT_FLAG_ENABLED;
|
||||
}
|
||||
|
||||
/* Fixed event currently active? */
|
||||
|
||||
Status = AcpiReadBitRegister (
|
||||
AcpiGbl_FixedEventInfo[Event].StatusRegisterId, &InByte);
|
||||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
return_ACPI_STATUS (Status);
|
||||
}
|
||||
|
||||
if (InByte)
|
||||
{
|
||||
LocalEventStatus |= ACPI_EVENT_FLAG_SET;
|
||||
}
|
||||
|
||||
(*EventStatus) = LocalEventStatus;
|
||||
return_ACPI_STATUS (AE_OK);
|
||||
}
|
||||
|
||||
ACPI_EXPORT_SYMBOL (AcpiGetEventStatus)
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EVXFGPE_C__
|
||||
#define EXPORT_ACPI_INTERFACES
|
||||
|
||||
#include "acpi.h"
|
||||
|
@ -213,12 +211,23 @@ AcpiEnableGpe (
|
|||
|
||||
Flags = AcpiOsAcquireLock (AcpiGbl_GpeLock);
|
||||
|
||||
/* Ensure that we have a valid GPE number */
|
||||
|
||||
/*
|
||||
* Ensure that we have a valid GPE number and that there is some way
|
||||
* of handling the GPE (handler or a GPE method). In other words, we
|
||||
* won't allow a valid GPE to be enabled if there is no way to handle it.
|
||||
*/
|
||||
GpeEventInfo = AcpiEvGetGpeEventInfo (GpeDevice, GpeNumber);
|
||||
if (GpeEventInfo)
|
||||
{
|
||||
Status = AcpiEvAddGpeReference (GpeEventInfo);
|
||||
if ((GpeEventInfo->Flags & ACPI_GPE_DISPATCH_MASK) !=
|
||||
ACPI_GPE_DISPATCH_NONE)
|
||||
{
|
||||
Status = AcpiEvAddGpeReference (GpeEventInfo);
|
||||
}
|
||||
else
|
||||
{
|
||||
Status = AE_NO_HANDLER;
|
||||
}
|
||||
}
|
||||
|
||||
AcpiOsReleaseLock (AcpiGbl_GpeLock, Flags);
|
||||
|
@ -346,6 +355,60 @@ UnlockAndExit:
|
|||
ACPI_EXPORT_SYMBOL (AcpiSetGpe)
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
*
|
||||
* FUNCTION: AcpiMarkGpeForWake
|
||||
*
|
||||
* PARAMETERS: GpeDevice - Parent GPE Device. NULL for GPE0/GPE1
|
||||
* GpeNumber - GPE level within the GPE block
|
||||
*
|
||||
* RETURN: Status
|
||||
*
|
||||
* DESCRIPTION: Mark a GPE as having the ability to wake the system. Simply
|
||||
* sets the ACPI_GPE_CAN_WAKE flag.
|
||||
*
|
||||
* Some potential callers of AcpiSetupGpeForWake may know in advance that
|
||||
* there won't be any notify handlers installed for device wake notifications
|
||||
* from the given GPE (one example is a button GPE in Linux). For these cases,
|
||||
* AcpiMarkGpeForWake should be used instead of AcpiSetupGpeForWake.
|
||||
* This will set the ACPI_GPE_CAN_WAKE flag for the GPE without trying to
|
||||
* setup implicit wake notification for it (since there's no handler method).
|
||||
*
|
||||
******************************************************************************/
|
||||
|
||||
ACPI_STATUS
|
||||
AcpiMarkGpeForWake (
|
||||
ACPI_HANDLE GpeDevice,
|
||||
UINT32 GpeNumber)
|
||||
{
|
||||
ACPI_GPE_EVENT_INFO *GpeEventInfo;
|
||||
ACPI_STATUS Status = AE_BAD_PARAMETER;
|
||||
ACPI_CPU_FLAGS Flags;
|
||||
|
||||
|
||||
ACPI_FUNCTION_TRACE (AcpiMarkGpeForWake);
|
||||
|
||||
|
||||
Flags = AcpiOsAcquireLock (AcpiGbl_GpeLock);
|
||||
|
||||
/* Ensure that we have a valid GPE number */
|
||||
|
||||
GpeEventInfo = AcpiEvGetGpeEventInfo (GpeDevice, GpeNumber);
|
||||
if (GpeEventInfo)
|
||||
{
|
||||
/* Mark the GPE as a possible wake event */
|
||||
|
||||
GpeEventInfo->Flags |= ACPI_GPE_CAN_WAKE;
|
||||
Status = AE_OK;
|
||||
}
|
||||
|
||||
AcpiOsReleaseLock (AcpiGbl_GpeLock, Flags);
|
||||
return_ACPI_STATUS (Status);
|
||||
}
|
||||
|
||||
ACPI_EXPORT_SYMBOL (AcpiMarkGpeForWake)
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
*
|
||||
* FUNCTION: AcpiSetupGpeForWake
|
||||
|
@ -881,7 +944,8 @@ AcpiInstallGpeBlock (
|
|||
* For user-installed GPE Block Devices, the GpeBlockBaseNumber
|
||||
* is always zero
|
||||
*/
|
||||
Status = AcpiEvCreateGpeBlock (Node, GpeBlockAddress, RegisterCount,
|
||||
Status = AcpiEvCreateGpeBlock (Node, GpeBlockAddress->Address,
|
||||
GpeBlockAddress->SpaceId, RegisterCount,
|
||||
0, InterruptNumber, &GpeBlock);
|
||||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
|
|
|
@ -114,7 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EVXFREGN_C__
|
||||
#define EXPORT_ACPI_INTERFACES
|
||||
|
||||
#include "acpi.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXCONFIG_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -113,9 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EXCONVRT_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXCREATE_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXDEBUG_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
@ -154,6 +152,7 @@ AcpiExDoDebugObject (
|
|||
UINT32 Index)
|
||||
{
|
||||
UINT32 i;
|
||||
UINT32 Timer;
|
||||
|
||||
|
||||
ACPI_FUNCTION_TRACE_PTR (ExDoDebugObject, SourceDesc);
|
||||
|
@ -167,13 +166,21 @@ AcpiExDoDebugObject (
|
|||
return_VOID;
|
||||
}
|
||||
|
||||
/*
|
||||
* We will emit the current timer value (in microseconds) with each
|
||||
* debug output. Only need the lower 26 bits. This allows for 67
|
||||
* million microseconds or 67 seconds before rollover.
|
||||
*/
|
||||
Timer = ((UINT32) AcpiOsGetTimer () / 10); /* (100 nanoseconds to microseconds) */
|
||||
Timer &= 0x03FFFFFF;
|
||||
|
||||
/*
|
||||
* Print line header as long as we are not in the middle of an
|
||||
* object display
|
||||
*/
|
||||
if (!((Level > 0) && Index == 0))
|
||||
{
|
||||
AcpiOsPrintf ("[ACPI Debug] %*s", Level, " ");
|
||||
AcpiOsPrintf ("[ACPI Debug %.8u] %*s", Timer, Level, " ");
|
||||
}
|
||||
|
||||
/* Display the index for package output only */
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXDUMP_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
@ -580,7 +578,7 @@ AcpiExDumpObject (
|
|||
}
|
||||
}
|
||||
|
||||
AcpiOsPrintf ("\n", Next);
|
||||
AcpiOsPrintf ("\n");
|
||||
break;
|
||||
|
||||
case ACPI_EXD_HDLR_LIST:
|
||||
|
@ -614,7 +612,7 @@ AcpiExDumpObject (
|
|||
}
|
||||
}
|
||||
|
||||
AcpiOsPrintf ("\n", Next);
|
||||
AcpiOsPrintf ("\n");
|
||||
break;
|
||||
|
||||
case ACPI_EXD_RGN_LIST:
|
||||
|
@ -648,7 +646,7 @@ AcpiExDumpObject (
|
|||
}
|
||||
}
|
||||
|
||||
AcpiOsPrintf ("\n", Next);
|
||||
AcpiOsPrintf ("\n");
|
||||
break;
|
||||
|
||||
case ACPI_EXD_NODE:
|
||||
|
|
|
@ -113,18 +113,84 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EXFIELD_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acdispat.h"
|
||||
#include "acinterp.h"
|
||||
#include "amlcode.h"
|
||||
|
||||
|
||||
#define _COMPONENT ACPI_EXECUTER
|
||||
ACPI_MODULE_NAME ("exfield")
|
||||
|
||||
/* Local prototypes */
|
||||
|
||||
static UINT32
|
||||
AcpiExGetSerialAccessLength (
|
||||
UINT32 AccessorType,
|
||||
UINT32 AccessLength);
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
*
|
||||
* FUNCTION: AcpiExGetSerialAccessLength
|
||||
*
|
||||
* PARAMETERS: AccessorType - The type of the protocol indicated by region
|
||||
* field access attributes
|
||||
* AccessLength - The access length of the region field
|
||||
*
|
||||
* RETURN: Decoded access length
|
||||
*
|
||||
* DESCRIPTION: This routine returns the length of the GenericSerialBus
|
||||
* protocol bytes
|
||||
*
|
||||
******************************************************************************/
|
||||
|
||||
static UINT32
|
||||
AcpiExGetSerialAccessLength (
|
||||
UINT32 AccessorType,
|
||||
UINT32 AccessLength)
|
||||
{
|
||||
UINT32 Length;
|
||||
|
||||
|
||||
switch (AccessorType)
|
||||
{
|
||||
case AML_FIELD_ATTRIB_QUICK:
|
||||
|
||||
Length = 0;
|
||||
break;
|
||||
|
||||
case AML_FIELD_ATTRIB_SEND_RCV:
|
||||
case AML_FIELD_ATTRIB_BYTE:
|
||||
|
||||
Length = 1;
|
||||
break;
|
||||
|
||||
case AML_FIELD_ATTRIB_WORD:
|
||||
case AML_FIELD_ATTRIB_WORD_CALL:
|
||||
|
||||
Length = 2;
|
||||
break;
|
||||
|
||||
case AML_FIELD_ATTRIB_MULTIBYTE:
|
||||
case AML_FIELD_ATTRIB_RAW_BYTES:
|
||||
case AML_FIELD_ATTRIB_RAW_PROCESS:
|
||||
|
||||
Length = AccessLength;
|
||||
break;
|
||||
|
||||
case AML_FIELD_ATTRIB_BLOCK:
|
||||
case AML_FIELD_ATTRIB_BLOCK_CALL:
|
||||
default:
|
||||
|
||||
Length = ACPI_GSBUS_BUFFER_SIZE - 2;
|
||||
break;
|
||||
}
|
||||
|
||||
return (Length);
|
||||
}
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
*
|
||||
|
@ -152,6 +218,7 @@ AcpiExReadDataFromField (
|
|||
ACPI_SIZE Length;
|
||||
void *Buffer;
|
||||
UINT32 Function;
|
||||
UINT16 AccessorType;
|
||||
|
||||
|
||||
ACPI_FUNCTION_TRACE_PTR (ExReadDataFromField, ObjDesc);
|
||||
|
@ -201,8 +268,19 @@ AcpiExReadDataFromField (
|
|||
}
|
||||
else if (ObjDesc->Field.RegionObj->Region.SpaceId == ACPI_ADR_SPACE_GSBUS)
|
||||
{
|
||||
Length = ACPI_GSBUS_BUFFER_SIZE;
|
||||
Function = ACPI_READ | (ObjDesc->Field.Attribute << 16);
|
||||
AccessorType = ObjDesc->Field.Attribute;
|
||||
Length = AcpiExGetSerialAccessLength (AccessorType,
|
||||
ObjDesc->Field.AccessLength);
|
||||
|
||||
/*
|
||||
* Add additional 2 bytes for the GenericSerialBus data buffer:
|
||||
*
|
||||
* Status; (Byte 0 of the data buffer)
|
||||
* Length; (Byte 1 of the data buffer)
|
||||
* Data[x-1]; (Bytes 2-x of the arbitrary length data buffer)
|
||||
*/
|
||||
Length += 2;
|
||||
Function = ACPI_READ | (AccessorType << 16);
|
||||
}
|
||||
else /* IPMI */
|
||||
{
|
||||
|
@ -265,6 +343,39 @@ AcpiExReadDataFromField (
|
|||
Buffer = &BufferDesc->Integer.Value;
|
||||
}
|
||||
|
||||
if ((ObjDesc->Common.Type == ACPI_TYPE_LOCAL_REGION_FIELD) &&
|
||||
(ObjDesc->Field.RegionObj->Region.SpaceId == ACPI_ADR_SPACE_GPIO))
|
||||
{
|
||||
/*
|
||||
* For GPIO (GeneralPurposeIo), the Address will be the bit offset
|
||||
* from the previous Connection() operator, making it effectively a
|
||||
* pin number index. The BitLength is the length of the field, which
|
||||
* is thus the number of pins.
|
||||
*/
|
||||
ACPI_DEBUG_PRINT ((ACPI_DB_BFIELD,
|
||||
"GPIO FieldRead [FROM]: Pin %u Bits %u\n",
|
||||
ObjDesc->Field.PinNumberIndex, ObjDesc->Field.BitLength));
|
||||
|
||||
/* Lock entire transaction if requested */
|
||||
|
||||
AcpiExAcquireGlobalLock (ObjDesc->CommonField.FieldFlags);
|
||||
|
||||
/* Perform the write */
|
||||
|
||||
Status = AcpiExAccessRegion (ObjDesc, 0,
|
||||
(UINT64 *) Buffer, ACPI_READ);
|
||||
AcpiExReleaseGlobalLock (ObjDesc->CommonField.FieldFlags);
|
||||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
AcpiUtRemoveReference (BufferDesc);
|
||||
}
|
||||
else
|
||||
{
|
||||
*RetBufferDesc = BufferDesc;
|
||||
}
|
||||
return_ACPI_STATUS (Status);
|
||||
}
|
||||
|
||||
ACPI_DEBUG_PRINT ((ACPI_DB_BFIELD,
|
||||
"FieldRead [TO]: Obj %p, Type %X, Buf %p, ByteLen %X\n",
|
||||
ObjDesc, ObjDesc->Common.Type, Buffer, (UINT32) Length));
|
||||
|
@ -323,6 +434,7 @@ AcpiExWriteDataToField (
|
|||
void *Buffer;
|
||||
ACPI_OPERAND_OBJECT *BufferDesc;
|
||||
UINT32 Function;
|
||||
UINT16 AccessorType;
|
||||
|
||||
|
||||
ACPI_FUNCTION_TRACE_PTR (ExWriteDataToField, ObjDesc);
|
||||
|
@ -382,8 +494,19 @@ AcpiExWriteDataToField (
|
|||
}
|
||||
else if (ObjDesc->Field.RegionObj->Region.SpaceId == ACPI_ADR_SPACE_GSBUS)
|
||||
{
|
||||
Length = ACPI_GSBUS_BUFFER_SIZE;
|
||||
Function = ACPI_WRITE | (ObjDesc->Field.Attribute << 16);
|
||||
AccessorType = ObjDesc->Field.Attribute;
|
||||
Length = AcpiExGetSerialAccessLength (AccessorType,
|
||||
ObjDesc->Field.AccessLength);
|
||||
|
||||
/*
|
||||
* Add additional 2 bytes for the GenericSerialBus data buffer:
|
||||
*
|
||||
* Status; (Byte 0 of the data buffer)
|
||||
* Length; (Byte 1 of the data buffer)
|
||||
* Data[x-1]; (Bytes 2-x of the arbitrary length data buffer)
|
||||
*/
|
||||
Length += 2;
|
||||
Function = ACPI_WRITE | (AccessorType << 16);
|
||||
}
|
||||
else /* IPMI */
|
||||
{
|
||||
|
@ -426,6 +549,41 @@ AcpiExWriteDataToField (
|
|||
*ResultDesc = BufferDesc;
|
||||
return_ACPI_STATUS (Status);
|
||||
}
|
||||
else if ((ObjDesc->Common.Type == ACPI_TYPE_LOCAL_REGION_FIELD) &&
|
||||
(ObjDesc->Field.RegionObj->Region.SpaceId == ACPI_ADR_SPACE_GPIO))
|
||||
{
|
||||
/*
|
||||
* For GPIO (GeneralPurposeIo), we will bypass the entire field
|
||||
* mechanism and handoff the bit address and bit width directly to
|
||||
* the handler. The Address will be the bit offset
|
||||
* from the previous Connection() operator, making it effectively a
|
||||
* pin number index. The BitLength is the length of the field, which
|
||||
* is thus the number of pins.
|
||||
*/
|
||||
if (SourceDesc->Common.Type != ACPI_TYPE_INTEGER)
|
||||
{
|
||||
return_ACPI_STATUS (AE_AML_OPERAND_TYPE);
|
||||
}
|
||||
|
||||
ACPI_DEBUG_PRINT ((ACPI_DB_BFIELD,
|
||||
"GPIO FieldWrite [FROM]: (%s:%X), Val %.8X [TO]: Pin %u Bits %u\n",
|
||||
AcpiUtGetTypeName (SourceDesc->Common.Type),
|
||||
SourceDesc->Common.Type, (UINT32) SourceDesc->Integer.Value,
|
||||
ObjDesc->Field.PinNumberIndex, ObjDesc->Field.BitLength));
|
||||
|
||||
Buffer = &SourceDesc->Integer.Value;
|
||||
|
||||
/* Lock entire transaction if requested */
|
||||
|
||||
AcpiExAcquireGlobalLock (ObjDesc->CommonField.FieldFlags);
|
||||
|
||||
/* Perform the write */
|
||||
|
||||
Status = AcpiExAccessRegion (ObjDesc, 0,
|
||||
(UINT64 *) Buffer, ACPI_WRITE);
|
||||
AcpiExReleaseGlobalLock (ObjDesc->CommonField.FieldFlags);
|
||||
return_ACPI_STATUS (Status);
|
||||
}
|
||||
|
||||
/* Get a pointer to the data to be written */
|
||||
|
||||
|
|
|
@ -113,9 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EXFLDIO_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXMISC_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXMUTEX_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXNAMES_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXOPARG1_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -113,9 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EXOPARG2_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXOPARG3_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXOPARG6_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXPREP_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
@ -587,6 +585,8 @@ AcpiExPrepFieldValue (
|
|||
ObjDesc->Field.ResourceLength = Info->ResourceLength;
|
||||
}
|
||||
|
||||
ObjDesc->Field.PinNumberIndex = Info->PinNumberIndex;
|
||||
|
||||
/* Allow full data read from EC address space */
|
||||
|
||||
if ((ObjDesc->Field.RegionObj->Region.SpaceId == ACPI_ADR_SPACE_EC) &&
|
||||
|
|
|
@ -113,9 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __EXREGION_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXRESNTE_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acdispat.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXRESOLV_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "amlcode.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXRESOP_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "amlcode.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXSTORE_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acdispat.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXSTOREN_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXSTOROB_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXSYSTEM_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acinterp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __EXUTILS_C__
|
||||
|
||||
/*
|
||||
* DEFINE_AML_GLOBALS is tested in amlcode.h
|
||||
* to determine whether certain global names should be "defined" or only
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __HWACPI_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
|
||||
|
|
|
@ -313,6 +313,14 @@ AcpiHwGetGpeStatus (
|
|||
return (AE_BAD_PARAMETER);
|
||||
}
|
||||
|
||||
/* GPE currently handled? */
|
||||
|
||||
if ((GpeEventInfo->Flags & ACPI_GPE_DISPATCH_MASK) !=
|
||||
ACPI_GPE_DISPATCH_NONE)
|
||||
{
|
||||
LocalEventStatus |= ACPI_EVENT_FLAG_HAS_HANDLER;
|
||||
}
|
||||
|
||||
/* Get the info block for the entire GPE register */
|
||||
|
||||
GpeRegisterInfo = GpeEventInfo->RegisterInfo;
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __HWPCI_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
|
||||
|
@ -233,11 +231,12 @@ AcpiHwDerivePciId (
|
|||
/* Walk the list, updating the PCI device/function/bus numbers */
|
||||
|
||||
Status = AcpiHwProcessPciList (PciId, ListHead);
|
||||
|
||||
/* Delete the list */
|
||||
|
||||
AcpiHwDeletePciList (ListHead);
|
||||
}
|
||||
|
||||
/* Always delete the list */
|
||||
|
||||
AcpiHwDeletePciList (ListHead);
|
||||
return_ACPI_STATUS (Status);
|
||||
}
|
||||
|
||||
|
@ -285,6 +284,9 @@ AcpiHwBuildPciList (
|
|||
Status = AcpiGetParent (CurrentDevice, &ParentDevice);
|
||||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
/* Must delete the list before exit */
|
||||
|
||||
AcpiHwDeletePciList (*ReturnListHead);
|
||||
return (Status);
|
||||
}
|
||||
|
||||
|
@ -299,6 +301,9 @@ AcpiHwBuildPciList (
|
|||
ListElement = ACPI_ALLOCATE (sizeof (ACPI_PCI_DEVICE));
|
||||
if (!ListElement)
|
||||
{
|
||||
/* Must delete the list before exit */
|
||||
|
||||
AcpiHwDeletePciList (*ReturnListHead);
|
||||
return (AE_NO_MEMORY);
|
||||
}
|
||||
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __HWREGS_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acevents.h"
|
||||
|
@ -382,17 +380,19 @@ AcpiHwClearAcpiStatus (
|
|||
|
||||
Status = AcpiHwRegisterWrite (ACPI_REGISTER_PM1_STATUS,
|
||||
ACPI_BITMASK_ALL_FIXED_STATUS);
|
||||
|
||||
AcpiOsReleaseLock (AcpiGbl_HardwareLock, LockFlags);
|
||||
|
||||
if (ACPI_FAILURE (Status))
|
||||
{
|
||||
goto UnlockAndExit;
|
||||
goto Exit;
|
||||
}
|
||||
|
||||
/* Clear the GPE Bits in all GPE registers in all GPE blocks */
|
||||
|
||||
Status = AcpiEvWalkGpeList (AcpiHwClearGpeBlock, NULL);
|
||||
|
||||
UnlockAndExit:
|
||||
AcpiOsReleaseLock (AcpiGbl_HardwareLock, LockFlags);
|
||||
Exit:
|
||||
return_ACPI_STATUS (Status);
|
||||
}
|
||||
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __HWVALID_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
|
||||
|
|
|
@ -156,10 +156,13 @@
|
|||
/* Macros for usage messages */
|
||||
|
||||
#define ACPI_USAGE_HEADER(Usage) \
|
||||
printf ("Usage: %s\nOptions:\n", Usage);
|
||||
AcpiOsPrintf ("Usage: %s\nOptions:\n", Usage);
|
||||
|
||||
#define ACPI_USAGE_TEXT(Description) \
|
||||
AcpiOsPrintf (Description);
|
||||
|
||||
#define ACPI_OPTION(Name, Description) \
|
||||
printf (" %-18s%s\n", Name, Description);
|
||||
AcpiOsPrintf (" %-18s%s\n", Name, Description);
|
||||
|
||||
|
||||
#define FILE_SUFFIX_DISASSEMBLY "dsl"
|
||||
|
@ -191,7 +194,7 @@ extern char *AcpiGbl_Optarg;
|
|||
*/
|
||||
UINT32
|
||||
CmGetFileSize (
|
||||
FILE *File);
|
||||
ACPI_FILE File);
|
||||
|
||||
|
||||
#ifndef ACPI_DUMP_APP
|
||||
|
|
|
@ -191,7 +191,9 @@ typedef struct acpi_pld_info
|
|||
{
|
||||
UINT8 Revision;
|
||||
UINT8 IgnoreColor;
|
||||
UINT32 Color;
|
||||
UINT8 Red;
|
||||
UINT8 Green;
|
||||
UINT8 Blue;
|
||||
UINT16 Width;
|
||||
UINT16 Height;
|
||||
UINT8 UserVisible;
|
||||
|
@ -237,8 +239,14 @@ typedef struct acpi_pld_info
|
|||
#define ACPI_PLD_GET_IGNORE_COLOR(dword) ACPI_GET_BITS (dword, 7, ACPI_1BIT_MASK)
|
||||
#define ACPI_PLD_SET_IGNORE_COLOR(dword,value) ACPI_SET_BITS (dword, 7, ACPI_1BIT_MASK, value) /* Offset 7, Len 1 */
|
||||
|
||||
#define ACPI_PLD_GET_COLOR(dword) ACPI_GET_BITS (dword, 8, ACPI_24BIT_MASK)
|
||||
#define ACPI_PLD_SET_COLOR(dword,value) ACPI_SET_BITS (dword, 8, ACPI_24BIT_MASK, value) /* Offset 8, Len 24 */
|
||||
#define ACPI_PLD_GET_RED(dword) ACPI_GET_BITS (dword, 8, ACPI_8BIT_MASK)
|
||||
#define ACPI_PLD_SET_RED(dword,value) ACPI_SET_BITS (dword, 8, ACPI_8BIT_MASK, value) /* Offset 8, Len 8 */
|
||||
|
||||
#define ACPI_PLD_GET_GREEN(dword) ACPI_GET_BITS (dword, 16, ACPI_8BIT_MASK)
|
||||
#define ACPI_PLD_SET_GREEN(dword,value) ACPI_SET_BITS (dword, 16, ACPI_8BIT_MASK, value) /* Offset 16, Len 8 */
|
||||
|
||||
#define ACPI_PLD_GET_BLUE(dword) ACPI_GET_BITS (dword, 24, ACPI_8BIT_MASK)
|
||||
#define ACPI_PLD_SET_BLUE(dword,value) ACPI_SET_BITS (dword, 24, ACPI_8BIT_MASK, value) /* Offset 24, Len 8 */
|
||||
|
||||
/* Second 32-bit dword, bits 33:63 */
|
||||
|
||||
|
|
|
@ -293,6 +293,25 @@
|
|||
#define ACPI_NUM_SxW_METHODS 5
|
||||
|
||||
|
||||
/******************************************************************************
|
||||
*
|
||||
* Miscellaneous constants
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
/* UUID constants */
|
||||
|
||||
#define UUID_BUFFER_LENGTH 16 /* Length of UUID in memory */
|
||||
#define UUID_STRING_LENGTH 36 /* Total length of a UUID string */
|
||||
|
||||
/* Positions for required hyphens (dashes) in UUID strings */
|
||||
|
||||
#define UUID_HYPHEN1_OFFSET 8
|
||||
#define UUID_HYPHEN2_OFFSET 13
|
||||
#define UUID_HYPHEN3_OFFSET 18
|
||||
#define UUID_HYPHEN4_OFFSET 23
|
||||
|
||||
|
||||
/******************************************************************************
|
||||
*
|
||||
* ACPI AML Debugger
|
||||
|
|
|
@ -449,11 +449,6 @@ AcpiDbGetTableFromFile (
|
|||
char *Filename,
|
||||
ACPI_TABLE_HEADER **Table);
|
||||
|
||||
ACPI_STATUS
|
||||
AcpiDbReadTableFromFile (
|
||||
char *Filename,
|
||||
ACPI_TABLE_HEADER **Table);
|
||||
|
||||
|
||||
/*
|
||||
* dbhistry - debugger HISTORY command
|
||||
|
|
|
@ -209,15 +209,18 @@ typedef enum
|
|||
|
||||
ACPI_DMT_ASF,
|
||||
ACPI_DMT_DMAR,
|
||||
ACPI_DMT_DMAR_SCOPE,
|
||||
ACPI_DMT_EINJACT,
|
||||
ACPI_DMT_EINJINST,
|
||||
ACPI_DMT_ERSTACT,
|
||||
ACPI_DMT_ERSTINST,
|
||||
ACPI_DMT_FADTPM,
|
||||
ACPI_DMT_GTDT,
|
||||
ACPI_DMT_HEST,
|
||||
ACPI_DMT_HESTNTFY,
|
||||
ACPI_DMT_HESTNTYP,
|
||||
ACPI_DMT_IVRS,
|
||||
ACPI_DMT_LPIT,
|
||||
ACPI_DMT_MADT,
|
||||
ACPI_DMT_PCCT,
|
||||
ACPI_DMT_PMTT,
|
||||
|
@ -259,6 +262,7 @@ typedef struct acpi_op_walk_info
|
|||
UINT32 BitOffset;
|
||||
UINT32 Flags;
|
||||
ACPI_WALK_STATE *WalkState;
|
||||
ACPI_PARSE_OBJECT *MappingOp;
|
||||
|
||||
} ACPI_OP_WALK_INFO;
|
||||
|
||||
|
@ -276,6 +280,7 @@ ACPI_STATUS (*ASL_WALK_CALLBACK) (
|
|||
|
||||
typedef
|
||||
void (*ACPI_RESOURCE_HANDLER) (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
@ -326,6 +331,7 @@ extern ACPI_DMTABLE_INFO AcpiDmTableInfoDmar0[];
|
|||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoDmar1[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoDmar2[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoDmar3[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoDmar4[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoDrtm[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoEcdt[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoEinj[];
|
||||
|
@ -343,6 +349,10 @@ extern ACPI_DMTABLE_INFO AcpiDmTableInfoFpdt0[];
|
|||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoFpdt1[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoGas[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoGtdt[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoGtdtHdr[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoGtdt0[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoGtdt0a[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoGtdt1[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoHeader[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoHest[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoHest0[];
|
||||
|
@ -355,6 +365,9 @@ extern ACPI_DMTABLE_INFO AcpiDmTableInfoHest9[];
|
|||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoHestNotify[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoHestBank[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoHpet[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoLpitHdr[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoLpit0[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoLpit1[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoIvrs[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoIvrs0[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoIvrs1[];
|
||||
|
@ -377,6 +390,8 @@ extern ACPI_DMTABLE_INFO AcpiDmTableInfoMadt9[];
|
|||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoMadt10[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoMadt11[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoMadt12[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoMadt13[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoMadt14[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoMadtHdr[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoMcfg[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoMcfg0[];
|
||||
|
@ -400,6 +415,7 @@ extern ACPI_DMTABLE_INFO AcpiDmTableInfoPmttHdr[];
|
|||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoPcct[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoPcctHdr[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoPcct0[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoPcct1[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoRsdp1[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoRsdp2[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoS3pt[];
|
||||
|
@ -418,6 +434,7 @@ extern ACPI_DMTABLE_INFO AcpiDmTableInfoSratHdr[];
|
|||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoSrat0[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoSrat1[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoSrat2[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoSrat3[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoTcpa[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoTpm2[];
|
||||
extern ACPI_DMTABLE_INFO AcpiDmTableInfoUefi[];
|
||||
|
@ -512,6 +529,10 @@ void
|
|||
AcpiDmDumpFpdt (
|
||||
ACPI_TABLE_HEADER *Table);
|
||||
|
||||
void
|
||||
AcpiDmDumpGtdt (
|
||||
ACPI_TABLE_HEADER *Table);
|
||||
|
||||
void
|
||||
AcpiDmDumpHest (
|
||||
ACPI_TABLE_HEADER *Table);
|
||||
|
@ -520,6 +541,10 @@ void
|
|||
AcpiDmDumpIvrs (
|
||||
ACPI_TABLE_HEADER *Table);
|
||||
|
||||
void
|
||||
AcpiDmDumpLpit (
|
||||
ACPI_TABLE_HEADER *Table);
|
||||
|
||||
void
|
||||
AcpiDmDumpMadt (
|
||||
ACPI_TABLE_HEADER *Table);
|
||||
|
@ -718,6 +743,10 @@ void
|
|||
AcpiDmDecompressEisaId (
|
||||
UINT32 EncodedId);
|
||||
|
||||
BOOLEAN
|
||||
AcpiDmIsUuidBuffer (
|
||||
ACPI_PARSE_OBJECT *Op);
|
||||
|
||||
BOOLEAN
|
||||
AcpiDmIsUnicodeBuffer (
|
||||
ACPI_PARSE_OBJECT *Op);
|
||||
|
@ -838,72 +867,84 @@ AcpiDmDescriptorName (
|
|||
*/
|
||||
void
|
||||
AcpiDmWordDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmDwordDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmExtendedDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmQwordDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmMemory24Descriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmMemory32Descriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmFixedMemory32Descriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmGenericRegisterDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmInterruptDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmVendorLargeDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmGpioDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmSerialBusDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
@ -921,48 +962,56 @@ AcpiDmVendorCommon (
|
|||
*/
|
||||
void
|
||||
AcpiDmIrqDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmDmaDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmFixedDmaDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmIoDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmFixedIoDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmStartDependentDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmEndDependentDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
||||
void
|
||||
AcpiDmVendorSmallDescriptor (
|
||||
ACPI_OP_WALK_INFO *Info,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 Length,
|
||||
UINT32 Level);
|
||||
|
@ -1001,6 +1050,19 @@ AcpiDmCheckResourceReference (
|
|||
ACPI_WALK_STATE *WalkState);
|
||||
|
||||
|
||||
/*
|
||||
* dmcstyle
|
||||
*/
|
||||
BOOLEAN
|
||||
AcpiDmCheckForSymbolicOpcode (
|
||||
ACPI_PARSE_OBJECT *Op,
|
||||
ACPI_OP_WALK_INFO *Info);
|
||||
|
||||
void
|
||||
AcpiDmCloseOperator (
|
||||
ACPI_PARSE_OBJECT *Op);
|
||||
|
||||
|
||||
/*
|
||||
* acdisasm
|
||||
*/
|
||||
|
@ -1008,5 +1070,4 @@ void
|
|||
AdDisassemblerHeader (
|
||||
char *Filename);
|
||||
|
||||
|
||||
#endif /* __ACDISASM_H__ */
|
||||
|
|
|
@ -113,7 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#ifndef _ACDISPAT_H_
|
||||
#define _ACDISPAT_H_
|
||||
|
||||
|
|
|
@ -216,9 +216,10 @@ AcpiEvFinishGpe (
|
|||
ACPI_STATUS
|
||||
AcpiEvCreateGpeBlock (
|
||||
ACPI_NAMESPACE_NODE *GpeDevice,
|
||||
ACPI_GENERIC_ADDRESS *GpeBlockAddress,
|
||||
UINT64 Address,
|
||||
UINT8 SpaceId,
|
||||
UINT32 RegisterCount,
|
||||
UINT8 GpeBlockBaseNumber,
|
||||
UINT16 GpeBlockBaseNumber,
|
||||
UINT32 InterruptNumber,
|
||||
ACPI_GPE_BLOCK_INFO **ReturnGpeBlock);
|
||||
|
||||
|
|
|
@ -117,146 +117,14 @@
|
|||
#define __ACGLOBAL_H__
|
||||
|
||||
|
||||
/*
|
||||
* Ensure that the globals are actually defined and initialized only once.
|
||||
*
|
||||
* The use of these macros allows a single list of globals (here) in order
|
||||
* to simplify maintenance of the code.
|
||||
*/
|
||||
#ifdef DEFINE_ACPI_GLOBALS
|
||||
#define ACPI_GLOBAL(type,name) \
|
||||
extern type name; \
|
||||
type name
|
||||
|
||||
#define ACPI_INIT_GLOBAL(type,name,value) \
|
||||
type name=value
|
||||
|
||||
#else
|
||||
#define ACPI_GLOBAL(type,name) \
|
||||
extern type name
|
||||
|
||||
#define ACPI_INIT_GLOBAL(type,name,value) \
|
||||
extern type name
|
||||
#endif
|
||||
|
||||
|
||||
#ifdef DEFINE_ACPI_GLOBALS
|
||||
|
||||
/* Public globals, available from outside ACPICA subsystem */
|
||||
|
||||
/*****************************************************************************
|
||||
*
|
||||
* Runtime configuration (static defaults that can be overriden at runtime)
|
||||
* Globals related to the ACPI tables
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/*
|
||||
* Enable "slack" in the AML interpreter? Default is FALSE, and the
|
||||
* interpreter strictly follows the ACPI specification. Setting to TRUE
|
||||
* allows the interpreter to ignore certain errors and/or bad AML constructs.
|
||||
*
|
||||
* Currently, these features are enabled by this flag:
|
||||
*
|
||||
* 1) Allow "implicit return" of last value in a control method
|
||||
* 2) Allow access beyond the end of an operation region
|
||||
* 3) Allow access to uninitialized locals/args (auto-init to integer 0)
|
||||
* 4) Allow ANY object type to be a source operand for the Store() operator
|
||||
* 5) Allow unresolved references (invalid target name) in package objects
|
||||
* 6) Enable warning messages for behavior that is not ACPI spec compliant
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_EnableInterpreterSlack, FALSE);
|
||||
/* Master list of all ACPI tables that were found in the RSDT/XSDT */
|
||||
|
||||
/*
|
||||
* Automatically serialize all methods that create named objects? Default
|
||||
* is TRUE, meaning that all NonSerialized methods are scanned once at
|
||||
* table load time to determine those that create named objects. Methods
|
||||
* that create named objects are marked Serialized in order to prevent
|
||||
* possible run-time problems if they are entered by more than one thread.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_AutoSerializeMethods, TRUE);
|
||||
|
||||
/*
|
||||
* Create the predefined _OSI method in the namespace? Default is TRUE
|
||||
* because ACPICA is fully compatible with other ACPI implementations.
|
||||
* Changing this will revert ACPICA (and machine ASL) to pre-OSI behavior.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_CreateOsiMethod, TRUE);
|
||||
|
||||
/*
|
||||
* Optionally use default values for the ACPI register widths. Set this to
|
||||
* TRUE to use the defaults, if an FADT contains incorrect widths/lengths.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_UseDefaultRegisterWidths, TRUE);
|
||||
|
||||
/*
|
||||
* Optionally enable output from the AML Debug Object.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_EnableAmlDebugObject, FALSE);
|
||||
|
||||
/*
|
||||
* Optionally copy the entire DSDT to local memory (instead of simply
|
||||
* mapping it.) There are some BIOSs that corrupt or replace the original
|
||||
* DSDT, creating the need for this option. Default is FALSE, do not copy
|
||||
* the DSDT.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_CopyDsdtLocally, FALSE);
|
||||
|
||||
/*
|
||||
* Optionally ignore an XSDT if present and use the RSDT instead.
|
||||
* Although the ACPI specification requires that an XSDT be used instead
|
||||
* of the RSDT, the XSDT has been found to be corrupt or ill-formed on
|
||||
* some machines. Default behavior is to use the XSDT if present.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_DoNotUseXsdt, FALSE);
|
||||
|
||||
/*
|
||||
* Optionally use 32-bit FADT addresses if and when there is a conflict
|
||||
* (address mismatch) between the 32-bit and 64-bit versions of the
|
||||
* address. Although ACPICA adheres to the ACPI specification which
|
||||
* requires the use of the corresponding 64-bit address if it is non-zero,
|
||||
* some machines have been found to have a corrupted non-zero 64-bit
|
||||
* address. Default is FALSE, do not favor the 32-bit addresses.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_Use32BitFadtAddresses, FALSE);
|
||||
|
||||
/*
|
||||
* Optionally truncate I/O addresses to 16 bits. Provides compatibility
|
||||
* with other ACPI implementations. NOTE: During ACPICA initialization,
|
||||
* this value is set to TRUE if any Windows OSI strings have been
|
||||
* requested by the BIOS.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_TruncateIoAddresses, FALSE);
|
||||
|
||||
/*
|
||||
* Disable runtime checking and repair of values returned by control methods.
|
||||
* Use only if the repair is causing a problem on a particular machine.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_DisableAutoRepair, FALSE);
|
||||
|
||||
/*
|
||||
* Optionally do not install any SSDTs from the RSDT/XSDT during initialization.
|
||||
* This can be useful for debugging ACPI problems on some machines.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_DisableSsdtTableInstall, FALSE);
|
||||
|
||||
/*
|
||||
* We keep track of the latest version of Windows that has been requested by
|
||||
* the BIOS.
|
||||
*/
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_OsiData, 0);
|
||||
|
||||
#endif /* DEFINE_ACPI_GLOBALS */
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
*
|
||||
* ACPI Table globals
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/*
|
||||
* Master list of all ACPI tables that were found in the RSDT/XSDT.
|
||||
*/
|
||||
ACPI_GLOBAL (ACPI_TABLE_LIST, AcpiGbl_RootTableList);
|
||||
|
||||
/* DSDT information. Used to check for DSDT corruption */
|
||||
|
@ -356,7 +224,6 @@ ACPI_GLOBAL (ACPI_EXCEPTION_HANDLER, AcpiGbl_ExceptionHandler);
|
|||
ACPI_GLOBAL (ACPI_INIT_HANDLER, AcpiGbl_InitHandler);
|
||||
ACPI_GLOBAL (ACPI_TABLE_HANDLER, AcpiGbl_TableHandler);
|
||||
ACPI_GLOBAL (void *, AcpiGbl_TableHandlerContext);
|
||||
ACPI_GLOBAL (ACPI_WALK_STATE *, AcpiGbl_BreakpointWalk);
|
||||
ACPI_GLOBAL (ACPI_INTERFACE_HANDLER, AcpiGbl_InterfaceHandler);
|
||||
ACPI_GLOBAL (ACPI_SCI_HANDLER_INFO *, AcpiGbl_SciHandlerList);
|
||||
|
||||
|
@ -373,7 +240,6 @@ ACPI_GLOBAL (BOOLEAN, AcpiGbl_RegMethodsExecuted);
|
|||
/* Misc */
|
||||
|
||||
ACPI_GLOBAL (UINT32, AcpiGbl_OriginalMode);
|
||||
ACPI_GLOBAL (UINT32, AcpiGbl_RsdpOriginalLocation);
|
||||
ACPI_GLOBAL (UINT32, AcpiGbl_NsLookupCount);
|
||||
ACPI_GLOBAL (UINT32, AcpiGbl_PsFindCount);
|
||||
ACPI_GLOBAL (UINT16, AcpiGbl_Pm1EnableRegisterSave);
|
||||
|
@ -507,7 +373,7 @@ ACPI_GLOBAL (UINT32, AcpiGbl_TraceDbgLayer);
|
|||
*
|
||||
****************************************************************************/
|
||||
|
||||
ACPI_GLOBAL (UINT8, AcpiGbl_DbOutputFlags);
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_DbOutputFlags, ACPI_DB_CONSOLE_OUTPUT);
|
||||
|
||||
#ifdef ACPI_DISASSEMBLER
|
||||
|
||||
|
@ -515,6 +381,7 @@ ACPI_GLOBAL (UINT8, AcpiGbl_DbOutputFlags);
|
|||
|
||||
ACPI_INIT_GLOBAL (UINT8, AcpiGbl_NoResourceDisassembly, FALSE);
|
||||
ACPI_INIT_GLOBAL (BOOLEAN, AcpiGbl_IgnoreNoopOperator, FALSE);
|
||||
ACPI_INIT_GLOBAL (BOOLEAN, AcpiGbl_CstyleDisassembly, TRUE);
|
||||
|
||||
ACPI_GLOBAL (BOOLEAN, AcpiGbl_DbOpt_disasm);
|
||||
ACPI_GLOBAL (BOOLEAN, AcpiGbl_DbOpt_verbose);
|
||||
|
@ -561,11 +428,6 @@ ACPI_GLOBAL (UINT16, AcpiGbl_NodeTypeCountMisc);
|
|||
ACPI_GLOBAL (UINT32, AcpiGbl_NumNodes);
|
||||
ACPI_GLOBAL (UINT32, AcpiGbl_NumObjects);
|
||||
|
||||
ACPI_GLOBAL (UINT32, AcpiGbl_SizeOfParseTree);
|
||||
ACPI_GLOBAL (UINT32, AcpiGbl_SizeOfMethodTrees);
|
||||
ACPI_GLOBAL (UINT32, AcpiGbl_SizeOfNodeEntries);
|
||||
ACPI_GLOBAL (UINT32, AcpiGbl_SizeOfAcpiObjects);
|
||||
|
||||
#endif /* ACPI_DEBUGGER */
|
||||
|
||||
|
||||
|
@ -578,6 +440,12 @@ ACPI_GLOBAL (UINT32, AcpiGbl_SizeOfAcpiObjects);
|
|||
#ifdef ACPI_APPLICATION
|
||||
|
||||
ACPI_INIT_GLOBAL (ACPI_FILE, AcpiGbl_DebugFile, NULL);
|
||||
ACPI_INIT_GLOBAL (ACPI_FILE, AcpiGbl_OutputFile, NULL);
|
||||
|
||||
/* Print buffer */
|
||||
|
||||
ACPI_GLOBAL (ACPI_SPINLOCK, AcpiGbl_PrintLock); /* For print buffer */
|
||||
ACPI_GLOBAL (char, AcpiGbl_PrintBuffer[1024]);
|
||||
|
||||
#endif /* ACPI_APPLICATION */
|
||||
|
||||
|
|
|
@ -363,6 +363,7 @@ typedef struct acpi_create_field_info
|
|||
UINT32 FieldBitPosition;
|
||||
UINT32 FieldBitLength;
|
||||
UINT16 ResourceLength;
|
||||
UINT16 PinNumberIndex;
|
||||
UINT8 FieldFlags;
|
||||
UINT8 Attribute;
|
||||
UINT8 FieldType;
|
||||
|
@ -588,9 +589,9 @@ typedef struct acpi_gpe_register_info
|
|||
{
|
||||
ACPI_GENERIC_ADDRESS StatusAddress; /* Address of status reg */
|
||||
ACPI_GENERIC_ADDRESS EnableAddress; /* Address of enable reg */
|
||||
UINT16 BaseGpeNumber; /* Base GPE number for this register */
|
||||
UINT8 EnableForWake; /* GPEs to keep enabled when sleeping */
|
||||
UINT8 EnableForRun; /* GPEs to keep enabled when running */
|
||||
UINT8 BaseGpeNumber; /* Base GPE number for this register */
|
||||
|
||||
} ACPI_GPE_REGISTER_INFO;
|
||||
|
||||
|
@ -606,10 +607,11 @@ typedef struct acpi_gpe_block_info
|
|||
struct acpi_gpe_xrupt_info *XruptBlock; /* Backpointer to interrupt block */
|
||||
ACPI_GPE_REGISTER_INFO *RegisterInfo; /* One per GPE register pair */
|
||||
ACPI_GPE_EVENT_INFO *EventInfo; /* One for each GPE */
|
||||
ACPI_GENERIC_ADDRESS BlockAddress; /* Base address of the block */
|
||||
UINT64 Address; /* Base address of the block */
|
||||
UINT32 RegisterCount; /* Number of register pairs in block */
|
||||
UINT16 GpeCount; /* Number of individual GPEs in block */
|
||||
UINT8 BlockBaseNumber;/* Base GPE number for this block */
|
||||
UINT16 BlockBaseNumber;/* Base GPE number for this block */
|
||||
UINT8 SpaceId;
|
||||
BOOLEAN Initialized; /* TRUE if this block is initialized */
|
||||
|
||||
} ACPI_GPE_BLOCK_INFO;
|
||||
|
@ -939,6 +941,7 @@ typedef union acpi_parse_value
|
|||
ACPI_DISASM_ONLY_MEMBERS (\
|
||||
UINT8 DisasmFlags; /* Used during AML disassembly */\
|
||||
UINT8 DisasmOpcode; /* Subtype used for disassembly */\
|
||||
char *OperatorSymbol;/* Used for C-style operator name strings */\
|
||||
char AmlOpName[16]) /* Op name (debug only) */
|
||||
|
||||
|
||||
|
@ -949,12 +952,13 @@ typedef union acpi_parse_value
|
|||
#define ACPI_DASM_STRING 0x02 /* Buffer is a ASCII string */
|
||||
#define ACPI_DASM_UNICODE 0x03 /* Buffer is a Unicode string */
|
||||
#define ACPI_DASM_PLD_METHOD 0x04 /* Buffer is a _PLD method bit-packed buffer */
|
||||
#define ACPI_DASM_EISAID 0x05 /* Integer is an EISAID */
|
||||
#define ACPI_DASM_MATCHOP 0x06 /* Parent opcode is a Match() operator */
|
||||
#define ACPI_DASM_LNOT_PREFIX 0x07 /* Start of a LNotEqual (etc.) pair of opcodes */
|
||||
#define ACPI_DASM_LNOT_SUFFIX 0x08 /* End of a LNotEqual (etc.) pair of opcodes */
|
||||
#define ACPI_DASM_HID_STRING 0x09 /* String is a _HID or _CID */
|
||||
#define ACPI_DASM_IGNORE 0x0A /* Not used at this time */
|
||||
#define ACPI_DASM_UUID 0x05 /* Buffer is a UUID/GUID */
|
||||
#define ACPI_DASM_EISAID 0x06 /* Integer is an EISAID */
|
||||
#define ACPI_DASM_MATCHOP 0x07 /* Parent opcode is a Match() operator */
|
||||
#define ACPI_DASM_LNOT_PREFIX 0x08 /* Start of a LNotEqual (etc.) pair of opcodes */
|
||||
#define ACPI_DASM_LNOT_SUFFIX 0x09 /* End of a LNotEqual (etc.) pair of opcodes */
|
||||
#define ACPI_DASM_HID_STRING 0x0A /* String is a _HID or _CID */
|
||||
#define ACPI_DASM_IGNORE 0x0B /* Not used at this time */
|
||||
|
||||
/*
|
||||
* Generic operation (for example: If, While, Store)
|
||||
|
@ -1060,6 +1064,8 @@ typedef struct acpi_parse_state
|
|||
#define ACPI_PARSEOP_EMPTY_TERMLIST 0x04
|
||||
#define ACPI_PARSEOP_PREDEF_CHECKED 0x08
|
||||
#define ACPI_PARSEOP_SPECIAL 0x10
|
||||
#define ACPI_PARSEOP_COMPOUND 0x20
|
||||
#define ACPI_PARSEOP_ASSIGNMENT 0x40
|
||||
|
||||
|
||||
/*****************************************************************************
|
||||
|
@ -1429,4 +1435,11 @@ typedef struct ah_device_id
|
|||
|
||||
} AH_DEVICE_ID;
|
||||
|
||||
typedef struct ah_uuid
|
||||
{
|
||||
char *Description;
|
||||
char *String;
|
||||
|
||||
} AH_UUID;
|
||||
|
||||
#endif /* __ACLOCAL_H__ */
|
||||
|
|
|
@ -124,12 +124,18 @@
|
|||
#define METHOD_NAME__CBA "_CBA"
|
||||
#define METHOD_NAME__CID "_CID"
|
||||
#define METHOD_NAME__CRS "_CRS"
|
||||
#define METHOD_NAME__DDN "_DDN"
|
||||
#define METHOD_NAME__HID "_HID"
|
||||
#define METHOD_NAME__INI "_INI"
|
||||
#define METHOD_NAME__PLD "_PLD"
|
||||
#define METHOD_NAME__DSD "_DSD"
|
||||
#define METHOD_NAME__PRS "_PRS"
|
||||
#define METHOD_NAME__PRT "_PRT"
|
||||
#define METHOD_NAME__PRW "_PRW"
|
||||
#define METHOD_NAME__PS0 "_PS0"
|
||||
#define METHOD_NAME__PS1 "_PS1"
|
||||
#define METHOD_NAME__PS2 "_PS2"
|
||||
#define METHOD_NAME__PS3 "_PS3"
|
||||
#define METHOD_NAME__REG "_REG"
|
||||
#define METHOD_NAME__SB_ "_SB_"
|
||||
#define METHOD_NAME__SEG "_SEG"
|
||||
|
|
|
@ -410,6 +410,7 @@ typedef struct acpi_object_region_field
|
|||
UINT16 ResourceLength;
|
||||
union acpi_operand_object *RegionObj; /* Containing OpRegion object */
|
||||
UINT8 *ResourceBuffer; /* ResourceTemplate for serial regions/fields */
|
||||
UINT16 PinNumberIndex; /* Index relative to previous Connection/Template */
|
||||
|
||||
} ACPI_OBJECT_REGION_FIELD;
|
||||
|
||||
|
|
|
@ -113,7 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#ifndef __ACPARSER_H__
|
||||
#define __ACPARSER_H__
|
||||
|
||||
|
|
|
@ -142,8 +142,6 @@
|
|||
#include "acrestyp.h" /* Resource Descriptor structs */
|
||||
#include "acpiosxf.h" /* OSL interfaces (ACPICA-to-OS) */
|
||||
#include "acpixf.h" /* ACPI core subsystem external interfaces */
|
||||
#ifdef ACPI_NATIVE_INTERFACE_HEADER
|
||||
#include ACPI_NATIVE_INTERFACE_HEADER
|
||||
#endif
|
||||
#include "platform/acenvex.h" /* Extra environment-specific items */
|
||||
|
||||
#endif /* __ACPI_H__ */
|
||||
|
|
|
@ -623,4 +623,53 @@ AcpiOsCloseDirectory (
|
|||
#endif
|
||||
|
||||
|
||||
/*
|
||||
* File I/O and related support
|
||||
*/
|
||||
#ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsOpenFile
|
||||
ACPI_FILE
|
||||
AcpiOsOpenFile (
|
||||
const char *Path,
|
||||
UINT8 Modes);
|
||||
#endif
|
||||
|
||||
#ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCloseFile
|
||||
void
|
||||
AcpiOsCloseFile (
|
||||
ACPI_FILE File);
|
||||
#endif
|
||||
|
||||
#ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadFile
|
||||
int
|
||||
AcpiOsReadFile (
|
||||
ACPI_FILE File,
|
||||
void *Buffer,
|
||||
ACPI_SIZE Size,
|
||||
ACPI_SIZE Count);
|
||||
#endif
|
||||
|
||||
#ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWriteFile
|
||||
int
|
||||
AcpiOsWriteFile (
|
||||
ACPI_FILE File,
|
||||
void *Buffer,
|
||||
ACPI_SIZE Size,
|
||||
ACPI_SIZE Count);
|
||||
#endif
|
||||
|
||||
#ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetFileOffset
|
||||
long
|
||||
AcpiOsGetFileOffset (
|
||||
ACPI_FILE File);
|
||||
#endif
|
||||
|
||||
#ifndef ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsSetFileOffset
|
||||
ACPI_STATUS
|
||||
AcpiOsSetFileOffset (
|
||||
ACPI_FILE File,
|
||||
long Offset,
|
||||
UINT8 From);
|
||||
#endif
|
||||
|
||||
|
||||
#endif /* __ACPIOSXF_H__ */
|
||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -178,6 +178,11 @@
|
|||
* count = 0 (optional)
|
||||
* (Used for _DLM)
|
||||
*
|
||||
* ACPI_PTYPE2_UUID_PAIR: Each subpackage is preceded by a UUID Buffer. The UUID
|
||||
* defines the format of the package. Zero-length parent package is
|
||||
* allowed.
|
||||
* (Used for _DSD)
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
enum AcpiReturnPackageTypes
|
||||
|
@ -191,7 +196,8 @@ enum AcpiReturnPackageTypes
|
|||
ACPI_PTYPE2_FIXED = 7,
|
||||
ACPI_PTYPE2_MIN = 8,
|
||||
ACPI_PTYPE2_REV_FIXED = 9,
|
||||
ACPI_PTYPE2_FIX_VAR = 10
|
||||
ACPI_PTYPE2_FIX_VAR = 10,
|
||||
ACPI_PTYPE2_UUID_PAIR = 11
|
||||
};
|
||||
|
||||
|
||||
|
@ -438,6 +444,9 @@ const ACPI_PREDEFINED_INFO AcpiGbl_PredefinedMethods[] =
|
|||
{{"_CBA", METHOD_0ARGS,
|
||||
METHOD_RETURNS (ACPI_RTYPE_INTEGER)}}, /* See PCI firmware spec 3.0 */
|
||||
|
||||
{{"_CCA", METHOD_0ARGS,
|
||||
METHOD_RETURNS (ACPI_RTYPE_INTEGER)}}, /* ACPI 5.1 */
|
||||
|
||||
{{"_CDM", METHOD_0ARGS,
|
||||
METHOD_RETURNS (ACPI_RTYPE_INTEGER)}},
|
||||
|
||||
|
@ -506,6 +515,10 @@ const ACPI_PREDEFINED_INFO AcpiGbl_PredefinedMethods[] =
|
|||
{{"_DOS", METHOD_1ARGS (ACPI_TYPE_INTEGER),
|
||||
METHOD_NO_RETURN_VALUE}},
|
||||
|
||||
{{"_DSD", METHOD_0ARGS,
|
||||
METHOD_RETURNS (ACPI_RTYPE_PACKAGE)}}, /* Variable-length (Pkgs) each: 1 Buf, 1 Pkg */
|
||||
PACKAGE_INFO (ACPI_PTYPE2_UUID_PAIR, ACPI_RTYPE_BUFFER, 1, ACPI_RTYPE_PACKAGE, 1,0),
|
||||
|
||||
{{"_DSM", METHOD_4ARGS (ACPI_TYPE_BUFFER, ACPI_TYPE_INTEGER, ACPI_TYPE_INTEGER, ACPI_TYPE_PACKAGE),
|
||||
METHOD_RETURNS (ACPI_RTYPE_ALL)}}, /* Must return a value, but it can be of any type */
|
||||
|
||||
|
@ -652,6 +665,10 @@ const ACPI_PREDEFINED_INFO AcpiGbl_PredefinedMethods[] =
|
|||
{{"_LID", METHOD_0ARGS,
|
||||
METHOD_RETURNS (ACPI_RTYPE_INTEGER)}},
|
||||
|
||||
{{"_LPD", METHOD_0ARGS,
|
||||
METHOD_RETURNS (ACPI_RTYPE_PACKAGE)}}, /* Variable-length (1 Int(rev), n Pkg (2 Int) */
|
||||
PACKAGE_INFO (ACPI_PTYPE2_REV_FIXED, ACPI_RTYPE_INTEGER, 2,0,0,0),
|
||||
|
||||
{{"_MAT", METHOD_0ARGS,
|
||||
METHOD_RETURNS (ACPI_RTYPE_BUFFER)}},
|
||||
|
||||
|
@ -756,12 +773,6 @@ const ACPI_PREDEFINED_INFO AcpiGbl_PredefinedMethods[] =
|
|||
METHOD_RETURNS (ACPI_RTYPE_PACKAGE)}}, /* Variable-length (Refs) */
|
||||
PACKAGE_INFO (ACPI_PTYPE1_VAR, ACPI_RTYPE_REFERENCE, 0,0,0,0),
|
||||
|
||||
{{"_PRP", METHOD_0ARGS,
|
||||
METHOD_RETURNS (ACPI_RTYPE_PACKAGE)}}, /* Variable-length (Pkgs) each: 1 Str, 1 Int/Str/Pkg */
|
||||
PACKAGE_INFO (ACPI_PTYPE2, ACPI_RTYPE_STRING, 1,
|
||||
ACPI_RTYPE_INTEGER | ACPI_RTYPE_STRING |
|
||||
ACPI_RTYPE_PACKAGE | ACPI_RTYPE_REFERENCE, 1,0),
|
||||
|
||||
{{"_PRS", METHOD_0ARGS,
|
||||
METHOD_RETURNS (ACPI_RTYPE_BUFFER)}},
|
||||
|
||||
|
|
|
@ -124,6 +124,10 @@ AcpiAllocateRootTable (
|
|||
/*
|
||||
* tbxfroot - Root pointer utilities
|
||||
*/
|
||||
UINT32
|
||||
AcpiTbGetRsdpLength (
|
||||
ACPI_TABLE_RSDP *Rsdp);
|
||||
|
||||
ACPI_STATUS
|
||||
AcpiTbValidateRsdp (
|
||||
ACPI_TABLE_RSDP *Rsdp);
|
||||
|
@ -158,6 +162,15 @@ void
|
|||
AcpiTbReleaseTempTable (
|
||||
ACPI_TABLE_DESC *TableDesc);
|
||||
|
||||
ACPI_STATUS
|
||||
AcpiTbValidateTempTable (
|
||||
ACPI_TABLE_DESC *TableDesc);
|
||||
|
||||
ACPI_STATUS
|
||||
AcpiTbVerifyTempTable (
|
||||
ACPI_TABLE_DESC *TableDesc,
|
||||
char *Signature);
|
||||
|
||||
BOOLEAN
|
||||
AcpiTbIsTableLoaded (
|
||||
UINT32 TableIndex);
|
||||
|
@ -207,11 +220,6 @@ void
|
|||
AcpiTbInvalidateTable (
|
||||
ACPI_TABLE_DESC *TableDesc);
|
||||
|
||||
ACPI_STATUS
|
||||
AcpiTbVerifyTable (
|
||||
ACPI_TABLE_DESC *TableDesc,
|
||||
char *Signature);
|
||||
|
||||
void
|
||||
AcpiTbOverrideTable (
|
||||
ACPI_TABLE_DESC *OldTableDesc);
|
||||
|
|
|
@ -368,7 +368,8 @@ typedef struct acpi_table_fadt
|
|||
UINT32 Flags; /* Miscellaneous flag bits (see below for individual flags) */
|
||||
ACPI_GENERIC_ADDRESS ResetRegister; /* 64-bit address of the Reset register */
|
||||
UINT8 ResetValue; /* Value to write to the ResetRegister port to reset the system */
|
||||
UINT8 Reserved4[3]; /* Reserved, must be zero */
|
||||
UINT16 ArmBootFlags; /* ARM-Specific Boot Flags (see below for individual flags) (ACPI 5.1) */
|
||||
UINT8 MinorRevision; /* FADT Minor Revision (ACPI 5.1) */
|
||||
UINT64 XFacs; /* 64-bit physical address of FACS */
|
||||
UINT64 XDsdt; /* 64-bit physical address of DSDT */
|
||||
ACPI_GENERIC_ADDRESS XPm1aEventBlock; /* 64-bit Extended Power Mgt 1a Event Reg Blk address */
|
||||
|
@ -385,7 +386,7 @@ typedef struct acpi_table_fadt
|
|||
} ACPI_TABLE_FADT;
|
||||
|
||||
|
||||
/* Masks for FADT Boot Architecture Flags (BootFlags) [Vx]=Introduced in this FADT revision */
|
||||
/* Masks for FADT IA-PC Boot Architecture Flags (boot_flags) [Vx]=Introduced in this FADT revision */
|
||||
|
||||
#define ACPI_FADT_LEGACY_DEVICES (1) /* 00: [V2] System has LPC or ISA bus devices */
|
||||
#define ACPI_FADT_8042 (1<<1) /* 01: [V3] System has an 8042 controller on port 60/64 */
|
||||
|
@ -394,6 +395,11 @@ typedef struct acpi_table_fadt
|
|||
#define ACPI_FADT_NO_ASPM (1<<4) /* 04: [V4] PCIe ASPM control must not be enabled */
|
||||
#define ACPI_FADT_NO_CMOS_RTC (1<<5) /* 05: [V5] No CMOS real-time clock present */
|
||||
|
||||
/* Masks for FADT ARM Boot Architecture Flags (arm_boot_flags) ACPI 5.1 */
|
||||
|
||||
#define ACPI_FADT_PSCI_COMPLIANT (1) /* 00: [V5+] PSCI 0.2+ is implemented */
|
||||
#define ACPI_FADT_PSCI_USE_HVC (1<<1) /* 01: [V5+] HVC must be used instead of SMC as the PSCI conduit */
|
||||
|
||||
/* Masks for FADT flags */
|
||||
|
||||
#define ACPI_FADT_WBINVD (1) /* 00: [V1] The WBINVD instruction works properly */
|
||||
|
@ -507,7 +513,7 @@ typedef struct acpi_table_desc
|
|||
* FADT V5 size: 0x10C
|
||||
*/
|
||||
#define ACPI_FADT_V1_SIZE (UINT32) (ACPI_FADT_OFFSET (Flags) + 4)
|
||||
#define ACPI_FADT_V2_SIZE (UINT32) (ACPI_FADT_OFFSET (Reserved4[0]) + 3)
|
||||
#define ACPI_FADT_V2_SIZE (UINT32) (ACPI_FADT_OFFSET (MinorRevision) + 1)
|
||||
#define ACPI_FADT_V3_SIZE (UINT32) (ACPI_FADT_OFFSET (SleepControl))
|
||||
#define ACPI_FADT_V5_SIZE (UINT32) (sizeof (ACPI_TABLE_FADT))
|
||||
|
||||
|
|
|
@ -834,25 +834,27 @@ typedef struct acpi_table_madt
|
|||
|
||||
enum AcpiMadtType
|
||||
{
|
||||
ACPI_MADT_TYPE_LOCAL_APIC = 0,
|
||||
ACPI_MADT_TYPE_IO_APIC = 1,
|
||||
ACPI_MADT_TYPE_INTERRUPT_OVERRIDE = 2,
|
||||
ACPI_MADT_TYPE_NMI_SOURCE = 3,
|
||||
ACPI_MADT_TYPE_LOCAL_APIC_NMI = 4,
|
||||
ACPI_MADT_TYPE_LOCAL_APIC_OVERRIDE = 5,
|
||||
ACPI_MADT_TYPE_IO_SAPIC = 6,
|
||||
ACPI_MADT_TYPE_LOCAL_SAPIC = 7,
|
||||
ACPI_MADT_TYPE_INTERRUPT_SOURCE = 8,
|
||||
ACPI_MADT_TYPE_LOCAL_X2APIC = 9,
|
||||
ACPI_MADT_TYPE_LOCAL_X2APIC_NMI = 10,
|
||||
ACPI_MADT_TYPE_GENERIC_INTERRUPT = 11,
|
||||
ACPI_MADT_TYPE_GENERIC_DISTRIBUTOR = 12,
|
||||
ACPI_MADT_TYPE_RESERVED = 13 /* 13 and greater are reserved */
|
||||
ACPI_MADT_TYPE_LOCAL_APIC = 0,
|
||||
ACPI_MADT_TYPE_IO_APIC = 1,
|
||||
ACPI_MADT_TYPE_INTERRUPT_OVERRIDE = 2,
|
||||
ACPI_MADT_TYPE_NMI_SOURCE = 3,
|
||||
ACPI_MADT_TYPE_LOCAL_APIC_NMI = 4,
|
||||
ACPI_MADT_TYPE_LOCAL_APIC_OVERRIDE = 5,
|
||||
ACPI_MADT_TYPE_IO_SAPIC = 6,
|
||||
ACPI_MADT_TYPE_LOCAL_SAPIC = 7,
|
||||
ACPI_MADT_TYPE_INTERRUPT_SOURCE = 8,
|
||||
ACPI_MADT_TYPE_LOCAL_X2APIC = 9,
|
||||
ACPI_MADT_TYPE_LOCAL_X2APIC_NMI = 10,
|
||||
ACPI_MADT_TYPE_GENERIC_INTERRUPT = 11,
|
||||
ACPI_MADT_TYPE_GENERIC_DISTRIBUTOR = 12,
|
||||
ACPI_MADT_TYPE_GENERIC_MSI_FRAME = 13,
|
||||
ACPI_MADT_TYPE_GENERIC_REDISTRIBUTOR = 14,
|
||||
ACPI_MADT_TYPE_RESERVED = 15 /* 15 and greater are reserved */
|
||||
};
|
||||
|
||||
|
||||
/*
|
||||
* MADT Sub-tables, correspond to Type in ACPI_SUBTABLE_HEADER
|
||||
* MADT Subtables, correspond to Type in ACPI_SUBTABLE_HEADER
|
||||
*/
|
||||
|
||||
/* 0: Processor Local APIC */
|
||||
|
@ -1008,16 +1010,27 @@ typedef struct acpi_madt_generic_interrupt
|
|||
{
|
||||
ACPI_SUBTABLE_HEADER Header;
|
||||
UINT16 Reserved; /* Reserved - must be zero */
|
||||
UINT32 GicId;
|
||||
UINT32 CpuInterfaceNumber;
|
||||
UINT32 Uid;
|
||||
UINT32 Flags;
|
||||
UINT32 ParkingVersion;
|
||||
UINT32 PerformanceInterrupt;
|
||||
UINT64 ParkedAddress;
|
||||
UINT64 BaseAddress;
|
||||
UINT64 GicvBaseAddress;
|
||||
UINT64 GichBaseAddress;
|
||||
UINT32 VgicInterrupt;
|
||||
UINT64 GicrBaseAddress;
|
||||
UINT64 ArmMpidr;
|
||||
|
||||
} ACPI_MADT_GENERIC_INTERRUPT;
|
||||
|
||||
/* Masks for Flags field above */
|
||||
|
||||
/* ACPI_MADT_ENABLED (1) Processor is usable if set */
|
||||
#define ACPI_MADT_PERFORMANCE_IRQ_MODE (1<<1) /* 01: Performance Interrupt Mode */
|
||||
#define ACPI_MADT_VGIC_IRQ_MODE (1<<2) /* 02: VGIC Maintenance Interrupt mode */
|
||||
|
||||
|
||||
/* 12: Generic Distributor (ACPI 5.0) */
|
||||
|
||||
|
@ -1033,11 +1046,42 @@ typedef struct acpi_madt_generic_distributor
|
|||
} ACPI_MADT_GENERIC_DISTRIBUTOR;
|
||||
|
||||
|
||||
/* 13: Generic MSI Frame (ACPI 5.1) */
|
||||
|
||||
typedef struct acpi_madt_generic_msi_frame
|
||||
{
|
||||
ACPI_SUBTABLE_HEADER Header;
|
||||
UINT16 Reserved; /* Reserved - must be zero */
|
||||
UINT32 MsiFrameId;
|
||||
UINT64 BaseAddress;
|
||||
UINT32 Flags;
|
||||
UINT16 SpiCount;
|
||||
UINT16 SpiBase;
|
||||
|
||||
} ACPI_MADT_GENERIC_MSI_FRAME;
|
||||
|
||||
/* Masks for Flags field above */
|
||||
|
||||
#define ACPI_MADT_OVERRIDE_SPI_VALUES (1)
|
||||
|
||||
|
||||
/* 14: Generic Redistributor (ACPI 5.1) */
|
||||
|
||||
typedef struct acpi_madt_generic_redistributor
|
||||
{
|
||||
ACPI_SUBTABLE_HEADER Header;
|
||||
UINT16 Reserved; /* reserved - must be zero */
|
||||
UINT64 BaseAddress;
|
||||
UINT32 Length;
|
||||
|
||||
} ACPI_MADT_GENERIC_REDISTRIBUTOR;
|
||||
|
||||
|
||||
/*
|
||||
* Common flags fields for MADT subtables
|
||||
*/
|
||||
|
||||
/* MADT Local APIC flags (LapicFlags) and GIC flags */
|
||||
/* MADT Local APIC flags */
|
||||
|
||||
#define ACPI_MADT_ENABLED (1) /* 00: Processor is usable if set */
|
||||
|
||||
|
@ -1146,11 +1190,12 @@ enum AcpiSratType
|
|||
ACPI_SRAT_TYPE_CPU_AFFINITY = 0,
|
||||
ACPI_SRAT_TYPE_MEMORY_AFFINITY = 1,
|
||||
ACPI_SRAT_TYPE_X2APIC_CPU_AFFINITY = 2,
|
||||
ACPI_SRAT_TYPE_RESERVED = 3 /* 3 and greater are reserved */
|
||||
ACPI_SRAT_TYPE_GICC_AFFINITY = 3,
|
||||
ACPI_SRAT_TYPE_RESERVED = 4 /* 4 and greater are reserved */
|
||||
};
|
||||
|
||||
/*
|
||||
* SRAT Sub-tables, correspond to Type in ACPI_SUBTABLE_HEADER
|
||||
* SRAT Subtables, correspond to Type in ACPI_SUBTABLE_HEADER
|
||||
*/
|
||||
|
||||
/* 0: Processor Local APIC/SAPIC Affinity */
|
||||
|
@ -1163,7 +1208,7 @@ typedef struct acpi_srat_cpu_affinity
|
|||
UINT32 Flags;
|
||||
UINT8 LocalSapicEid;
|
||||
UINT8 ProximityDomainHi[3];
|
||||
UINT32 Reserved; /* Reserved, must be zero */
|
||||
UINT32 ClockDomain;
|
||||
|
||||
} ACPI_SRAT_CPU_AFFINITY;
|
||||
|
||||
|
@ -1213,6 +1258,22 @@ typedef struct acpi_srat_x2apic_cpu_affinity
|
|||
#define ACPI_SRAT_CPU_ENABLED (1) /* 00: Use affinity structure */
|
||||
|
||||
|
||||
/* 3: GICC Affinity (ACPI 5.1) */
|
||||
|
||||
typedef struct acpi_srat_gicc_affinity
|
||||
{
|
||||
ACPI_SUBTABLE_HEADER Header;
|
||||
UINT32 ProximityDomain;
|
||||
UINT32 AcpiProcessorUid;
|
||||
UINT32 Flags;
|
||||
UINT32 ClockDomain;
|
||||
|
||||
} ACPI_SRAT_GICC_AFFINITY;
|
||||
|
||||
/* Flags for ACPI_SRAT_GICC_AFFINITY */
|
||||
|
||||
#define ACPI_SRAT_GICC_ENABLED (1) /* 00: Use affinity structure */
|
||||
|
||||
/* Reset to default packing */
|
||||
|
||||
#pragma pack()
|
||||
|
|
|
@ -144,6 +144,7 @@
|
|||
#define ACPI_SIG_HPET "HPET" /* High Precision Event Timer table */
|
||||
#define ACPI_SIG_IBFT "IBFT" /* iSCSI Boot Firmware Table */
|
||||
#define ACPI_SIG_IVRS "IVRS" /* I/O Virtualization Reporting Structure */
|
||||
#define ACPI_SIG_LPIT "LPIT" /* Low Power Idle Table */
|
||||
#define ACPI_SIG_MCFG "MCFG" /* PCI Memory Mapped Configuration table */
|
||||
#define ACPI_SIG_MCHI "MCHI" /* Management Controller Host Interface table */
|
||||
#define ACPI_SIG_MTMR "MTMR" /* MID Timer table */
|
||||
|
@ -521,7 +522,7 @@ typedef struct acpi_table_dbgp
|
|||
* Version 1
|
||||
*
|
||||
* Conforms to "Intel Virtualization Technology for Directed I/O",
|
||||
* Version 1.2, Sept. 2008
|
||||
* Version 2.2, Sept. 2013
|
||||
*
|
||||
******************************************************************************/
|
||||
|
||||
|
@ -554,9 +555,10 @@ enum AcpiDmarType
|
|||
{
|
||||
ACPI_DMAR_TYPE_HARDWARE_UNIT = 0,
|
||||
ACPI_DMAR_TYPE_RESERVED_MEMORY = 1,
|
||||
ACPI_DMAR_TYPE_ATSR = 2,
|
||||
ACPI_DMAR_HARDWARE_AFFINITY = 3,
|
||||
ACPI_DMAR_TYPE_RESERVED = 4 /* 4 and greater are reserved */
|
||||
ACPI_DMAR_TYPE_ROOT_ATS = 2,
|
||||
ACPI_DMAR_TYPE_HARDWARE_AFFINITY = 3,
|
||||
ACPI_DMAR_TYPE_NAMESPACE = 4,
|
||||
ACPI_DMAR_TYPE_RESERVED = 5 /* 5 and greater are reserved */
|
||||
};
|
||||
|
||||
|
||||
|
@ -572,7 +574,7 @@ typedef struct acpi_dmar_device_scope
|
|||
|
||||
} ACPI_DMAR_DEVICE_SCOPE;
|
||||
|
||||
/* Values for EntryType in ACPI_DMAR_DEVICE_SCOPE */
|
||||
/* Values for EntryType in ACPI_DMAR_DEVICE_SCOPE - device types */
|
||||
|
||||
enum AcpiDmarScopeType
|
||||
{
|
||||
|
@ -581,7 +583,8 @@ enum AcpiDmarScopeType
|
|||
ACPI_DMAR_SCOPE_TYPE_BRIDGE = 2,
|
||||
ACPI_DMAR_SCOPE_TYPE_IOAPIC = 3,
|
||||
ACPI_DMAR_SCOPE_TYPE_HPET = 4,
|
||||
ACPI_DMAR_SCOPE_TYPE_RESERVED = 5 /* 5 and greater are reserved */
|
||||
ACPI_DMAR_SCOPE_TYPE_NAMESPACE = 5,
|
||||
ACPI_DMAR_SCOPE_TYPE_RESERVED = 6 /* 6 and greater are reserved */
|
||||
};
|
||||
|
||||
typedef struct acpi_dmar_pci_path
|
||||
|
@ -593,7 +596,7 @@ typedef struct acpi_dmar_pci_path
|
|||
|
||||
|
||||
/*
|
||||
* DMAR Sub-tables, correspond to Type in ACPI_DMAR_HEADER
|
||||
* DMAR Subtables, correspond to Type in ACPI_DMAR_HEADER
|
||||
*/
|
||||
|
||||
/* 0: Hardware Unit Definition */
|
||||
|
@ -658,6 +661,18 @@ typedef struct acpi_dmar_rhsa
|
|||
} ACPI_DMAR_RHSA;
|
||||
|
||||
|
||||
/* 4: ACPI Namespace Device Declaration Structure */
|
||||
|
||||
typedef struct acpi_dmar_andd
|
||||
{
|
||||
ACPI_DMAR_HEADER Header;
|
||||
UINT8 Reserved[3];
|
||||
UINT8 DeviceNumber;
|
||||
char DeviceName[1];
|
||||
|
||||
} ACPI_DMAR_ANDD;
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
*
|
||||
* HPET - High Precision Event Timer table
|
||||
|
@ -1006,7 +1021,83 @@ typedef struct acpi_ivrs_memory
|
|||
|
||||
/*******************************************************************************
|
||||
*
|
||||
* MCFG - PCI Memory Mapped Configuration table and sub-table
|
||||
* LPIT - Low Power Idle Table
|
||||
*
|
||||
* Conforms to "ACPI Low Power Idle Table (LPIT) and _LPD Proposal (DRAFT)"
|
||||
*
|
||||
******************************************************************************/
|
||||
|
||||
typedef struct acpi_table_lpit
|
||||
{
|
||||
ACPI_TABLE_HEADER Header; /* Common ACPI table header */
|
||||
|
||||
} ACPI_TABLE_LPIT;
|
||||
|
||||
|
||||
/* LPIT subtable header */
|
||||
|
||||
typedef struct acpi_lpit_header
|
||||
{
|
||||
UINT32 Type; /* Subtable type */
|
||||
UINT32 Length; /* Subtable length */
|
||||
UINT16 UniqueId;
|
||||
UINT16 Reserved;
|
||||
UINT32 Flags;
|
||||
|
||||
} ACPI_LPIT_HEADER;
|
||||
|
||||
/* Values for subtable Type above */
|
||||
|
||||
enum AcpiLpitType
|
||||
{
|
||||
ACPI_LPIT_TYPE_NATIVE_CSTATE = 0x00,
|
||||
ACPI_LPIT_TYPE_SIMPLE_IO = 0x01
|
||||
};
|
||||
|
||||
/* Masks for Flags field above */
|
||||
|
||||
#define ACPI_LPIT_STATE_DISABLED (1)
|
||||
#define ACPI_LPIT_NO_COUNTER (1<<1)
|
||||
|
||||
/*
|
||||
* LPIT subtables, correspond to Type in ACPI_LPIT_HEADER
|
||||
*/
|
||||
|
||||
/* 0x00: Native C-state instruction based LPI structure */
|
||||
|
||||
typedef struct acpi_lpit_native
|
||||
{
|
||||
ACPI_LPIT_HEADER Header;
|
||||
ACPI_GENERIC_ADDRESS EntryTrigger;
|
||||
UINT32 Residency;
|
||||
UINT32 Latency;
|
||||
ACPI_GENERIC_ADDRESS ResidencyCounter;
|
||||
UINT64 CounterFrequency;
|
||||
|
||||
} ACPI_LPIT_NATIVE;
|
||||
|
||||
|
||||
/* 0x01: Simple I/O based LPI structure */
|
||||
|
||||
typedef struct acpi_lpit_io
|
||||
{
|
||||
ACPI_LPIT_HEADER Header;
|
||||
ACPI_GENERIC_ADDRESS EntryTrigger;
|
||||
UINT32 TriggerAction;
|
||||
UINT64 TriggerValue;
|
||||
UINT64 TriggerMask;
|
||||
ACPI_GENERIC_ADDRESS MinimumIdleState;
|
||||
UINT32 Residency;
|
||||
UINT32 Latency;
|
||||
ACPI_GENERIC_ADDRESS ResidencyCounter;
|
||||
UINT64 CounterFrequency;
|
||||
|
||||
} ACPI_LPIT_IO;
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
*
|
||||
* MCFG - PCI Memory Mapped Configuration table and subtable
|
||||
* Version 1
|
||||
*
|
||||
* Conforms to "PCI Firmware Specification", Revision 3.0, June 20, 2005
|
||||
|
@ -1130,7 +1221,7 @@ enum AcpiSlicType
|
|||
|
||||
|
||||
/*
|
||||
* SLIC Sub-tables, correspond to Type in ACPI_SLIC_HEADER
|
||||
* SLIC Subtables, correspond to Type in ACPI_SLIC_HEADER
|
||||
*/
|
||||
|
||||
/* 0: Public Key Structure */
|
||||
|
|
|
@ -352,35 +352,115 @@ typedef struct acpi_s3pt_suspend
|
|||
|
||||
/*******************************************************************************
|
||||
*
|
||||
* GTDT - Generic Timer Description Table (ACPI 5.0)
|
||||
* Version 1
|
||||
* GTDT - Generic Timer Description Table (ACPI 5.1)
|
||||
* Version 2
|
||||
*
|
||||
******************************************************************************/
|
||||
|
||||
typedef struct acpi_table_gtdt
|
||||
{
|
||||
ACPI_TABLE_HEADER Header; /* Common ACPI table header */
|
||||
UINT64 Address;
|
||||
UINT32 Flags;
|
||||
UINT32 SecurePl1Interrupt;
|
||||
UINT32 SecurePl1Flags;
|
||||
UINT32 NonSecurePl1Interrupt;
|
||||
UINT32 NonSecurePl1Flags;
|
||||
UINT64 CounterBlockAddresss;
|
||||
UINT32 Reserved;
|
||||
UINT32 SecureEl1Interrupt;
|
||||
UINT32 SecureEl1Flags;
|
||||
UINT32 NonSecureEl1Interrupt;
|
||||
UINT32 NonSecureEl1Flags;
|
||||
UINT32 VirtualTimerInterrupt;
|
||||
UINT32 VirtualTimerFlags;
|
||||
UINT32 NonSecurePl2Interrupt;
|
||||
UINT32 NonSecurePl2Flags;
|
||||
UINT32 NonSecureEl2Interrupt;
|
||||
UINT32 NonSecureEl2Flags;
|
||||
UINT64 CounterReadBlockAddress;
|
||||
UINT32 PlatformTimerCount;
|
||||
UINT32 PlatformTimerOffset;
|
||||
|
||||
} ACPI_TABLE_GTDT;
|
||||
|
||||
/* Values for Flags field above */
|
||||
/* Flag Definitions: Timer Block Physical Timers and Virtual timers */
|
||||
|
||||
#define ACPI_GTDT_MAPPED_BLOCK_PRESENT 1
|
||||
#define ACPI_GTDT_INTERRUPT_MODE (1)
|
||||
#define ACPI_GTDT_INTERRUPT_POLARITY (1<<1)
|
||||
#define ACPI_GTDT_ALWAYS_ON (1<<2)
|
||||
|
||||
/* Values for all "TimerFlags" fields above */
|
||||
|
||||
#define ACPI_GTDT_INTERRUPT_MODE 1
|
||||
#define ACPI_GTDT_INTERRUPT_POLARITY 2
|
||||
/* Common GTDT subtable header */
|
||||
|
||||
typedef struct acpi_gtdt_header
|
||||
{
|
||||
UINT8 Type;
|
||||
UINT16 Length;
|
||||
|
||||
} ACPI_GTDT_HEADER;
|
||||
|
||||
/* Values for GTDT subtable type above */
|
||||
|
||||
enum AcpiGtdtType
|
||||
{
|
||||
ACPI_GTDT_TYPE_TIMER_BLOCK = 0,
|
||||
ACPI_GTDT_TYPE_WATCHDOG = 1,
|
||||
ACPI_GTDT_TYPE_RESERVED = 2 /* 2 and greater are reserved */
|
||||
};
|
||||
|
||||
|
||||
/* GTDT Subtables, correspond to Type in acpi_gtdt_header */
|
||||
|
||||
/* 0: Generic Timer Block */
|
||||
|
||||
typedef struct acpi_gtdt_timer_block
|
||||
{
|
||||
ACPI_GTDT_HEADER Header;
|
||||
UINT8 Reserved;
|
||||
UINT64 BlockAddress;
|
||||
UINT32 TimerCount;
|
||||
UINT32 TimerOffset;
|
||||
|
||||
} ACPI_GTDT_TIMER_BLOCK;
|
||||
|
||||
/* Timer Sub-Structure, one per timer */
|
||||
|
||||
typedef struct acpi_gtdt_timer_entry
|
||||
{
|
||||
UINT8 FrameNumber;
|
||||
UINT8 Reserved[3];
|
||||
UINT64 BaseAddress;
|
||||
UINT64 El0BaseAddress;
|
||||
UINT32 TimerInterrupt;
|
||||
UINT32 TimerFlags;
|
||||
UINT32 VirtualTimerInterrupt;
|
||||
UINT32 VirtualTimerFlags;
|
||||
UINT32 CommonFlags;
|
||||
|
||||
} ACPI_GTDT_TIMER_ENTRY;
|
||||
|
||||
/* Flag Definitions: TimerFlags and VirtualTimerFlags above */
|
||||
|
||||
#define ACPI_GTDT_GT_IRQ_MODE (1)
|
||||
#define ACPI_GTDT_GT_IRQ_POLARITY (1<<1)
|
||||
|
||||
/* Flag Definitions: CommonFlags above */
|
||||
|
||||
#define ACPI_GTDT_GT_IS_SECURE_TIMER (1)
|
||||
#define ACPI_GTDT_GT_ALWAYS_ON (1<<1)
|
||||
|
||||
|
||||
/* 1: SBSA Generic Watchdog Structure */
|
||||
|
||||
typedef struct acpi_gtdt_watchdog
|
||||
{
|
||||
ACPI_GTDT_HEADER Header;
|
||||
UINT8 Reserved;
|
||||
UINT64 RefreshFrameAddress;
|
||||
UINT64 ControlFrameAddress;
|
||||
UINT32 TimerInterrupt;
|
||||
UINT32 TimerFlags;
|
||||
|
||||
} ACPI_GTDT_WATCHDOG;
|
||||
|
||||
/* Flag Definitions: TimerFlags above */
|
||||
|
||||
#define ACPI_GTDT_WATCHDOG_IRQ_MODE (1)
|
||||
#define ACPI_GTDT_WATCHDOG_IRQ_POLARITY (1<<1)
|
||||
#define ACPI_GTDT_WATCHDOG_SECURE (1<<2)
|
||||
|
||||
|
||||
/*******************************************************************************
|
||||
|
@ -525,7 +605,8 @@ typedef struct acpi_table_pcct
|
|||
enum AcpiPcctType
|
||||
{
|
||||
ACPI_PCCT_TYPE_GENERIC_SUBSPACE = 0,
|
||||
ACPI_PCCT_TYPE_RESERVED = 1 /* 1 and greater are reserved */
|
||||
ACPI_PCCT_TYPE_HW_REDUCED_SUBSPACE = 1,
|
||||
ACPI_PCCT_TYPE_RESERVED = 2 /* 2 and greater are reserved */
|
||||
};
|
||||
|
||||
/*
|
||||
|
@ -550,6 +631,31 @@ typedef struct acpi_pcct_subspace
|
|||
} ACPI_PCCT_SUBSPACE;
|
||||
|
||||
|
||||
/* 1: HW-reduced Communications Subspace (ACPI 5.1) */
|
||||
|
||||
typedef struct acpi_pcct_hw_reduced
|
||||
{
|
||||
ACPI_SUBTABLE_HEADER Header;
|
||||
UINT32 DoorbellInterrupt;
|
||||
UINT8 Flags;
|
||||
UINT8 Reserved;
|
||||
UINT64 BaseAddress;
|
||||
UINT64 Length;
|
||||
ACPI_GENERIC_ADDRESS DoorbellRegister;
|
||||
UINT64 PreserveMask;
|
||||
UINT64 WriteMask;
|
||||
UINT32 Latency;
|
||||
UINT32 MaxAccessRate;
|
||||
UINT16 MinTurnaroundTime;
|
||||
|
||||
} ACPI_PCCT_HW_REDUCED;
|
||||
|
||||
/* Values for doorbell flags above */
|
||||
|
||||
#define ACPI_PCCT_INTERRUPT_POLARITY (1)
|
||||
#define ACPI_PCCT_INTERRUPT_MODE (1<<1)
|
||||
|
||||
|
||||
/*
|
||||
* PCC memory structures (not part of the ACPI table)
|
||||
*/
|
||||
|
|
|
@ -127,8 +127,6 @@
|
|||
#error ACPI_MACHINE_WIDTH not defined
|
||||
#endif
|
||||
|
||||
/*! [Begin] no source code translation */
|
||||
|
||||
/*
|
||||
* Data type ranges
|
||||
* Note: These macros are designed to be compiler independent as well as
|
||||
|
@ -196,15 +194,16 @@
|
|||
*
|
||||
******************************************************************************/
|
||||
|
||||
#ifndef __REACTOS__
|
||||
#ifndef ACPI_USE_SYSTEM_INTTYPES
|
||||
|
||||
typedef unsigned char BOOLEAN;
|
||||
typedef unsigned char UINT8;
|
||||
typedef unsigned short UINT16;
|
||||
typedef short INT16;
|
||||
typedef COMPILER_DEPENDENT_UINT64 UINT64;
|
||||
typedef COMPILER_DEPENDENT_INT64 INT64;
|
||||
#endif /* __REACTOS__ */
|
||||
|
||||
/*! [End] no source code translation !*/
|
||||
#endif /* ACPI_USE_SYSTEM_INTTYPES */
|
||||
|
||||
/*
|
||||
* Value returned by AcpiOsGetThreadId. There is no standard "thread_id"
|
||||
|
@ -225,14 +224,13 @@ typedef COMPILER_DEPENDENT_INT64 INT64;
|
|||
|
||||
#if ACPI_MACHINE_WIDTH == 64
|
||||
|
||||
/*! [Begin] no source code translation (keep the typedefs as-is) */
|
||||
#ifndef ACPI_USE_SYSTEM_INTTYPES
|
||||
|
||||
#ifndef __REACTOS__
|
||||
typedef unsigned int UINT32;
|
||||
typedef int INT32;
|
||||
#endif /* __REACTOS__ */
|
||||
|
||||
/*! [End] no source code translation !*/
|
||||
#endif /* ACPI_USE_SYSTEM_INTTYPES */
|
||||
|
||||
|
||||
|
||||
typedef INT64 ACPI_NATIVE_INT;
|
||||
|
@ -266,14 +264,13 @@ typedef UINT64 ACPI_PHYSICAL_ADDRESS;
|
|||
|
||||
#elif ACPI_MACHINE_WIDTH == 32
|
||||
|
||||
/*! [Begin] no source code translation (keep the typedefs as-is) */
|
||||
#ifndef ACPI_USE_SYSTEM_INTTYPES
|
||||
|
||||
#ifndef __REACTOS__
|
||||
typedef unsigned int UINT32;
|
||||
typedef int INT32;
|
||||
#endif /* __REACTOS__ */
|
||||
|
||||
/*! [End] no source code translation !*/
|
||||
#endif /* ACPI_USE_SYSTEM_INTTYPES */
|
||||
|
||||
|
||||
|
||||
typedef INT32 ACPI_NATIVE_INT;
|
||||
|
@ -412,6 +409,15 @@ typedef UINT32 ACPI_PHYSICAL_ADDRESS;
|
|||
*
|
||||
******************************************************************************/
|
||||
|
||||
#ifdef ACPI_NO_MEM_ALLOCATIONS
|
||||
|
||||
#define ACPI_ALLOCATE(a) NULL
|
||||
#define ACPI_ALLOCATE_ZEROED(a) NULL
|
||||
#define ACPI_FREE(a)
|
||||
#define ACPI_MEM_TRACKING(a)
|
||||
|
||||
#else /* ACPI_NO_MEM_ALLOCATIONS */
|
||||
|
||||
#ifdef ACPI_DBG_TRACK_ALLOCATIONS
|
||||
/*
|
||||
* Memory allocation tracking (used by AcpiExec to detect memory leaks)
|
||||
|
@ -433,6 +439,8 @@ typedef UINT32 ACPI_PHYSICAL_ADDRESS;
|
|||
|
||||
#endif /* ACPI_DBG_TRACK_ALLOCATIONS */
|
||||
|
||||
#endif /* ACPI_NO_MEM_ALLOCATIONS */
|
||||
|
||||
|
||||
/******************************************************************************
|
||||
*
|
||||
|
@ -590,7 +598,7 @@ typedef UINT64 ACPI_INTEGER;
|
|||
|
||||
#define ACPI_TO_POINTER(i) ACPI_ADD_PTR (void, (void *) NULL,(ACPI_SIZE) 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_OFFSET(d, f) ACPI_PTR_DIFF (&(((d *) 0)->f), (void *) NULL)
|
||||
#define ACPI_PHYSADDR_TO_PTR(i) ACPI_TO_POINTER(i)
|
||||
#define ACPI_PTR_TO_PHYSADDR(i) ACPI_TO_INTEGER(i)
|
||||
|
||||
|
@ -684,8 +692,9 @@ typedef UINT64 ACPI_INTEGER;
|
|||
#define ACPI_NOTIFY_RESERVED (UINT8) 0x0A
|
||||
#define ACPI_NOTIFY_LOCALITY_UPDATE (UINT8) 0x0B
|
||||
#define ACPI_NOTIFY_SHUTDOWN_REQUEST (UINT8) 0x0C
|
||||
#define ACPI_NOTIFY_AFFINITY_UPDATE (UINT8) 0x0D
|
||||
|
||||
#define ACPI_NOTIFY_MAX 0x0C
|
||||
#define ACPI_NOTIFY_MAX 0x0D
|
||||
|
||||
/*
|
||||
* Types associated with ACPI names and objects. The first group of
|
||||
|
@ -785,14 +794,15 @@ typedef UINT32 ACPI_EVENT_TYPE;
|
|||
* The encoding of ACPI_EVENT_STATUS is illustrated below.
|
||||
* Note that a set bit (1) indicates the property is TRUE
|
||||
* (e.g. if bit 0 is set then the event is enabled).
|
||||
* +-------------+-+-+-+
|
||||
* | Bits 31:3 |2|1|0|
|
||||
* +-------------+-+-+-+
|
||||
* | | | |
|
||||
* | | | +- Enabled?
|
||||
* | | +--- Enabled for wake?
|
||||
* | +----- Set?
|
||||
* +----------- <Reserved>
|
||||
* +-------------+-+-+-+-+
|
||||
* | Bits 31:4 |3|2|1|0|
|
||||
* +-------------+-+-+-+-+
|
||||
* | | | | |
|
||||
* | | | | +- Enabled?
|
||||
* | | | +--- Enabled for wake?
|
||||
* | | +----- Set?
|
||||
* | +------- Has a handler?
|
||||
* +------------- <Reserved>
|
||||
*/
|
||||
typedef UINT32 ACPI_EVENT_STATUS;
|
||||
|
||||
|
@ -800,6 +810,7 @@ typedef UINT32 ACPI_EVENT_STATUS;
|
|||
#define ACPI_EVENT_FLAG_ENABLED (ACPI_EVENT_STATUS) 0x01
|
||||
#define ACPI_EVENT_FLAG_WAKE_ENABLED (ACPI_EVENT_STATUS) 0x02
|
||||
#define ACPI_EVENT_FLAG_SET (ACPI_EVENT_STATUS) 0x04
|
||||
#define ACPI_EVENT_FLAG_HAS_HANDLER (ACPI_EVENT_STATUS) 0x08
|
||||
|
||||
/* Actions for AcpiSetGpe, AcpiGpeWakeup, AcpiHwLowSetGpe */
|
||||
|
||||
|
@ -1032,9 +1043,19 @@ typedef struct acpi_object_list
|
|||
* Miscellaneous common Data Structures used by the interfaces
|
||||
*/
|
||||
#define ACPI_NO_BUFFER 0
|
||||
|
||||
#ifdef ACPI_NO_MEM_ALLOCATIONS
|
||||
|
||||
#define ACPI_ALLOCATE_BUFFER (ACPI_SIZE) (0)
|
||||
#define ACPI_ALLOCATE_LOCAL_BUFFER (ACPI_SIZE) (0)
|
||||
|
||||
#else /* ACPI_NO_MEM_ALLOCATIONS */
|
||||
|
||||
#define ACPI_ALLOCATE_BUFFER (ACPI_SIZE) (-1) /* Let ACPICA allocate buffer */
|
||||
#define ACPI_ALLOCATE_LOCAL_BUFFER (ACPI_SIZE) (-2) /* For internal use only (enables tracking) */
|
||||
|
||||
#endif /* ACPI_NO_MEM_ALLOCATIONS */
|
||||
|
||||
typedef struct acpi_buffer
|
||||
{
|
||||
ACPI_SIZE Length; /* Length in bytes of the buffer */
|
||||
|
@ -1393,4 +1414,19 @@ typedef struct acpi_memory_list
|
|||
#define ACPI_OSI_WIN_8 0x0C
|
||||
|
||||
|
||||
/* Definitions of file IO */
|
||||
|
||||
#define ACPI_FILE_READING 0x01
|
||||
#define ACPI_FILE_WRITING 0x02
|
||||
#define ACPI_FILE_BINARY 0x04
|
||||
|
||||
#define ACPI_FILE_BEGIN 0x01
|
||||
#define ACPI_FILE_END 0x02
|
||||
|
||||
|
||||
/* Definitions of getopt */
|
||||
|
||||
#define ACPI_OPT_END -1
|
||||
|
||||
|
||||
#endif /* __ACTYPES_H__ */
|
||||
|
|
|
@ -168,7 +168,6 @@ extern const char *AcpiGbl_PtDecode[];
|
|||
#ifdef ACPI_ASL_COMPILER
|
||||
|
||||
#include <stdio.h>
|
||||
extern FILE *AcpiGbl_OutputFile;
|
||||
|
||||
#define ACPI_MSG_REDIRECT_BEGIN \
|
||||
FILE *OutputFile = AcpiGbl_OutputFile; \
|
||||
|
@ -298,6 +297,10 @@ AcpiUtHexToAsciiChar (
|
|||
UINT64 Integer,
|
||||
UINT32 Position);
|
||||
|
||||
UINT8
|
||||
AcpiUtAsciiCharToHex (
|
||||
int HexChar);
|
||||
|
||||
BOOLEAN
|
||||
AcpiUtValidObjectType (
|
||||
ACPI_OBJECT_TYPE Type);
|
||||
|
@ -324,6 +327,11 @@ ACPI_SIZE
|
|||
AcpiUtStrlen (
|
||||
const char *String);
|
||||
|
||||
char *
|
||||
AcpiUtStrchr (
|
||||
const char *String,
|
||||
int ch);
|
||||
|
||||
char *
|
||||
AcpiUtStrcpy (
|
||||
char *DstString,
|
||||
|
@ -412,7 +420,7 @@ extern const UINT8 _acpi_ctype[];
|
|||
#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_PRINT(c) (_acpi_ctype[(unsigned char)(c)] & (_ACPI_LO | _ACPI_UP | _ACPI_DI | _ACPI_XS | _ACPI_PU))
|
||||
#define ACPI_IS_ALPHA(c) (_acpi_ctype[(unsigned char)(c)] & (_ACPI_LO | _ACPI_UP))
|
||||
|
||||
#endif /* !ACPI_USE_SYSTEM_CLIBRARY */
|
||||
|
@ -554,6 +562,16 @@ AcpiUtDumpBuffer (
|
|||
UINT32 Display,
|
||||
UINT32 Offset);
|
||||
|
||||
#ifdef ACPI_APPLICATION
|
||||
void
|
||||
AcpiUtDumpBufferToFile (
|
||||
ACPI_FILE File,
|
||||
UINT8 *Buffer,
|
||||
UINT32 Count,
|
||||
UINT32 Display,
|
||||
UINT32 BaseOffset);
|
||||
#endif
|
||||
|
||||
void
|
||||
AcpiUtReportError (
|
||||
char *ModuleName,
|
||||
|
@ -622,6 +640,17 @@ AcpiUtExecutePowerMethods (
|
|||
UINT8 *OutValues);
|
||||
|
||||
|
||||
/*
|
||||
* utfileio - file operations
|
||||
*/
|
||||
#ifdef ACPI_APPLICATION
|
||||
ACPI_STATUS
|
||||
AcpiUtReadTableFromFile (
|
||||
char *Filename,
|
||||
ACPI_TABLE_HEADER **Table);
|
||||
#endif
|
||||
|
||||
|
||||
/*
|
||||
* utids - device ID support
|
||||
*/
|
||||
|
@ -1182,4 +1211,57 @@ const AH_DEVICE_ID *
|
|||
AcpiAhMatchHardwareId (
|
||||
char *Hid);
|
||||
|
||||
const char *
|
||||
AcpiAhMatchUuid (
|
||||
UINT8 *Data);
|
||||
|
||||
/*
|
||||
* utprint - printf/vprintf output functions
|
||||
*/
|
||||
const char *
|
||||
AcpiUtScanNumber (
|
||||
const char *String,
|
||||
UINT64 *NumberPtr);
|
||||
|
||||
const char *
|
||||
AcpiUtPrintNumber (
|
||||
char *String,
|
||||
UINT64 Number);
|
||||
|
||||
int
|
||||
AcpiUtVsnprintf (
|
||||
char *String,
|
||||
ACPI_SIZE Size,
|
||||
const char *Format,
|
||||
va_list Args);
|
||||
|
||||
int
|
||||
AcpiUtSnprintf (
|
||||
char *String,
|
||||
ACPI_SIZE Size,
|
||||
const char *Format,
|
||||
...);
|
||||
|
||||
#ifdef ACPI_APPLICATION
|
||||
int
|
||||
AcpiUtFileVprintf (
|
||||
ACPI_FILE File,
|
||||
const char *Format,
|
||||
va_list Args);
|
||||
|
||||
int
|
||||
AcpiUtFilePrintf (
|
||||
ACPI_FILE File,
|
||||
const char *Format,
|
||||
...);
|
||||
#endif
|
||||
|
||||
/*
|
||||
* utuuid -- UUID support functions
|
||||
*/
|
||||
void
|
||||
AcpiUtConvertStringToUuid (
|
||||
char *InString,
|
||||
UINT8 *UuidBuffer);
|
||||
|
||||
#endif /* _ACUTILS_H */
|
||||
|
|
|
@ -194,6 +194,14 @@ typedef struct asl_resource_node
|
|||
|
||||
} ASL_RESOURCE_NODE;
|
||||
|
||||
typedef struct asl_resource_info
|
||||
{
|
||||
ACPI_PARSE_OBJECT *DescriptorTypeOp; /* Resource descriptor parse node */
|
||||
ACPI_PARSE_OBJECT *MappingOp; /* Used for mapfile support */
|
||||
UINT32 CurrentByteOffset; /* Offset in resource template */
|
||||
|
||||
} ASL_RESOURCE_INFO;
|
||||
|
||||
|
||||
/* Macros used to generate AML resource length fields */
|
||||
|
||||
|
@ -646,4 +654,50 @@ typedef union aml_resource
|
|||
|
||||
} AML_RESOURCE;
|
||||
|
||||
|
||||
/* Interfaces used by both the disassembler and compiler */
|
||||
|
||||
void
|
||||
MpSaveGpioInfo (
|
||||
ACPI_PARSE_OBJECT *Op,
|
||||
AML_RESOURCE *Resource,
|
||||
UINT32 PinCount,
|
||||
UINT16 *PinList,
|
||||
char *DeviceName);
|
||||
|
||||
void
|
||||
MpSaveSerialInfo (
|
||||
ACPI_PARSE_OBJECT *Op,
|
||||
AML_RESOURCE *Resource,
|
||||
char *DeviceName);
|
||||
|
||||
char *
|
||||
MpGetHidFromParseTree (
|
||||
ACPI_NAMESPACE_NODE *HidNode);
|
||||
|
||||
char *
|
||||
MpGetHidViaNamestring (
|
||||
char *DeviceName);
|
||||
|
||||
char *
|
||||
MpGetConnectionInfo (
|
||||
ACPI_PARSE_OBJECT *Op,
|
||||
UINT32 PinIndex,
|
||||
ACPI_NAMESPACE_NODE **TargetNode,
|
||||
char **TargetName);
|
||||
|
||||
char *
|
||||
MpGetParentDeviceHid (
|
||||
ACPI_PARSE_OBJECT *Op,
|
||||
ACPI_NAMESPACE_NODE **TargetNode,
|
||||
char **ParentDeviceName);
|
||||
|
||||
char *
|
||||
MpGetDdnValue (
|
||||
char *DeviceName);
|
||||
|
||||
char *
|
||||
MpGetHidValue (
|
||||
ACPI_NAMESPACE_NODE *DeviceNode);
|
||||
|
||||
#endif
|
||||
|
|
|
@ -164,11 +164,14 @@
|
|||
|
||||
|
||||
/*
|
||||
* The vsnprintf function is defined by c99, but cygwin/gcc does not
|
||||
* enable this prototype when the -ansi flag is set. Also related to
|
||||
* __STRICT_ANSI__. So, we just declare the prototype here.
|
||||
* The vsnprintf/snprintf functions are defined by c99, but cygwin/gcc
|
||||
* does not enable this prototype when the -ansi flag is set. Also related
|
||||
* to __STRICT_ANSI__. So, we just declare the prototype here.
|
||||
*/
|
||||
int
|
||||
vsnprintf (char *s, size_t n, const char *format, va_list ap);
|
||||
|
||||
int
|
||||
snprintf (char *s, size_t n, const char *format, ...);
|
||||
|
||||
#endif /* __ACCYGWIN_H__ */
|
||||
|
|
|
@ -116,11 +116,20 @@
|
|||
#ifndef __ACEFI_H__
|
||||
#define __ACEFI_H__
|
||||
|
||||
#include <stdarg.h>
|
||||
#if defined(_GNU_EFI)
|
||||
#include <stdint.h>
|
||||
#include <unistd.h>
|
||||
#endif
|
||||
#include <efi.h>
|
||||
#include <efistdarg.h>
|
||||
#include <efilib.h>
|
||||
|
||||
|
||||
/* AED EFI definitions */
|
||||
|
||||
#if defined(_AED_EFI)
|
||||
|
||||
/* _int64 works for both IA32 and IA64 */
|
||||
|
||||
#define COMPILER_DEPENDENT_INT64 __int64
|
||||
|
@ -143,5 +152,57 @@
|
|||
|
||||
#pragma warning(disable:4142)
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
/* GNU EFI definitions */
|
||||
|
||||
#if defined(_GNU_EFI)
|
||||
|
||||
/* Using GCC for GNU EFI */
|
||||
|
||||
#include "acgcc.h"
|
||||
|
||||
#undef ACPI_USE_SYSTEM_CLIBRARY
|
||||
#undef ACPI_USE_STANDARD_HEADERS
|
||||
#undef ACPI_USE_NATIVE_DIVIDE
|
||||
#define ACPI_USE_SYSTEM_INTTYPES
|
||||
|
||||
#define ACPI_FILE SIMPLE_TEXT_OUTPUT_INTERFACE *
|
||||
#define ACPI_FILE_OUT ST->ConOut
|
||||
#define ACPI_FILE_ERR ST->ConOut
|
||||
|
||||
/*
|
||||
* Math helpers
|
||||
*/
|
||||
#define ACPI_DIV_64_BY_32(n_hi, n_lo, d32, q32, r32) \
|
||||
do { \
|
||||
UINT64 __n = ((UINT64) n_hi) << 32 | (n_lo); \
|
||||
(q32) = DivU64x32 ((__n), (d32), &(r32)); \
|
||||
} while (0)
|
||||
|
||||
#define ACPI_SHIFT_RIGHT_64(n_hi, n_lo) \
|
||||
do { \
|
||||
(n_lo) >>= 1; \
|
||||
(n_lo) |= (((n_hi) & 1) << 31); \
|
||||
(n_hi) >>= 1; \
|
||||
} while (0)
|
||||
|
||||
/*
|
||||
* EFI specific prototypes
|
||||
*/
|
||||
EFI_STATUS
|
||||
efi_main (
|
||||
EFI_HANDLE Image,
|
||||
EFI_SYSTEM_TABLE *SystemTab);
|
||||
|
||||
int
|
||||
acpi_main (
|
||||
int argc,
|
||||
char *argv[]);
|
||||
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
#endif /* __ACEFI_H__ */
|
||||
|
|
|
@ -160,20 +160,14 @@
|
|||
#define ACPI_DBG_TRACK_ALLOCATIONS
|
||||
#endif
|
||||
|
||||
/* AcpiNames configuration. Single threaded with debugger output enabled. */
|
||||
|
||||
#ifdef ACPI_NAMES_APP
|
||||
#define ACPI_DEBUGGER
|
||||
#define ACPI_APPLICATION
|
||||
#define ACPI_SINGLE_THREADED
|
||||
#endif
|
||||
|
||||
/*
|
||||
* AcpiBin/AcpiDump/AcpiSrc/AcpiXtract/Example configuration. All single
|
||||
* threaded, with no debug output.
|
||||
* AcpiBin/AcpiDump/AcpiHelp/AcpiNames/AcpiSrc/AcpiXtract/Example configuration.
|
||||
* All single threaded.
|
||||
*/
|
||||
#if (defined ACPI_BIN_APP) || \
|
||||
(defined ACPI_DUMP_APP) || \
|
||||
(defined ACPI_HELP_APP) || \
|
||||
(defined ACPI_NAMES_APP) || \
|
||||
(defined ACPI_SRC_APP) || \
|
||||
(defined ACPI_XTRACT_APP) || \
|
||||
(defined ACPI_EXAMPLE_APP)
|
||||
|
@ -181,12 +175,40 @@
|
|||
#define ACPI_SINGLE_THREADED
|
||||
#endif
|
||||
|
||||
/* AcpiHelp configuration. Error messages disabled. */
|
||||
|
||||
#ifdef ACPI_HELP_APP
|
||||
#define ACPI_APPLICATION
|
||||
#define ACPI_SINGLE_THREADED
|
||||
#define ACPI_NO_ERROR_MESSAGES
|
||||
#endif
|
||||
|
||||
/* AcpiNames configuration. Debug output enabled. */
|
||||
|
||||
#ifdef ACPI_NAMES_APP
|
||||
#define ACPI_DEBUG_OUTPUT
|
||||
#endif
|
||||
|
||||
/* AcpiExec/AcpiNames/Example configuration. Native RSDP used. */
|
||||
|
||||
#if (defined ACPI_EXEC_APP) || \
|
||||
(defined ACPI_EXAMPLE_APP) || \
|
||||
(defined ACPI_NAMES_APP)
|
||||
#define ACPI_USE_NATIVE_RSDP_POINTER
|
||||
#endif
|
||||
|
||||
/* AcpiDump configuration. Native mapping used if provied by OSPMs */
|
||||
|
||||
#ifdef ACPI_DUMP_APP
|
||||
#define ACPI_USE_NATIVE_MEMORY_MAPPING
|
||||
#define USE_NATIVE_ALLOCATE_ZEROED
|
||||
#endif
|
||||
|
||||
/* AcpiNames/Example configuration. Hardware disabled */
|
||||
|
||||
#if (defined ACPI_EXAMPLE_APP) || \
|
||||
(defined ACPI_NAMES_APP)
|
||||
#define ACPI_REDUCED_HARDWARE 1
|
||||
#endif
|
||||
|
||||
/* Linkable ACPICA library */
|
||||
|
||||
#ifdef ACPI_LIBRARY
|
||||
|
@ -257,6 +279,9 @@
|
|||
#elif defined(_AED_EFI)
|
||||
#include "acefi.h"
|
||||
|
||||
#elif defined(_GNU_EFI)
|
||||
#include "acefi.h"
|
||||
|
||||
#elif defined(__HAIKU__)
|
||||
#include "achaiku.h"
|
||||
|
||||
|
@ -477,8 +502,12 @@ typedef char *va_list;
|
|||
#ifdef ACPI_APPLICATION
|
||||
#include <stdio.h>
|
||||
#define ACPI_FILE FILE *
|
||||
#define ACPI_FILE_OUT stdout
|
||||
#define ACPI_FILE_ERR stderr
|
||||
#else
|
||||
#define ACPI_FILE void *
|
||||
#define ACPI_FILE_OUT NULL
|
||||
#define ACPI_FILE_ERR NULL
|
||||
#endif /* ACPI_APPLICATION */
|
||||
#endif /* ACPI_FILE */
|
||||
|
||||
|
|
135
reactos/drivers/bus/acpi/acpica/include/platform/acenvex.h
Normal file
135
reactos/drivers/bus/acpi/acpica/include/platform/acenvex.h
Normal file
|
@ -0,0 +1,135 @@
|
|||
/******************************************************************************
|
||||
*
|
||||
* Name: acenvex.h - Extra host and compiler configuration
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
/******************************************************************************
|
||||
*
|
||||
* 1. Copyright Notice
|
||||
*
|
||||
* Some or all of this work - Copyright (c) 1999 - 2014, Intel Corp.
|
||||
* All rights reserved.
|
||||
*
|
||||
* 2. License
|
||||
*
|
||||
* 2.1. This is your license from Intel Corp. under its intellectual property
|
||||
* rights. You may have additional license terms from the party that provided
|
||||
* you this software, covering your right to use that party's intellectual
|
||||
* property rights.
|
||||
*
|
||||
* 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
|
||||
* copy of the source code appearing in this file ("Covered Code") an
|
||||
* irrevocable, perpetual, worldwide license under Intel's copyrights in the
|
||||
* base code distributed originally by Intel ("Original Intel Code") to copy,
|
||||
* make derivatives, distribute, use and display any portion of the Covered
|
||||
* Code in any form, with the right to sublicense such rights; and
|
||||
*
|
||||
* 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
|
||||
* license (with the right to sublicense), under only those claims of Intel
|
||||
* patents that are infringed by the Original Intel Code, to make, use, sell,
|
||||
* offer to sell, and import the Covered Code and derivative works thereof
|
||||
* solely to the minimum extent necessary to exercise the above copyright
|
||||
* license, and in no event shall the patent license extend to any additions
|
||||
* to or modifications of the Original Intel Code. No other license or right
|
||||
* is granted directly or by implication, estoppel or otherwise;
|
||||
*
|
||||
* The above copyright and patent license is granted only if the following
|
||||
* conditions are met:
|
||||
*
|
||||
* 3. Conditions
|
||||
*
|
||||
* 3.1. Redistribution of Source with Rights to Further Distribute Source.
|
||||
* Redistribution of source code of any substantial portion of the Covered
|
||||
* Code or modification with rights to further distribute source must include
|
||||
* the above Copyright Notice, the above License, this list of Conditions,
|
||||
* and the following Disclaimer and Export Compliance provision. In addition,
|
||||
* Licensee must cause all Covered Code to which Licensee contributes to
|
||||
* contain a file documenting the changes Licensee made to create that Covered
|
||||
* Code and the date of any change. Licensee must include in that file the
|
||||
* documentation of any changes made by any predecessor Licensee. Licensee
|
||||
* must include a prominent statement that the modification is derived,
|
||||
* directly or indirectly, from Original Intel Code.
|
||||
*
|
||||
* 3.2. Redistribution of Source with no Rights to Further Distribute Source.
|
||||
* Redistribution of source code of any substantial portion of the Covered
|
||||
* Code or modification without rights to further distribute source must
|
||||
* include the following Disclaimer and Export Compliance provision in the
|
||||
* documentation and/or other materials provided with distribution. In
|
||||
* addition, Licensee may not authorize further sublicense of source of any
|
||||
* portion of the Covered Code, and must include terms to the effect that the
|
||||
* license from Licensee to its licensee is limited to the intellectual
|
||||
* property embodied in the software Licensee provides to its licensee, and
|
||||
* not to intellectual property embodied in modifications its licensee may
|
||||
* make.
|
||||
*
|
||||
* 3.3. Redistribution of Executable. Redistribution in executable form of any
|
||||
* substantial portion of the Covered Code or modification must reproduce the
|
||||
* above Copyright Notice, and the following Disclaimer and Export Compliance
|
||||
* provision in the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
*
|
||||
* 3.4. Intel retains all right, title, and interest in and to the Original
|
||||
* Intel Code.
|
||||
*
|
||||
* 3.5. Neither the name Intel nor any other trademark owned or controlled by
|
||||
* Intel shall be used in advertising or otherwise to promote the sale, use or
|
||||
* other dealings in products derived from or relating to the Covered Code
|
||||
* without prior written authorization from Intel.
|
||||
*
|
||||
* 4. Disclaimer and Export Compliance
|
||||
*
|
||||
* 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
|
||||
* HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
|
||||
* IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
|
||||
* INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
|
||||
* UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
|
||||
* PARTICULAR PURPOSE.
|
||||
*
|
||||
* 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
|
||||
* OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
|
||||
* COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
|
||||
* SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
|
||||
* CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
|
||||
* HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
|
||||
* SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
|
||||
* LIMITED REMEDY.
|
||||
*
|
||||
* 4.3. Licensee shall not export, either directly or indirectly, any of this
|
||||
* software or system incorporating such software without first obtaining any
|
||||
* required license or other approval from the U. S. Department of Commerce or
|
||||
* any other agency or department of the United States Government. In the
|
||||
* event Licensee exports any such software from the United States or
|
||||
* re-exports any such software from a foreign destination, Licensee shall
|
||||
* ensure that the distribution and export/re-export of the software is in
|
||||
* compliance with all laws, regulations, orders, or other restrictions of the
|
||||
* U.S. Export Administration Regulations. Licensee agrees that neither it nor
|
||||
* any of its subsidiaries will export/re-export any technical data, process,
|
||||
* software, or service, directly or indirectly, to any country for which the
|
||||
* United States government or any agency thereof requires an export license,
|
||||
* other governmental approval, or letter of assurance, without first obtaining
|
||||
* such license, approval or letter.
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#ifndef __ACENVEX_H__
|
||||
#define __ACENVEX_H__
|
||||
|
||||
/*! [Begin] no source code translation */
|
||||
|
||||
/******************************************************************************
|
||||
*
|
||||
* Extra host configuration files. All ACPICA headers are included before
|
||||
* including these files.
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#if defined(_LINUX) || defined(__linux__)
|
||||
#include "aclinuxex.h"
|
||||
|
||||
#endif
|
||||
|
||||
/*! [End] no source code translation !*/
|
||||
|
||||
#endif /* __ACENVEX_H__ */
|
|
@ -132,7 +132,8 @@ struct mutex;
|
|||
|
||||
#define ACPI_USE_NATIVE_DIVIDE
|
||||
|
||||
// #define ACPI_THREAD_ID thread_id
|
||||
/* #define ACPI_THREAD_ID thread_id */
|
||||
|
||||
#define ACPI_SEMAPHORE sem_id
|
||||
#define ACPI_SPINLOCK spinlock *
|
||||
#define ACPI_CPU_FLAGS cpu_status
|
||||
|
|
|
@ -116,15 +116,32 @@
|
|||
#ifndef __ACLINUX_H__
|
||||
#define __ACLINUX_H__
|
||||
|
||||
#ifdef __KERNEL__
|
||||
|
||||
/* ACPICA external files should not include ACPICA headers directly. */
|
||||
|
||||
#if !defined(BUILDING_ACPICA) && !defined(_LINUX_ACPI_H)
|
||||
#error "Please don't include <acpi/acpi.h> directly, include <linux/acpi.h> instead."
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
/* Common (in-kernel/user-space) ACPICA configuration */
|
||||
|
||||
#define ACPI_USE_SYSTEM_CLIBRARY
|
||||
#define ACPI_USE_DO_WHILE_0
|
||||
#define ACPI_MUTEX_TYPE ACPI_BINARY_SEMAPHORE
|
||||
|
||||
|
||||
#ifdef __KERNEL__
|
||||
|
||||
#define ACPI_USE_SYSTEM_INTTYPES
|
||||
|
||||
/* Compile for reduced hardware mode only with this kernel config */
|
||||
|
||||
#ifdef CONFIG_ACPI_REDUCED_HARDWARE_ONLY
|
||||
#define ACPI_REDUCED_HARDWARE 1
|
||||
#endif
|
||||
|
||||
#include <linux/string.h>
|
||||
#include <linux/kernel.h>
|
||||
#include <linux/ctype.h>
|
||||
|
@ -136,7 +153,40 @@
|
|||
#ifdef EXPORT_ACPI_INTERFACES
|
||||
#include <linux/export.h>
|
||||
#endif
|
||||
#include <asm/acpi.h>
|
||||
#ifdef CONFIG_ACPI
|
||||
#include <asm/acenv.h>
|
||||
#endif
|
||||
|
||||
#ifndef CONFIG_ACPI
|
||||
|
||||
/* External globals for __KERNEL__, stubs is needed */
|
||||
|
||||
#define ACPI_GLOBAL(t,a)
|
||||
#define ACPI_INIT_GLOBAL(t,a,b)
|
||||
|
||||
/* Generating stubs for configurable ACPICA macros */
|
||||
|
||||
#define ACPI_NO_MEM_ALLOCATIONS
|
||||
|
||||
/* Generating stubs for configurable ACPICA functions */
|
||||
|
||||
#define ACPI_NO_ERROR_MESSAGES
|
||||
#undef ACPI_DEBUG_OUTPUT
|
||||
|
||||
/* External interface for __KERNEL__, stub is needed */
|
||||
|
||||
#define ACPI_EXTERNAL_RETURN_STATUS(Prototype) \
|
||||
static ACPI_INLINE Prototype {return(AE_NOT_CONFIGURED);}
|
||||
#define ACPI_EXTERNAL_RETURN_OK(Prototype) \
|
||||
static ACPI_INLINE Prototype {return(AE_OK);}
|
||||
#define ACPI_EXTERNAL_RETURN_VOID(Prototype) \
|
||||
static ACPI_INLINE Prototype {return;}
|
||||
#define ACPI_EXTERNAL_RETURN_UINT32(Prototype) \
|
||||
static ACPI_INLINE Prototype {return(0);}
|
||||
#define ACPI_EXTERNAL_RETURN_PTR(Prototype) \
|
||||
static ACPI_INLINE Prototype {return(NULL);}
|
||||
|
||||
#endif /* CONFIG_ACPI */
|
||||
|
||||
/* Host-dependent types and defines for in-kernel ACPICA */
|
||||
|
||||
|
@ -148,6 +198,40 @@
|
|||
#define ACPI_SPINLOCK spinlock_t *
|
||||
#define ACPI_CPU_FLAGS unsigned long
|
||||
|
||||
/* Use native linux version of AcpiOsAllocateZeroed */
|
||||
|
||||
#define USE_NATIVE_ALLOCATE_ZEROED
|
||||
|
||||
/*
|
||||
* Overrides for in-kernel ACPICA
|
||||
*/
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsInitialize
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTerminate
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAllocate
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAllocateZeroed
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsFree
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireObject
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetThreadId
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateLock
|
||||
|
||||
/*
|
||||
* OSL interfaces used by debugger/disassembler
|
||||
*/
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadable
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritable
|
||||
|
||||
/*
|
||||
* OSL interfaces used by utilities
|
||||
*/
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsRedirectOutput
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetLine
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByName
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByIndex
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByAddress
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsOpenDirectory
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetNextFilename
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCloseDirectory
|
||||
|
||||
#else /* !__KERNEL__ */
|
||||
|
||||
#include <stdarg.h>
|
||||
|
@ -162,10 +246,6 @@
|
|||
#define __init
|
||||
#endif
|
||||
|
||||
#ifndef __iomem
|
||||
#define __iomem
|
||||
#endif
|
||||
|
||||
/* Host-dependent types and defines for user-space ACPICA */
|
||||
|
||||
#define ACPI_FLUSH_CPU_CACHE()
|
||||
|
@ -193,153 +273,4 @@
|
|||
|
||||
#include "acgcc.h"
|
||||
|
||||
|
||||
#ifdef __KERNEL__
|
||||
|
||||
/*
|
||||
* FIXME: Inclusion of actypes.h
|
||||
* Linux kernel need this before defining inline OSL interfaces as
|
||||
* actypes.h need to be included to find ACPICA type definitions.
|
||||
* Since from ACPICA's perspective, the actypes.h should be included after
|
||||
* acenv.h (aclinux.h), this leads to a inclusion mis-ordering issue.
|
||||
*/
|
||||
#include <acpi/actypes.h>
|
||||
|
||||
/*
|
||||
* Overrides for in-kernel ACPICA
|
||||
*/
|
||||
ACPI_STATUS __init AcpiOsInitialize (
|
||||
void);
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsInitialize
|
||||
|
||||
ACPI_STATUS AcpiOsTerminate (
|
||||
void);
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsTerminate
|
||||
|
||||
/*
|
||||
* Memory allocation/deallocation
|
||||
*/
|
||||
|
||||
/*
|
||||
* The irqs_disabled() check is for resume from RAM.
|
||||
* Interrupts are off during resume, just like they are for boot.
|
||||
* However, boot has (system_state != SYSTEM_RUNNING)
|
||||
* to quiet __might_sleep() in kmalloc() and resume does not.
|
||||
*/
|
||||
static inline void *
|
||||
AcpiOsAllocate (
|
||||
ACPI_SIZE Size)
|
||||
{
|
||||
return kmalloc (Size, irqs_disabled () ? GFP_ATOMIC : GFP_KERNEL);
|
||||
}
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAllocate
|
||||
|
||||
/* Use native linux version of AcpiOsAllocateZeroed */
|
||||
|
||||
static inline void *
|
||||
AcpiOsAllocateZeroed (
|
||||
ACPI_SIZE Size)
|
||||
{
|
||||
return kzalloc (Size, irqs_disabled () ? GFP_ATOMIC : GFP_KERNEL);
|
||||
}
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAllocateZeroed
|
||||
#define USE_NATIVE_ALLOCATE_ZEROED
|
||||
|
||||
static inline void
|
||||
AcpiOsFree (
|
||||
void *Memory)
|
||||
{
|
||||
kfree (Memory);
|
||||
}
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsFree
|
||||
|
||||
static inline void *
|
||||
AcpiOsAcquireObject (
|
||||
ACPI_CACHE_T *Cache)
|
||||
{
|
||||
return kmem_cache_zalloc (Cache,
|
||||
irqs_disabled () ? GFP_ATOMIC : GFP_KERNEL);
|
||||
}
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsAcquireObject
|
||||
|
||||
static inline ACPI_THREAD_ID
|
||||
AcpiOsGetThreadId (
|
||||
void)
|
||||
{
|
||||
return (ACPI_THREAD_ID) (unsigned long) current;
|
||||
}
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetThreadId
|
||||
|
||||
#ifndef CONFIG_PREEMPT
|
||||
|
||||
/*
|
||||
* Used within ACPICA to show where it is safe to preempt execution
|
||||
* when CONFIG_PREEMPT=n
|
||||
*/
|
||||
#define ACPI_PREEMPTION_POINT() \
|
||||
do { \
|
||||
if (!irqs_disabled()) \
|
||||
cond_resched(); \
|
||||
} while (0)
|
||||
|
||||
#endif
|
||||
|
||||
/*
|
||||
* When lockdep is enabled, the spin_lock_init() macro stringifies it's
|
||||
* argument and uses that as a name for the lock in debugging.
|
||||
* By executing spin_lock_init() in a macro the key changes from "lock" for
|
||||
* all locks to the name of the argument of acpi_os_create_lock(), which
|
||||
* prevents lockdep from reporting false positives for ACPICA locks.
|
||||
*/
|
||||
#define AcpiOsCreateLock(__Handle) \
|
||||
({ \
|
||||
spinlock_t *Lock = ACPI_ALLOCATE(sizeof(*Lock)); \
|
||||
if (Lock) { \
|
||||
*(__Handle) = Lock; \
|
||||
spin_lock_init(*(__Handle)); \
|
||||
} \
|
||||
Lock ? AE_OK : AE_NO_MEMORY; \
|
||||
})
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCreateLock
|
||||
|
||||
void __iomem *
|
||||
AcpiOsMapMemory (
|
||||
ACPI_PHYSICAL_ADDRESS Where,
|
||||
ACPI_SIZE Length);
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsMapMemory
|
||||
|
||||
void
|
||||
AcpiOsUnmapMemory (
|
||||
void __iomem *LogicalAddress,
|
||||
ACPI_SIZE Size);
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsUnmapMemory
|
||||
|
||||
/*
|
||||
* OSL interfaces used by debugger/disassembler
|
||||
*/
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsReadable
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsWritable
|
||||
|
||||
/*
|
||||
* OSL interfaces used by utilities
|
||||
*/
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsRedirectOutput
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetLine
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByName
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByIndex
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetTableByAddress
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsOpenDirectory
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsGetNextFilename
|
||||
#define ACPI_USE_ALTERNATE_PROTOTYPE_AcpiOsCloseDirectory
|
||||
|
||||
/*
|
||||
* OSL interfaces added by Linux
|
||||
*/
|
||||
void
|
||||
EarlyAcpiOsUnmapMemory (
|
||||
void __iomem *Virt,
|
||||
ACPI_SIZE Size);
|
||||
|
||||
#endif /* __KERNEL__ */
|
||||
|
||||
#endif /* __ACLINUX_H__ */
|
||||
|
|
221
reactos/drivers/bus/acpi/acpica/include/platform/aclinuxex.h
Normal file
221
reactos/drivers/bus/acpi/acpica/include/platform/aclinuxex.h
Normal file
|
@ -0,0 +1,221 @@
|
|||
/******************************************************************************
|
||||
*
|
||||
* Name: aclinuxex.h - Extra OS specific defines, etc. for Linux
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
/******************************************************************************
|
||||
*
|
||||
* 1. Copyright Notice
|
||||
*
|
||||
* Some or all of this work - Copyright (c) 1999 - 2014, Intel Corp.
|
||||
* All rights reserved.
|
||||
*
|
||||
* 2. License
|
||||
*
|
||||
* 2.1. This is your license from Intel Corp. under its intellectual property
|
||||
* rights. You may have additional license terms from the party that provided
|
||||
* you this software, covering your right to use that party's intellectual
|
||||
* property rights.
|
||||
*
|
||||
* 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
|
||||
* copy of the source code appearing in this file ("Covered Code") an
|
||||
* irrevocable, perpetual, worldwide license under Intel's copyrights in the
|
||||
* base code distributed originally by Intel ("Original Intel Code") to copy,
|
||||
* make derivatives, distribute, use and display any portion of the Covered
|
||||
* Code in any form, with the right to sublicense such rights; and
|
||||
*
|
||||
* 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
|
||||
* license (with the right to sublicense), under only those claims of Intel
|
||||
* patents that are infringed by the Original Intel Code, to make, use, sell,
|
||||
* offer to sell, and import the Covered Code and derivative works thereof
|
||||
* solely to the minimum extent necessary to exercise the above copyright
|
||||
* license, and in no event shall the patent license extend to any additions
|
||||
* to or modifications of the Original Intel Code. No other license or right
|
||||
* is granted directly or by implication, estoppel or otherwise;
|
||||
*
|
||||
* The above copyright and patent license is granted only if the following
|
||||
* conditions are met:
|
||||
*
|
||||
* 3. Conditions
|
||||
*
|
||||
* 3.1. Redistribution of Source with Rights to Further Distribute Source.
|
||||
* Redistribution of source code of any substantial portion of the Covered
|
||||
* Code or modification with rights to further distribute source must include
|
||||
* the above Copyright Notice, the above License, this list of Conditions,
|
||||
* and the following Disclaimer and Export Compliance provision. In addition,
|
||||
* Licensee must cause all Covered Code to which Licensee contributes to
|
||||
* contain a file documenting the changes Licensee made to create that Covered
|
||||
* Code and the date of any change. Licensee must include in that file the
|
||||
* documentation of any changes made by any predecessor Licensee. Licensee
|
||||
* must include a prominent statement that the modification is derived,
|
||||
* directly or indirectly, from Original Intel Code.
|
||||
*
|
||||
* 3.2. Redistribution of Source with no Rights to Further Distribute Source.
|
||||
* Redistribution of source code of any substantial portion of the Covered
|
||||
* Code or modification without rights to further distribute source must
|
||||
* include the following Disclaimer and Export Compliance provision in the
|
||||
* documentation and/or other materials provided with distribution. In
|
||||
* addition, Licensee may not authorize further sublicense of source of any
|
||||
* portion of the Covered Code, and must include terms to the effect that the
|
||||
* license from Licensee to its licensee is limited to the intellectual
|
||||
* property embodied in the software Licensee provides to its licensee, and
|
||||
* not to intellectual property embodied in modifications its licensee may
|
||||
* make.
|
||||
*
|
||||
* 3.3. Redistribution of Executable. Redistribution in executable form of any
|
||||
* substantial portion of the Covered Code or modification must reproduce the
|
||||
* above Copyright Notice, and the following Disclaimer and Export Compliance
|
||||
* provision in the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
*
|
||||
* 3.4. Intel retains all right, title, and interest in and to the Original
|
||||
* Intel Code.
|
||||
*
|
||||
* 3.5. Neither the name Intel nor any other trademark owned or controlled by
|
||||
* Intel shall be used in advertising or otherwise to promote the sale, use or
|
||||
* other dealings in products derived from or relating to the Covered Code
|
||||
* without prior written authorization from Intel.
|
||||
*
|
||||
* 4. Disclaimer and Export Compliance
|
||||
*
|
||||
* 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
|
||||
* HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
|
||||
* IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
|
||||
* INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
|
||||
* UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
|
||||
* PARTICULAR PURPOSE.
|
||||
*
|
||||
* 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
|
||||
* OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
|
||||
* COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
|
||||
* SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
|
||||
* CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
|
||||
* HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
|
||||
* SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
|
||||
* LIMITED REMEDY.
|
||||
*
|
||||
* 4.3. Licensee shall not export, either directly or indirectly, any of this
|
||||
* software or system incorporating such software without first obtaining any
|
||||
* required license or other approval from the U. S. Department of Commerce or
|
||||
* any other agency or department of the United States Government. In the
|
||||
* event Licensee exports any such software from the United States or
|
||||
* re-exports any such software from a foreign destination, Licensee shall
|
||||
* ensure that the distribution and export/re-export of the software is in
|
||||
* compliance with all laws, regulations, orders, or other restrictions of the
|
||||
* U.S. Export Administration Regulations. Licensee agrees that neither it nor
|
||||
* any of its subsidiaries will export/re-export any technical data, process,
|
||||
* software, or service, directly or indirectly, to any country for which the
|
||||
* United States government or any agency thereof requires an export license,
|
||||
* other governmental approval, or letter of assurance, without first obtaining
|
||||
* such license, approval or letter.
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#ifndef __ACLINUXEX_H__
|
||||
#define __ACLINUXEX_H__
|
||||
|
||||
#ifdef __KERNEL__
|
||||
|
||||
#ifndef ACPI_USE_NATIVE_DIVIDE
|
||||
|
||||
#ifndef ACPI_DIV_64_BY_32
|
||||
#define ACPI_DIV_64_BY_32(n_hi, n_lo, d32, q32, r32) \
|
||||
do { \
|
||||
UINT64 (__n) = ((UINT64) n_hi) << 32 | (n_lo); \
|
||||
(r32) = do_div ((__n), (d32)); \
|
||||
(q32) = (UINT32) (__n); \
|
||||
} while (0)
|
||||
#endif
|
||||
|
||||
#ifndef ACPI_SHIFT_RIGHT_64
|
||||
#define ACPI_SHIFT_RIGHT_64(n_hi, n_lo) \
|
||||
do { \
|
||||
(n_lo) >>= 1; \
|
||||
(n_lo) |= (((n_hi) & 1) << 31); \
|
||||
(n_hi) >>= 1; \
|
||||
} while (0)
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Overrides for in-kernel ACPICA
|
||||
*/
|
||||
ACPI_STATUS __init AcpiOsInitialize (
|
||||
void);
|
||||
|
||||
ACPI_STATUS AcpiOsTerminate (
|
||||
void);
|
||||
|
||||
/*
|
||||
* The irqs_disabled() check is for resume from RAM.
|
||||
* Interrupts are off during resume, just like they are for boot.
|
||||
* However, boot has (system_state != SYSTEM_RUNNING)
|
||||
* to quiet __might_sleep() in kmalloc() and resume does not.
|
||||
*/
|
||||
static inline void *
|
||||
AcpiOsAllocate (
|
||||
ACPI_SIZE Size)
|
||||
{
|
||||
return kmalloc (Size, irqs_disabled () ? GFP_ATOMIC : GFP_KERNEL);
|
||||
}
|
||||
|
||||
static inline void *
|
||||
AcpiOsAllocateZeroed (
|
||||
ACPI_SIZE Size)
|
||||
{
|
||||
return kzalloc (Size, irqs_disabled () ? GFP_ATOMIC : GFP_KERNEL);
|
||||
}
|
||||
|
||||
static inline void
|
||||
AcpiOsFree (
|
||||
void *Memory)
|
||||
{
|
||||
kfree (Memory);
|
||||
}
|
||||
|
||||
static inline void *
|
||||
AcpiOsAcquireObject (
|
||||
ACPI_CACHE_T *Cache)
|
||||
{
|
||||
return kmem_cache_zalloc (Cache,
|
||||
irqs_disabled () ? GFP_ATOMIC : GFP_KERNEL);
|
||||
}
|
||||
|
||||
static inline ACPI_THREAD_ID
|
||||
AcpiOsGetThreadId (
|
||||
void)
|
||||
{
|
||||
return (ACPI_THREAD_ID) (unsigned long) current;
|
||||
}
|
||||
|
||||
/*
|
||||
* When lockdep is enabled, the spin_lock_init() macro stringifies it's
|
||||
* argument and uses that as a name for the lock in debugging.
|
||||
* By executing spin_lock_init() in a macro the key changes from "lock" for
|
||||
* all locks to the name of the argument of acpi_os_create_lock(), which
|
||||
* prevents lockdep from reporting false positives for ACPICA locks.
|
||||
*/
|
||||
#define AcpiOsCreateLock(__Handle) \
|
||||
({ \
|
||||
spinlock_t *Lock = ACPI_ALLOCATE(sizeof(*Lock)); \
|
||||
if (Lock) { \
|
||||
*(__Handle) = Lock; \
|
||||
spin_lock_init(*(__Handle)); \
|
||||
} \
|
||||
Lock ? AE_OK : AE_NO_MEMORY; \
|
||||
})
|
||||
|
||||
/*
|
||||
* OSL interfaces added by Linux
|
||||
*/
|
||||
void
|
||||
EarlyAcpiOsUnmapMemory (
|
||||
void __iomem *Virt,
|
||||
ACPI_SIZE Size);
|
||||
|
||||
#endif /* __KERNEL__ */
|
||||
|
||||
#endif /* __ACLINUXEX_H__ */
|
|
@ -285,6 +285,10 @@
|
|||
/* Debug support. Must be last in this file, do not move. */
|
||||
|
||||
#ifdef _DEBUG
|
||||
#define _CRTDBG_MAP_ALLOC /* Enables specific file/lineno for leaks */
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <malloc.h>
|
||||
#include <crtdbg.h>
|
||||
|
||||
/*
|
||||
|
@ -294,9 +298,26 @@
|
|||
* This can quickly localize the memory corruption.
|
||||
*/
|
||||
#define ACPI_DEBUG_INITIALIZE() \
|
||||
_CrtSetDbgFlag (_CRTDBG_CHECK_ALWAYS_DF | \
|
||||
_CRTDBG_ALLOC_MEM_DF | _CRTDBG_CHECK_CRT_DF | \
|
||||
_CrtSetDbgFlag(_CRTDBG_REPORT_FLAG))
|
||||
_CrtSetDbgFlag (\
|
||||
_CRTDBG_CHECK_ALWAYS_DF | \
|
||||
_CRTDBG_ALLOC_MEM_DF | \
|
||||
_CRTDBG_DELAY_FREE_MEM_DF | \
|
||||
_CRTDBG_LEAK_CHECK_DF | \
|
||||
_CrtSetDbgFlag(_CRTDBG_REPORT_FLAG));
|
||||
|
||||
#if 0
|
||||
/*
|
||||
* _CrtSetBreakAlloc can be used to set a breakpoint at a particular
|
||||
* memory leak, add to the macro above.
|
||||
*/
|
||||
Detected memory leaks!
|
||||
Dumping objects ->
|
||||
..\..\source\os_specific\service_layers\oswinxf.c(701) : {937} normal block at 0x002E9190, 40 bytes long.
|
||||
Data: < > 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||
|
||||
_CrtSetBreakAlloc (937);
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
#endif /* __ACMSVC_H__ */
|
||||
|
|
|
@ -126,6 +126,8 @@
|
|||
#if !defined(_MSC_VER) && defined(__GNUC__)
|
||||
#include "acgcc.h"
|
||||
#endif
|
||||
|
||||
#define ACPI_USE_SYSTEM_INTTYPES
|
||||
#endif /* __REACTOS __ */
|
||||
/*! [End] no source code translation !*/
|
||||
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __NSACCESS_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "amlcode.h"
|
||||
|
|
|
@ -113,9 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __NSALLOC_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acnamesp.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __NSCONVERT_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acnamesp.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __NSDUMP_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acnamesp.h"
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __NSDUMPDV_C__
|
||||
|
||||
#include "acpi.h"
|
||||
|
||||
|
||||
|
|
|
@ -114,8 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __NSEVAL_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acparser.h"
|
||||
|
|
|
@ -113,9 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __NSXFINIT_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acnamesp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __NSLOAD_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acnamesp.h"
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __NSNAMES_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "amlcode.h"
|
||||
|
|
|
@ -114,9 +114,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
|
||||
#define __NSOBJECT_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acnamesp.h"
|
||||
|
@ -335,6 +332,16 @@ AcpiNsDetachObject (
|
|||
{
|
||||
Node->Object = Node->Object->Common.NextObject;
|
||||
}
|
||||
|
||||
/*
|
||||
* Detach the object from any data objects (which are still held by
|
||||
* the namespace node)
|
||||
*/
|
||||
if (ObjDesc->Common.NextObject &&
|
||||
((ObjDesc->Common.NextObject)->Common.Type == ACPI_TYPE_LOCAL_DATA))
|
||||
{
|
||||
ObjDesc->Common.NextObject = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
/* Reset the node type to untyped */
|
||||
|
|
|
@ -113,8 +113,6 @@
|
|||
*
|
||||
*****************************************************************************/
|
||||
|
||||
#define __NSPARSE_C__
|
||||
|
||||
#include "acpi.h"
|
||||
#include "accommon.h"
|
||||
#include "acnamesp.h"
|
||||
|
|
|
@ -393,6 +393,46 @@ AcpiNsCheckPackage (
|
|||
Status = AcpiNsCheckPackageList (Info, Package, Elements, Count);
|
||||
break;
|
||||
|
||||
case ACPI_PTYPE2_UUID_PAIR:
|
||||
|
||||
/* The package must contain pairs of (UUID + type) */
|
||||
|
||||
if (Count & 1)
|
||||
{
|
||||
ExpectedCount = Count + 1;
|
||||
goto PackageTooSmall;
|
||||
}
|
||||
|
||||
while (Count > 0)
|
||||
{
|
||||
Status = AcpiNsCheckObjectType(Info, Elements,
|
||||
Package->RetInfo.ObjectType1, 0);
|
||||
if (ACPI_FAILURE(Status))
|
||||
{
|
||||
return (Status);
|
||||
}
|
||||
|
||||
/* Validate length of the UUID buffer */
|
||||
|
||||
if ((*Elements)->Buffer.Length != 16)
|
||||
{
|
||||
ACPI_WARN_PREDEFINED ((AE_INFO, Info->FullPathname,
|
||||
Info->NodeFlags, "Invalid length for UUID Buffer"));
|
||||
return (AE_AML_OPERAND_VALUE);
|
||||
}
|
||||
|
||||
Status = AcpiNsCheckObjectType(Info, Elements + 1,
|
||||
Package->RetInfo.ObjectType2, 0);
|
||||
if (ACPI_FAILURE(Status))
|
||||
{
|
||||
return (Status);
|
||||
}
|
||||
|
||||
Elements += 2;
|
||||
Count -= 2;
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
|
||||
/* Should not get here if predefined info table is correct */
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue