2021-03-04 12:42:42 +00:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS ISA PnP Bus driver
|
|
|
|
* LICENSE: GPL-2.0-or-later (https://spdx.org/licenses/GPL-2.0-or-later)
|
|
|
|
* PURPOSE: Common header file
|
|
|
|
* COPYRIGHT: Copyright 2010 Cameron Gutman <cameron.gutman@reactos.org>
|
|
|
|
* Copyright 2020 Hervé Poussineau <hpoussin@reactos.org>
|
|
|
|
*/
|
|
|
|
|
2014-02-06 11:18:34 +00:00
|
|
|
#ifndef _ISAPNP_PCH_
|
|
|
|
#define _ISAPNP_PCH_
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2010-04-07 20:19:29 +00:00
|
|
|
#include <wdm.h>
|
2020-02-10 20:31:28 +00:00
|
|
|
#include <ntstrsafe.h>
|
2021-03-04 12:43:44 +00:00
|
|
|
#include <section_attribs.h>
|
2021-03-04 12:42:42 +00:00
|
|
|
#include "isapnphw.h"
|
2007-07-06 20:25:30 +00:00
|
|
|
|
2001-05-01 23:00:05 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2021-03-04 12:43:19 +00:00
|
|
|
#define TAG_ISAPNP 'pasI'
|
2007-07-06 20:25:30 +00:00
|
|
|
|
2021-03-04 12:42:42 +00:00
|
|
|
typedef enum
|
|
|
|
{
|
2020-03-20 18:19:30 +00:00
|
|
|
dsStopped,
|
|
|
|
dsStarted
|
2010-04-07 20:19:29 +00:00
|
|
|
} ISAPNP_DEVICE_STATE;
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2021-03-04 12:42:42 +00:00
|
|
|
typedef struct _ISAPNP_IO
|
|
|
|
{
|
2020-03-21 22:08:00 +00:00
|
|
|
USHORT CurrentBase;
|
|
|
|
ISAPNP_IO_DESCRIPTION Description;
|
2021-03-04 12:42:42 +00:00
|
|
|
} ISAPNP_IO, *PISAPNP_IO;
|
2020-03-21 22:08:00 +00:00
|
|
|
|
2021-03-04 12:42:42 +00:00
|
|
|
typedef struct _ISAPNP_IRQ
|
|
|
|
{
|
2020-03-21 22:08:00 +00:00
|
|
|
UCHAR CurrentNo;
|
|
|
|
UCHAR CurrentType;
|
|
|
|
ISAPNP_IRQ_DESCRIPTION Description;
|
|
|
|
} ISAPNP_IRQ, *PISAPNP_IRQ;
|
|
|
|
|
2021-03-04 12:42:42 +00:00
|
|
|
typedef struct _ISAPNP_DMA
|
|
|
|
{
|
2020-03-22 22:23:04 +00:00
|
|
|
UCHAR CurrentChannel;
|
|
|
|
ISAPNP_DMA_DESCRIPTION Description;
|
|
|
|
} ISAPNP_DMA, *PISAPNP_DMA;
|
|
|
|
|
2021-03-04 12:42:42 +00:00
|
|
|
typedef struct _ISAPNP_LOGICAL_DEVICE
|
|
|
|
{
|
2020-03-20 18:19:30 +00:00
|
|
|
PDEVICE_OBJECT Pdo;
|
2020-03-21 22:08:00 +00:00
|
|
|
ISAPNP_LOGDEVID LogDevId;
|
2020-03-20 18:19:30 +00:00
|
|
|
UCHAR VendorId[3];
|
|
|
|
USHORT ProdId;
|
|
|
|
ULONG SerialNumber;
|
2020-03-21 22:08:00 +00:00
|
|
|
ISAPNP_IO Io[8];
|
|
|
|
ISAPNP_IRQ Irq[2];
|
2020-03-22 22:23:04 +00:00
|
|
|
ISAPNP_DMA Dma[2];
|
2020-03-20 18:19:30 +00:00
|
|
|
UCHAR CSN;
|
|
|
|
UCHAR LDN;
|
2021-03-04 12:42:42 +00:00
|
|
|
LIST_ENTRY DeviceLink;
|
2020-03-12 10:53:09 +00:00
|
|
|
} ISAPNP_LOGICAL_DEVICE, *PISAPNP_LOGICAL_DEVICE;
|
|
|
|
|
2021-03-04 12:42:42 +00:00
|
|
|
typedef struct _ISAPNP_COMMON_EXTENSION
|
|
|
|
{
|
2020-03-20 18:19:30 +00:00
|
|
|
PDEVICE_OBJECT Self;
|
|
|
|
BOOLEAN IsFdo;
|
|
|
|
ISAPNP_DEVICE_STATE State;
|
2010-04-07 20:19:29 +00:00
|
|
|
} ISAPNP_COMMON_EXTENSION, *PISAPNP_COMMON_EXTENSION;
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2021-03-04 12:42:42 +00:00
|
|
|
typedef struct _ISAPNP_FDO_EXTENSION
|
|
|
|
{
|
2020-03-20 18:19:30 +00:00
|
|
|
ISAPNP_COMMON_EXTENSION Common;
|
|
|
|
PDEVICE_OBJECT Ldo;
|
|
|
|
PDEVICE_OBJECT Pdo;
|
2021-03-04 12:42:42 +00:00
|
|
|
PDEVICE_OBJECT ReadPortPdo;
|
2021-03-04 12:43:44 +00:00
|
|
|
KEVENT DeviceSyncEvent;
|
2020-03-20 18:19:30 +00:00
|
|
|
LIST_ENTRY DeviceListHead;
|
|
|
|
ULONG DeviceCount;
|
|
|
|
PDRIVER_OBJECT DriverObject;
|
|
|
|
PUCHAR ReadDataPort;
|
2010-04-07 20:19:29 +00:00
|
|
|
} ISAPNP_FDO_EXTENSION, *PISAPNP_FDO_EXTENSION;
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2021-03-04 12:42:42 +00:00
|
|
|
typedef struct _ISAPNP_PDO_EXTENSION
|
|
|
|
{
|
2020-03-20 18:19:30 +00:00
|
|
|
ISAPNP_COMMON_EXTENSION Common;
|
|
|
|
PISAPNP_LOGICAL_DEVICE IsaPnpDevice;
|
2020-03-16 18:43:37 +00:00
|
|
|
PISAPNP_FDO_EXTENSION FdoExt;
|
2020-03-21 15:58:21 +00:00
|
|
|
PIO_RESOURCE_REQUIREMENTS_LIST RequirementsList;
|
2020-03-21 16:37:45 +00:00
|
|
|
PCM_RESOURCE_LIST ResourceList;
|
|
|
|
ULONG ResourceListSize;
|
2020-03-12 10:53:09 +00:00
|
|
|
} ISAPNP_PDO_EXTENSION, *PISAPNP_PDO_EXTENSION;
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2021-03-04 12:43:44 +00:00
|
|
|
_Requires_lock_not_held_(FdoExt->DeviceSyncEvent)
|
|
|
|
_Acquires_lock_(FdoExt->DeviceSyncEvent)
|
|
|
|
FORCEINLINE
|
|
|
|
VOID
|
|
|
|
IsaPnpAcquireDeviceDataLock(
|
|
|
|
_In_ PISAPNP_FDO_EXTENSION FdoExt)
|
|
|
|
{
|
|
|
|
KeWaitForSingleObject(&FdoExt->DeviceSyncEvent, Executive, KernelMode, FALSE, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
_Releases_lock_(FdoExt->DeviceSyncEvent)
|
|
|
|
FORCEINLINE
|
|
|
|
VOID
|
|
|
|
IsaPnpReleaseDeviceDataLock(
|
|
|
|
_In_ PISAPNP_FDO_EXTENSION FdoExt)
|
|
|
|
{
|
|
|
|
KeSetEvent(&FdoExt->DeviceSyncEvent, IO_NO_INCREMENT, FALSE);
|
|
|
|
}
|
|
|
|
|
2010-04-07 20:19:29 +00:00
|
|
|
/* isapnp.c */
|
2013-05-09 14:06:21 +00:00
|
|
|
|
2021-03-04 12:43:44 +00:00
|
|
|
CODE_SEG("PAGE")
|
2020-03-16 17:07:24 +00:00
|
|
|
NTSTATUS
|
|
|
|
IsaPnpFillDeviceRelations(
|
2021-03-04 12:42:42 +00:00
|
|
|
_In_ PISAPNP_FDO_EXTENSION FdoExt,
|
|
|
|
_Inout_ PIRP Irp,
|
|
|
|
_In_ BOOLEAN IncludeDataPort);
|
2020-03-16 17:07:24 +00:00
|
|
|
|
2021-03-04 12:43:44 +00:00
|
|
|
CODE_SEG("INIT")
|
2013-05-09 14:06:21 +00:00
|
|
|
DRIVER_INITIALIZE DriverEntry;
|
|
|
|
|
2010-04-07 20:19:29 +00:00
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
IsaForwardIrpSynchronous(
|
2021-03-04 12:42:42 +00:00
|
|
|
_In_ PISAPNP_FDO_EXTENSION FdoExt,
|
|
|
|
_Inout_ PIRP Irp);
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2010-04-07 20:19:29 +00:00
|
|
|
/* fdo.c */
|
2021-03-04 12:43:44 +00:00
|
|
|
CODE_SEG("PAGE")
|
2010-04-07 20:19:29 +00:00
|
|
|
NTSTATUS
|
|
|
|
IsaFdoPnp(
|
2021-03-04 12:42:42 +00:00
|
|
|
_In_ PISAPNP_FDO_EXTENSION FdoExt,
|
|
|
|
_Inout_ PIRP Irp,
|
|
|
|
_In_ PIO_STACK_LOCATION IrpSp);
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2010-04-07 20:19:29 +00:00
|
|
|
/* pdo.c */
|
2021-03-04 12:43:44 +00:00
|
|
|
CODE_SEG("PAGE")
|
2010-04-07 20:19:29 +00:00
|
|
|
NTSTATUS
|
|
|
|
IsaPdoPnp(
|
2021-03-04 12:42:42 +00:00
|
|
|
_In_ PISAPNP_PDO_EXTENSION PdoDeviceExtension,
|
|
|
|
_Inout_ PIRP Irp,
|
|
|
|
_In_ PIO_STACK_LOCATION IrpSp);
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2010-04-07 20:19:29 +00:00
|
|
|
/* hardware.c */
|
2021-03-04 12:43:44 +00:00
|
|
|
CODE_SEG("PAGE")
|
2010-04-07 20:19:29 +00:00
|
|
|
NTSTATUS
|
2020-03-16 19:58:53 +00:00
|
|
|
IsaHwTryReadDataPort(
|
2021-03-04 12:42:42 +00:00
|
|
|
_In_ PUCHAR ReadDataPort);
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2021-03-04 12:43:44 +00:00
|
|
|
CODE_SEG("PAGE")
|
2010-04-07 20:19:29 +00:00
|
|
|
NTSTATUS
|
|
|
|
IsaHwFillDeviceList(
|
2021-03-04 12:42:42 +00:00
|
|
|
_In_ PISAPNP_FDO_EXTENSION FdoExt);
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2021-03-04 12:43:44 +00:00
|
|
|
_IRQL_requires_max_(DISPATCH_LEVEL)
|
2010-04-07 20:19:29 +00:00
|
|
|
NTSTATUS
|
|
|
|
IsaHwDeactivateDevice(
|
2021-03-04 12:42:42 +00:00
|
|
|
_In_ PISAPNP_LOGICAL_DEVICE LogicalDevice);
|
2001-05-01 23:00:05 +00:00
|
|
|
|
2021-03-04 12:43:44 +00:00
|
|
|
_IRQL_requires_max_(DISPATCH_LEVEL)
|
2005-10-06 21:39:18 +00:00
|
|
|
NTSTATUS
|
2010-04-07 20:19:29 +00:00
|
|
|
IsaHwActivateDevice(
|
2021-03-04 12:42:42 +00:00
|
|
|
_In_ PISAPNP_LOGICAL_DEVICE LogicalDevice);
|
2005-10-06 21:39:18 +00:00
|
|
|
|
2001-05-01 23:00:05 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2014-02-06 11:18:34 +00:00
|
|
|
|
|
|
|
#endif /* _ISAPNP_PCH_ */
|