2012-01-02 21:38:57 +00:00
|
|
|
/*
|
|
|
|
* COPYRIGHT: See COPYING in the top level directory
|
|
|
|
* PROJECT: ReactOS NDIS User I/O driver
|
|
|
|
* FILE: ndisuio.h
|
|
|
|
* PURPOSE: NDISUIO definitions
|
|
|
|
*/
|
2014-02-06 17:19:30 +00:00
|
|
|
|
2012-01-02 21:38:57 +00:00
|
|
|
#ifndef __NDISUIO_H
|
|
|
|
#define __NDISUIO_H
|
|
|
|
|
|
|
|
#include <ndis.h>
|
2012-01-06 05:59:56 +00:00
|
|
|
#include <nuiouser.h>
|
2012-01-02 21:38:57 +00:00
|
|
|
|
2012-01-06 05:59:56 +00:00
|
|
|
extern PDEVICE_OBJECT GlobalDeviceObject;
|
|
|
|
extern NDIS_HANDLE GlobalProtocolHandle;
|
|
|
|
extern LIST_ENTRY GlobalAdapterList;
|
|
|
|
extern KSPIN_LOCK GlobalAdapterListLock;
|
|
|
|
|
|
|
|
typedef struct _NDISUIO_ADAPTER_CONTEXT
|
2012-01-02 21:38:57 +00:00
|
|
|
{
|
|
|
|
/* Asynchronous completion */
|
|
|
|
NDIS_STATUS AsyncStatus;
|
|
|
|
KEVENT AsyncEvent;
|
|
|
|
|
|
|
|
/* NDIS binding information */
|
|
|
|
NDIS_HANDLE BindingHandle;
|
2021-06-11 12:29:21 +00:00
|
|
|
|
2012-01-02 21:38:57 +00:00
|
|
|
/* Reference count information */
|
|
|
|
ULONG OpenCount;
|
|
|
|
LIST_ENTRY OpenEntryList;
|
2021-06-11 12:29:21 +00:00
|
|
|
|
2012-01-06 19:43:15 +00:00
|
|
|
/* NDIS pools */
|
|
|
|
NDIS_HANDLE PacketPoolHandle;
|
|
|
|
NDIS_HANDLE BufferPoolHandle;
|
2012-01-02 21:38:57 +00:00
|
|
|
|
|
|
|
/* Receive packet list */
|
|
|
|
LIST_ENTRY PacketList;
|
2012-01-03 17:54:01 +00:00
|
|
|
KEVENT PacketReadEvent;
|
2021-06-11 12:29:21 +00:00
|
|
|
|
2012-01-10 01:52:18 +00:00
|
|
|
/* Mac options */
|
|
|
|
ULONG MacOptions;
|
2012-01-02 21:38:57 +00:00
|
|
|
|
2012-01-06 05:59:56 +00:00
|
|
|
/* Device name */
|
|
|
|
UNICODE_STRING DeviceName;
|
|
|
|
|
2012-01-02 21:38:57 +00:00
|
|
|
/* Global list entry */
|
|
|
|
LIST_ENTRY ListEntry;
|
|
|
|
|
|
|
|
/* Spin lock */
|
|
|
|
KSPIN_LOCK Spinlock;
|
|
|
|
} NDISUIO_ADAPTER_CONTEXT, *PNDISUIO_ADAPTER_CONTEXT;
|
|
|
|
|
2012-01-06 05:59:56 +00:00
|
|
|
typedef struct _NDISUIO_OPEN_ENTRY
|
2012-01-02 21:38:57 +00:00
|
|
|
{
|
|
|
|
/* File object */
|
|
|
|
PFILE_OBJECT FileObject;
|
2021-06-11 12:29:21 +00:00
|
|
|
|
2012-01-03 18:12:29 +00:00
|
|
|
/* Tracks how this adapter was opened (write-only or read-write) */
|
|
|
|
BOOLEAN WriteOnly;
|
2021-06-11 12:29:21 +00:00
|
|
|
|
2012-01-02 21:38:57 +00:00
|
|
|
/* List entry */
|
|
|
|
LIST_ENTRY ListEntry;
|
|
|
|
} NDISUIO_OPEN_ENTRY, *PNDISUIO_OPEN_ENTRY;
|
|
|
|
|
2012-01-06 05:59:56 +00:00
|
|
|
typedef struct _NDISUIO_PACKET_ENTRY
|
2012-01-03 18:12:29 +00:00
|
|
|
{
|
|
|
|
/* Length of data at the end of the struct */
|
|
|
|
ULONG PacketLength;
|
2021-06-11 12:29:21 +00:00
|
|
|
|
2012-01-03 18:12:29 +00:00
|
|
|
/* Entry on the packet list */
|
|
|
|
LIST_ENTRY ListEntry;
|
|
|
|
|
|
|
|
/* Packet data */
|
|
|
|
UCHAR PacketData[1];
|
|
|
|
} NDISUIO_PACKET_ENTRY, *PNDISUIO_PACKET_ENTRY;
|
|
|
|
|
2012-01-02 21:38:57 +00:00
|
|
|
/* NDIS version info */
|
2012-01-06 05:59:56 +00:00
|
|
|
#define NDIS_MAJOR_VERSION 5
|
2012-01-02 21:38:57 +00:00
|
|
|
#define NDIS_MINOR_VERSION 0
|
|
|
|
|
2012-01-06 05:59:56 +00:00
|
|
|
/* createclose.c */
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NduDispatchCreate(PDEVICE_OBJECT DeviceObject,
|
|
|
|
PIRP Irp);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NduDispatchClose(PDEVICE_OBJECT DeviceObject,
|
|
|
|
PIRP Irp);
|
|
|
|
|
|
|
|
/* ioctl.c */
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NduDispatchDeviceControl(PDEVICE_OBJECT DeviceObject,
|
|
|
|
PIRP Irp);
|
|
|
|
|
|
|
|
/* misc.c */
|
|
|
|
NDIS_STATUS
|
2012-01-06 19:43:15 +00:00
|
|
|
AllocateAndChainBuffer(PNDISUIO_ADAPTER_CONTEXT AdapterContext,
|
|
|
|
PNDIS_PACKET Packet,
|
2012-01-06 05:59:56 +00:00
|
|
|
PVOID Buffer,
|
|
|
|
ULONG BufferSize,
|
|
|
|
BOOLEAN Front);
|
|
|
|
|
|
|
|
PNDIS_PACKET
|
2012-01-06 19:43:15 +00:00
|
|
|
CreatePacketFromPoolBuffer(PNDISUIO_ADAPTER_CONTEXT AdapterContext,
|
|
|
|
PVOID Buffer,
|
2012-01-06 05:59:56 +00:00
|
|
|
ULONG BufferSize);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
CleanupAndFreePacket(PNDIS_PACKET Packet,
|
|
|
|
BOOLEAN FreePool);
|
|
|
|
|
|
|
|
PNDISUIO_ADAPTER_CONTEXT
|
|
|
|
FindAdapterContextByName(PNDIS_STRING DeviceName);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
ReferenceAdapterContext(PNDISUIO_ADAPTER_CONTEXT AdapterContext);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
DereferenceAdapterContextWithOpenEntry(PNDISUIO_ADAPTER_CONTEXT AdapterContext,
|
|
|
|
PNDISUIO_OPEN_ENTRY OpenEntry);
|
|
|
|
|
|
|
|
/* protocol.c */
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduOpenAdapterComplete(NDIS_HANDLE ProtocolBindingContext,
|
|
|
|
NDIS_STATUS Status,
|
|
|
|
NDIS_STATUS OpenStatus);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduCloseAdapterComplete(NDIS_HANDLE ProtocolBindingContext,
|
|
|
|
NDIS_STATUS Status);
|
|
|
|
|
2014-08-22 19:13:31 +00:00
|
|
|
NDIS_STATUS
|
|
|
|
NTAPI
|
|
|
|
NduNetPnPEvent(NDIS_HANDLE ProtocolBindingContext,
|
|
|
|
PNET_PNP_EVENT NetPnPEvent);
|
|
|
|
|
2012-01-06 05:59:56 +00:00
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduSendComplete(NDIS_HANDLE ProtocolBindingContext,
|
|
|
|
PNDIS_PACKET Packet,
|
|
|
|
NDIS_STATUS Status);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduTransferDataComplete(NDIS_HANDLE ProtocolBindingContext,
|
|
|
|
PNDIS_PACKET Packet,
|
|
|
|
NDIS_STATUS Status,
|
|
|
|
UINT BytesTransferred);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduResetComplete(NDIS_HANDLE ProtocolBindingContext,
|
|
|
|
NDIS_STATUS Status);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduRequestComplete(NDIS_HANDLE ProtocolBindingContext,
|
|
|
|
PNDIS_REQUEST NdisRequest,
|
|
|
|
NDIS_STATUS Status);
|
|
|
|
|
|
|
|
NDIS_STATUS
|
|
|
|
NTAPI
|
|
|
|
NduReceive(NDIS_HANDLE ProtocolBindingContext,
|
|
|
|
NDIS_HANDLE MacReceiveContext,
|
|
|
|
PVOID HeaderBuffer,
|
|
|
|
UINT HeaderBufferSize,
|
|
|
|
PVOID LookAheadBuffer,
|
|
|
|
UINT LookaheadBufferSize,
|
|
|
|
UINT PacketSize);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduReceiveComplete(NDIS_HANDLE ProtocolBindingContext);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduStatus(NDIS_HANDLE ProtocolBindingContext,
|
|
|
|
NDIS_STATUS GeneralStatus,
|
|
|
|
PVOID StatusBuffer,
|
|
|
|
UINT StatusBufferSize);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduStatusComplete(NDIS_HANDLE ProtocolBindingContext);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduBindAdapter(PNDIS_STATUS Status,
|
|
|
|
NDIS_HANDLE BindContext,
|
|
|
|
PNDIS_STRING DeviceName,
|
|
|
|
PVOID SystemSpecific1,
|
|
|
|
PVOID SystemSpecific2);
|
|
|
|
|
|
|
|
VOID
|
|
|
|
NTAPI
|
|
|
|
NduUnbindAdapter(PNDIS_STATUS Status,
|
|
|
|
NDIS_HANDLE ProtocolBindingContext,
|
|
|
|
NDIS_HANDLE UnbindContext);
|
|
|
|
|
|
|
|
/* readwrite.c */
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NduDispatchRead(PDEVICE_OBJECT DeviceObject,
|
|
|
|
PIRP Irp);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
NTAPI
|
|
|
|
NduDispatchWrite(PDEVICE_OBJECT DeviceObject,
|
|
|
|
PIRP Irp);
|
2014-02-06 17:19:30 +00:00
|
|
|
|
2012-01-02 21:38:57 +00:00
|
|
|
#endif /* __NDISUIO_H */
|