2020-03-26 14:45:59 +00:00
|
|
|
/*
|
2022-01-10 03:35:45 +00:00
|
|
|
* PROJECT: ReactOS Kernel&Driver SDK
|
|
|
|
* LICENSE: GPL-2.0-or-later (https://spdx.org/licenses/GPL-2.0-or-later)
|
|
|
|
* PURPOSE: Hardware Resources Arbiter Library
|
|
|
|
* COPYRIGHT: Copyright 2020 Vadim Galyant <vgal@rambler.ru>
|
2020-03-26 14:45:59 +00:00
|
|
|
*/
|
|
|
|
|
2022-01-10 03:35:45 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#define ARBITER_SIGNATURE 'sbrA'
|
|
|
|
#define TAG_ARBITER 'MbrA'
|
|
|
|
#define TAG_ARB_ALLOCATION 'AbrA'
|
|
|
|
#define TAG_ARB_RANGE 'RbrA'
|
2020-03-26 14:45:59 +00:00
|
|
|
|
|
|
|
typedef struct _ARBITER_ORDERING
|
|
|
|
{
|
2022-01-10 03:35:45 +00:00
|
|
|
UINT64 Start;
|
|
|
|
UINT64 End;
|
2020-03-26 14:45:59 +00:00
|
|
|
} ARBITER_ORDERING, *PARBITER_ORDERING;
|
|
|
|
|
|
|
|
typedef struct _ARBITER_ORDERING_LIST
|
|
|
|
{
|
2022-01-10 03:35:45 +00:00
|
|
|
UINT16 Count;
|
|
|
|
UINT16 Maximum;
|
2020-03-26 14:45:59 +00:00
|
|
|
PARBITER_ORDERING Orderings;
|
|
|
|
} ARBITER_ORDERING_LIST, *PARBITER_ORDERING_LIST;
|
|
|
|
|
|
|
|
typedef struct _ARBITER_ALTERNATIVE
|
|
|
|
{
|
2022-01-10 03:35:45 +00:00
|
|
|
UINT64 Minimum;
|
|
|
|
UINT64 Maximum;
|
|
|
|
UINT32 Length;
|
|
|
|
UINT32 Alignment;
|
|
|
|
INT32 Priority;
|
|
|
|
UINT32 Flags;
|
2020-03-26 14:45:59 +00:00
|
|
|
PIO_RESOURCE_DESCRIPTOR Descriptor;
|
2022-01-10 03:35:45 +00:00
|
|
|
UINT32 Reserved[3];
|
2020-03-26 14:45:59 +00:00
|
|
|
} ARBITER_ALTERNATIVE, *PARBITER_ALTERNATIVE;
|
|
|
|
|
|
|
|
typedef struct _ARBITER_ALLOCATION_STATE
|
|
|
|
{
|
2022-01-10 03:35:45 +00:00
|
|
|
UINT64 Start;
|
|
|
|
UINT64 End;
|
|
|
|
UINT64 CurrentMinimum;
|
|
|
|
UINT64 CurrentMaximum;
|
2020-03-26 14:45:59 +00:00
|
|
|
PARBITER_LIST_ENTRY Entry;
|
|
|
|
PARBITER_ALTERNATIVE CurrentAlternative;
|
2022-01-10 03:35:45 +00:00
|
|
|
UINT32 AlternativeCount;
|
2020-03-26 14:45:59 +00:00
|
|
|
PARBITER_ALTERNATIVE Alternatives;
|
2022-01-10 03:35:45 +00:00
|
|
|
UINT16 Flags;
|
2020-03-26 14:45:59 +00:00
|
|
|
UCHAR RangeAttributes;
|
|
|
|
UCHAR RangeAvailableAttributes;
|
|
|
|
ULONG_PTR WorkSpace;
|
|
|
|
} ARBITER_ALLOCATION_STATE, *PARBITER_ALLOCATION_STATE;
|
|
|
|
|
|
|
|
typedef struct _ARBITER_INSTANCE *PARBITER_INSTANCE;
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_UNPACK_REQUIREMENT)(
|
|
|
|
_In_ PIO_RESOURCE_DESCRIPTOR IoDescriptor,
|
2022-01-10 03:35:45 +00:00
|
|
|
_Out_ PUINT64 OutMinimumAddress,
|
|
|
|
_Out_ PUINT64 OutMaximumAddress,
|
|
|
|
_Out_ PUINT32 OutLength,
|
|
|
|
_Out_ PUINT32 OutAlignment
|
2020-03-26 14:45:59 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_PACK_RESOURCE)(
|
|
|
|
_In_ PIO_RESOURCE_DESCRIPTOR IoDescriptor,
|
2022-01-10 03:35:45 +00:00
|
|
|
_In_ UINT64 Start,
|
2020-03-26 14:45:59 +00:00
|
|
|
_Out_ PCM_PARTIAL_RESOURCE_DESCRIPTOR CmDescriptor
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_UNPACK_RESOURCE)(
|
|
|
|
_In_ PCM_PARTIAL_RESOURCE_DESCRIPTOR CmDescriptor,
|
2022-01-10 03:35:45 +00:00
|
|
|
_Out_ PUINT64 Start,
|
|
|
|
_Out_ PUINT32 OutLength
|
2020-03-26 14:45:59 +00:00
|
|
|
);
|
|
|
|
|
2022-01-10 03:35:45 +00:00
|
|
|
typedef INT32
|
2020-03-26 14:45:59 +00:00
|
|
|
(NTAPI * PARB_SCORE_REQUIREMENT)(
|
|
|
|
_In_ PIO_RESOURCE_DESCRIPTOR IoDescriptor
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_TEST_ALLOCATION)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter,
|
|
|
|
_In_ PLIST_ENTRY ArbitrationList
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_RETEST_ALLOCATION)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter,
|
|
|
|
_In_ PLIST_ENTRY ArbitrationList
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_COMMIT_ALLOCATION)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_ROLLBACK_ALLOCATION)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_BOOT_ALLOCATION)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter,
|
|
|
|
_In_ PLIST_ENTRY ArbitrationList
|
|
|
|
);
|
|
|
|
|
|
|
|
/* Not correct yet, FIXME! */
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_QUERY_ARBITRATE)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter
|
|
|
|
);
|
|
|
|
|
|
|
|
/* Not correct yet, FIXME! */
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_QUERY_CONFLICT)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter
|
|
|
|
);
|
|
|
|
|
|
|
|
/* Not correct yet, FIXME! */
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_ADD_RESERVED)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter
|
|
|
|
);
|
|
|
|
|
|
|
|
/* Not correct yet, FIXME! */
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_START_ARBITER)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_PREPROCESS_ENTRY)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter,
|
|
|
|
_Inout_ PARBITER_ALLOCATION_STATE ArbState
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_ALLOCATE_ENTRY)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter,
|
|
|
|
_Inout_ PARBITER_ALLOCATION_STATE ArbState
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef BOOLEAN
|
|
|
|
(NTAPI * PARB_GET_NEXT_ALLOCATION_RANGE)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter,
|
|
|
|
_Inout_ PARBITER_ALLOCATION_STATE ArbState
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef BOOLEAN
|
|
|
|
(NTAPI * PARB_FIND_SUITABLE_RANGE)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter,
|
|
|
|
_Inout_ PARBITER_ALLOCATION_STATE ArbState
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef VOID
|
|
|
|
(NTAPI * PARB_ADD_ALLOCATION)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter,
|
|
|
|
_Inout_ PARBITER_ALLOCATION_STATE ArbState
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef VOID
|
|
|
|
(NTAPI * PARB_BACKTRACK_ALLOCATION)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter,
|
|
|
|
_Inout_ PARBITER_ALLOCATION_STATE ArbState
|
|
|
|
);
|
|
|
|
|
|
|
|
/* Not correct yet, FIXME! */
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_OVERRIDE_CONFLICT)(
|
|
|
|
_In_ PARBITER_INSTANCE Arbiter
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef struct _ARBITER_INSTANCE
|
|
|
|
{
|
2022-01-10 03:35:45 +00:00
|
|
|
UINT32 Signature;
|
2020-03-26 14:45:59 +00:00
|
|
|
PKEVENT MutexEvent;
|
|
|
|
PCWSTR Name;
|
|
|
|
CM_RESOURCE_TYPE ResourceType;
|
|
|
|
PRTL_RANGE_LIST Allocation;
|
|
|
|
PRTL_RANGE_LIST PossibleAllocation;
|
|
|
|
ARBITER_ORDERING_LIST OrderingList;
|
|
|
|
ARBITER_ORDERING_LIST ReservedList;
|
2022-01-10 03:35:45 +00:00
|
|
|
INT32 ReferenceCount;
|
2020-03-26 14:45:59 +00:00
|
|
|
PARBITER_INTERFACE Interface;
|
2022-01-10 03:35:45 +00:00
|
|
|
UINT32 AllocationStackMaxSize;
|
2020-03-26 14:45:59 +00:00
|
|
|
PARBITER_ALLOCATION_STATE AllocationStack;
|
|
|
|
PARB_UNPACK_REQUIREMENT UnpackRequirement;
|
|
|
|
PARB_PACK_RESOURCE PackResource;
|
|
|
|
PARB_UNPACK_RESOURCE UnpackResource;
|
|
|
|
PARB_SCORE_REQUIREMENT ScoreRequirement;
|
|
|
|
PARB_TEST_ALLOCATION TestAllocation;
|
|
|
|
PARB_RETEST_ALLOCATION RetestAllocation;
|
|
|
|
PARB_COMMIT_ALLOCATION CommitAllocation;
|
|
|
|
PARB_ROLLBACK_ALLOCATION RollbackAllocation;
|
|
|
|
PARB_BOOT_ALLOCATION BootAllocation;
|
|
|
|
PARB_QUERY_ARBITRATE QueryArbitrate; // Not used yet
|
|
|
|
PARB_QUERY_CONFLICT QueryConflict; // Not used yet
|
|
|
|
PARB_ADD_RESERVED AddReserved; // Not used yet
|
|
|
|
PARB_START_ARBITER StartArbiter; // Not used yet
|
|
|
|
PARB_PREPROCESS_ENTRY PreprocessEntry;
|
|
|
|
PARB_ALLOCATE_ENTRY AllocateEntry;
|
|
|
|
PARB_GET_NEXT_ALLOCATION_RANGE GetNextAllocationRange;
|
|
|
|
PARB_FIND_SUITABLE_RANGE FindSuitableRange;
|
|
|
|
PARB_ADD_ALLOCATION AddAllocation;
|
|
|
|
PARB_BACKTRACK_ALLOCATION BacktrackAllocation;
|
|
|
|
PARB_OVERRIDE_CONFLICT OverrideConflict; // Not used yet
|
|
|
|
BOOLEAN TransactionInProgress;
|
|
|
|
PVOID Extension;
|
|
|
|
PDEVICE_OBJECT BusDeviceObject;
|
|
|
|
PVOID ConflictCallbackContext;
|
|
|
|
PVOID ConflictCallback;
|
|
|
|
} ARBITER_INSTANCE, *PARBITER_INSTANCE;
|
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(NTAPI * PARB_TRANSLATE_ORDERING)(
|
|
|
|
_Out_ PIO_RESOURCE_DESCRIPTOR OutIoDescriptor,
|
|
|
|
_In_ PIO_RESOURCE_DESCRIPTOR IoDescriptor
|
|
|
|
);
|
|
|
|
|
2022-01-10 03:35:45 +00:00
|
|
|
CODE_SEG("PAGE")
|
2020-03-26 14:45:59 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
ArbInitializeArbiterInstance(
|
|
|
|
_Inout_ PARBITER_INSTANCE Arbiter,
|
|
|
|
_In_ PDEVICE_OBJECT BusDeviceObject,
|
|
|
|
_In_ CM_RESOURCE_TYPE ResourceType,
|
|
|
|
_In_ PCWSTR ArbiterName,
|
|
|
|
_In_ PCWSTR OrderName,
|
|
|
|
_In_ PARB_TRANSLATE_ORDERING TranslateOrderingFunction
|
|
|
|
);
|