mirror of
https://github.com/reactos/reactos.git
synced 2025-04-05 05:01:03 +00:00
Merge 871eb35068
into c5325f5016
This commit is contained in:
commit
1b491dce64
16 changed files with 1684 additions and 147 deletions
|
@ -3,5 +3,6 @@ add_subdirectory(afd)
|
||||||
add_subdirectory(dd)
|
add_subdirectory(dd)
|
||||||
add_subdirectory(ndis)
|
add_subdirectory(ndis)
|
||||||
add_subdirectory(ndisuio)
|
add_subdirectory(ndisuio)
|
||||||
|
add_subdirectory(netio)
|
||||||
add_subdirectory(tcpip)
|
add_subdirectory(tcpip)
|
||||||
add_subdirectory(tdi)
|
add_subdirectory(tdi)
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
|
|
||||||
include_directories(
|
include_directories(
|
||||||
BEFORE include
|
BEFORE include
|
||||||
|
../tdihelpers/include
|
||||||
${REACTOS_SOURCE_DIR}/sdk/include/reactos/drivers)
|
${REACTOS_SOURCE_DIR}/sdk/include/reactos/drivers)
|
||||||
|
|
||||||
list(APPEND SOURCE
|
list(APPEND SOURCE
|
||||||
|
@ -13,8 +14,8 @@ list(APPEND SOURCE
|
||||||
afd/main.c
|
afd/main.c
|
||||||
afd/read.c
|
afd/read.c
|
||||||
afd/select.c
|
afd/select.c
|
||||||
afd/tdi.c
|
../tdihelpers/tdi.c
|
||||||
afd/tdiconn.c
|
../tdihelpers/tdiconn.c
|
||||||
afd/write.c
|
afd/write.c
|
||||||
include/afd.h)
|
include/afd.h)
|
||||||
|
|
||||||
|
|
|
@ -337,71 +337,6 @@ VOID SignalSocket(
|
||||||
PAFD_ACTIVE_POLL Poll OPTIONAL, PIRP _Irp OPTIONAL,
|
PAFD_ACTIVE_POLL Poll OPTIONAL, PIRP _Irp OPTIONAL,
|
||||||
PAFD_POLL_INFO PollReq, NTSTATUS Status);
|
PAFD_POLL_INFO PollReq, NTSTATUS Status);
|
||||||
|
|
||||||
/* tdi.c */
|
|
||||||
|
|
||||||
NTSTATUS TdiOpenAddressFile(
|
|
||||||
PUNICODE_STRING DeviceName,
|
|
||||||
PTRANSPORT_ADDRESS Name,
|
|
||||||
ULONG ShareType,
|
|
||||||
PHANDLE AddressHandle,
|
|
||||||
PFILE_OBJECT *AddressObject);
|
|
||||||
|
|
||||||
NTSTATUS TdiAssociateAddressFile(
|
|
||||||
HANDLE AddressHandle,
|
|
||||||
PFILE_OBJECT ConnectionObject);
|
|
||||||
|
|
||||||
NTSTATUS TdiDisassociateAddressFile(
|
|
||||||
PFILE_OBJECT ConnectionObject);
|
|
||||||
|
|
||||||
NTSTATUS TdiListen
|
|
||||||
( PIRP *Irp,
|
|
||||||
PFILE_OBJECT ConnectionObject,
|
|
||||||
PTDI_CONNECTION_INFORMATION *RequestConnectionInfo,
|
|
||||||
PTDI_CONNECTION_INFORMATION *ReturnConnectionInfo,
|
|
||||||
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
|
||||||
PVOID CompletionContext);
|
|
||||||
|
|
||||||
NTSTATUS TdiReceive
|
|
||||||
( PIRP *Irp,
|
|
||||||
PFILE_OBJECT ConnectionObject,
|
|
||||||
USHORT Flags,
|
|
||||||
PCHAR Buffer,
|
|
||||||
UINT BufferLength,
|
|
||||||
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
|
||||||
PVOID CompletionContext);
|
|
||||||
|
|
||||||
NTSTATUS TdiSend
|
|
||||||
( PIRP *Irp,
|
|
||||||
PFILE_OBJECT ConnectionObject,
|
|
||||||
USHORT Flags,
|
|
||||||
PCHAR Buffer,
|
|
||||||
UINT BufferLength,
|
|
||||||
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
|
||||||
PVOID CompletionContext);
|
|
||||||
|
|
||||||
NTSTATUS TdiReceiveDatagram(
|
|
||||||
PIRP *Irp,
|
|
||||||
PFILE_OBJECT TransportObject,
|
|
||||||
USHORT Flags,
|
|
||||||
PCHAR Buffer,
|
|
||||||
UINT BufferLength,
|
|
||||||
PTDI_CONNECTION_INFORMATION From,
|
|
||||||
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
|
||||||
PVOID CompletionContext);
|
|
||||||
|
|
||||||
NTSTATUS TdiSendDatagram(
|
|
||||||
PIRP *Irp,
|
|
||||||
PFILE_OBJECT TransportObject,
|
|
||||||
PCHAR Buffer,
|
|
||||||
UINT BufferLength,
|
|
||||||
PTDI_CONNECTION_INFORMATION To,
|
|
||||||
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
|
||||||
PVOID CompletionContext);
|
|
||||||
|
|
||||||
NTSTATUS TdiQueryMaxDatagramLength(
|
|
||||||
PFILE_OBJECT FileObject,
|
|
||||||
PUINT MaxDatagramLength);
|
|
||||||
|
|
||||||
/* write.c */
|
/* write.c */
|
||||||
|
|
||||||
NTSTATUS NTAPI
|
NTSTATUS NTAPI
|
||||||
|
|
|
@ -1,45 +0,0 @@
|
||||||
#pragma once
|
|
||||||
|
|
||||||
NTSTATUS TdiConnect( PIRP *PendingIrp,
|
|
||||||
PFILE_OBJECT ConnectionObject,
|
|
||||||
PTDI_CONNECTION_INFORMATION ConnectionCallInfo,
|
|
||||||
PTDI_CONNECTION_INFORMATION ConnectionReturnInfo,
|
|
||||||
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
|
||||||
PVOID CompletionContext );
|
|
||||||
|
|
||||||
NTSTATUS TdiOpenConnectionEndpointFile(PUNICODE_STRING DeviceName,
|
|
||||||
PHANDLE ConnectionHandle,
|
|
||||||
PFILE_OBJECT *ConnectionObject);
|
|
||||||
|
|
||||||
NTSTATUS TdiCloseDevice(HANDLE Handle,
|
|
||||||
PFILE_OBJECT FileObject);
|
|
||||||
|
|
||||||
NTSTATUS TdiDisconnect
|
|
||||||
( PIRP *Irp,
|
|
||||||
PFILE_OBJECT TransportObject,
|
|
||||||
PLARGE_INTEGER Time,
|
|
||||||
USHORT Flags,
|
|
||||||
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
|
||||||
PVOID CompletionContext,
|
|
||||||
PTDI_CONNECTION_INFORMATION RequestConnectionInfo,
|
|
||||||
PTDI_CONNECTION_INFORMATION ReturnConnectionInfo );
|
|
||||||
|
|
||||||
NTSTATUS TdiQueryInformation(
|
|
||||||
PFILE_OBJECT FileObject,
|
|
||||||
LONG QueryType,
|
|
||||||
PMDL MdlBuffer);
|
|
||||||
|
|
||||||
NTSTATUS TdiSetEventHandler(
|
|
||||||
PFILE_OBJECT FileObject,
|
|
||||||
LONG EventType,
|
|
||||||
PVOID Handler,
|
|
||||||
PVOID Context);
|
|
||||||
|
|
||||||
NTSTATUS TdiQueryDeviceControl(
|
|
||||||
PFILE_OBJECT FileObject,
|
|
||||||
ULONG IoControlCode,
|
|
||||||
PVOID InputBuffer,
|
|
||||||
ULONG InputBufferLength,
|
|
||||||
PVOID OutputBuffer,
|
|
||||||
ULONG OutputBufferLength,
|
|
||||||
PULONG Return);
|
|
|
@ -1,20 +0,0 @@
|
||||||
#pragma once
|
|
||||||
|
|
||||||
typedef VOID *PTDI_CONNECTION_INFO_PAIR;
|
|
||||||
|
|
||||||
PTRANSPORT_ADDRESS TaCopyTransportAddress( PTRANSPORT_ADDRESS OtherAddress );
|
|
||||||
PTRANSPORT_ADDRESS TaBuildNullTransportAddress(UINT AddressType);
|
|
||||||
UINT TaLengthOfAddress( PTA_ADDRESS Addr );
|
|
||||||
UINT TaLengthOfTransportAddress( PTRANSPORT_ADDRESS Addr );
|
|
||||||
VOID TaCopyTransportAddressInPlace( PTRANSPORT_ADDRESS Target,
|
|
||||||
PTRANSPORT_ADDRESS Source );
|
|
||||||
UINT TdiAddressSizeFromType( UINT Type );
|
|
||||||
UINT TdiAddressSizeFromName( PTRANSPORT_ADDRESS Name );
|
|
||||||
NTSTATUS TdiBuildConnectionInfoInPlace
|
|
||||||
( PTDI_CONNECTION_INFORMATION ConnInfo, PTRANSPORT_ADDRESS Name );
|
|
||||||
NTSTATUS TdiBuildConnectionInfo
|
|
||||||
( PTDI_CONNECTION_INFORMATION *ConnectionInfo, PTRANSPORT_ADDRESS Name );
|
|
||||||
NTSTATUS TdiBuildNullConnectionInfoInPlace
|
|
||||||
( PTDI_CONNECTION_INFORMATION ConnInfo, ULONG Type );
|
|
||||||
NTSTATUS TdiBuildNullConnectionInfo
|
|
||||||
( PTDI_CONNECTION_INFORMATION *ConnectionInfo, ULONG Type );
|
|
24
drivers/network/netio/CMakeLists.txt
Normal file
24
drivers/network/netio/CMakeLists.txt
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
|
||||||
|
spec2def(netio.sys netio.spec ADD_IMPORTLIB)
|
||||||
|
|
||||||
|
# TODO: dependency on afd.h should go away ...
|
||||||
|
|
||||||
|
include_directories(
|
||||||
|
BEFORE include
|
||||||
|
../afd/include
|
||||||
|
../tdihelpers/include
|
||||||
|
${REACTOS_SOURCE_DIR}/sdk/include/reactos/drivers)
|
||||||
|
|
||||||
|
list(APPEND SOURCE
|
||||||
|
netio.c
|
||||||
|
../tdihelpers/tdi.c
|
||||||
|
../tdihelpers/tdiconn.c
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/netio.def
|
||||||
|
)
|
||||||
|
|
||||||
|
add_library(netio MODULE ${SOURCE})
|
||||||
|
target_link_libraries(netio ${PSEH_LIB})
|
||||||
|
set_module_type(netio kernelmodedriver)
|
||||||
|
add_importlibs(netio ntoskrnl hal)
|
||||||
|
add_cd_file(TARGET netio DESTINATION reactos/system32/drivers FOR all)
|
||||||
|
add_registry_inf(netio_reg.inf)
|
95
drivers/network/netio/include/netio_debug.h
Normal file
95
drivers/network/netio/include/netio_debug.h
Normal file
|
@ -0,0 +1,95 @@
|
||||||
|
/*
|
||||||
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
|
* PROJECT: ReactOS Ancillary Function Driver
|
||||||
|
* FILE: include/netio_debug.h
|
||||||
|
* PURPOSE: Debugging support macros
|
||||||
|
* DEFINES: DBG - Enable debug output
|
||||||
|
* NASSERT - Disable assertions
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Question to reviewers: does mingw support this #pragma? */
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#define NORMAL_MASK 0x000000FF
|
||||||
|
#define SPECIAL_MASK 0xFFFFFF00
|
||||||
|
#define MIN_TRACE 0x00000001
|
||||||
|
#define MID_TRACE 0x00000002
|
||||||
|
#define MAX_TRACE 0x00000003
|
||||||
|
|
||||||
|
#define DEBUG_CHECK 0x00000100
|
||||||
|
#define DEBUG_IRP 0x00000200
|
||||||
|
#define DEBUG_ULTRA 0xFFFFFFFF
|
||||||
|
|
||||||
|
#if DBG
|
||||||
|
|
||||||
|
extern ULONG DebugTraceLevel;
|
||||||
|
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
|
||||||
|
#define NETIO_DbgPrint(_t_, _x_) \
|
||||||
|
if ((_t_ > NORMAL_MASK) \
|
||||||
|
? (DebugTraceLevel & _t_) > NORMAL_MASK \
|
||||||
|
: (DebugTraceLevel & NORMAL_MASK) >= _t_) { \
|
||||||
|
DbgPrint("(%s:%d) ", __FILE__, __LINE__); \
|
||||||
|
DbgPrint _x_ ; \
|
||||||
|
}
|
||||||
|
|
||||||
|
#else /* _MSC_VER */
|
||||||
|
|
||||||
|
#define NETIO_DbgPrint(_t_, _x_) \
|
||||||
|
if ((_t_ > NORMAL_MASK) \
|
||||||
|
? (DebugTraceLevel & _t_) > NORMAL_MASK \
|
||||||
|
: (DebugTraceLevel & NORMAL_MASK) >= _t_) { \
|
||||||
|
DbgPrint("(%s:%d)(%s) ", __FILE__, __LINE__, __FUNCTION__); \
|
||||||
|
DbgPrint _x_; \
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* _MSC_VER */
|
||||||
|
|
||||||
|
#ifdef ASSERT
|
||||||
|
#undef ASSERT
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef NASSERT
|
||||||
|
#define ASSERT(x)
|
||||||
|
#else /* NASSERT */
|
||||||
|
#define ASSERT(x) if (!(x)) { NETIO_DbgPrint(MIN_TRACE, ("Assertion "#x" failed at %s:%d\n", __FILE__, __LINE__)); DbgBreakPoint(); }
|
||||||
|
#endif /* NASSERT */
|
||||||
|
|
||||||
|
#else /* DBG */
|
||||||
|
|
||||||
|
#define NETIO_DbgPrint(_t_, _x_)
|
||||||
|
|
||||||
|
#define ASSERTKM(x)
|
||||||
|
#ifndef ASSERT
|
||||||
|
#define ASSERT(x)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* DBG */
|
||||||
|
|
||||||
|
|
||||||
|
#undef assert
|
||||||
|
#define assert(x) ASSERT(x)
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
|
||||||
|
#define UNIMPLEMENTED \
|
||||||
|
NETIO_DbgPrint(MIN_TRACE, ("The function at %s:%d is unimplemented, \
|
||||||
|
but come back another day.\n", __FILE__, __LINE__));
|
||||||
|
|
||||||
|
#else /* _MSC_VER */
|
||||||
|
|
||||||
|
#define UNIMPLEMENTED \
|
||||||
|
NETIO_DbgPrint(MIN_TRACE, ("%s at %s:%d is unimplemented, " \
|
||||||
|
"but come back another day.\n", __FUNCTION__, __FILE__, __LINE__));
|
||||||
|
|
||||||
|
#endif /* _MSC_VER */
|
||||||
|
|
||||||
|
|
||||||
|
#define CHECKPOINT \
|
||||||
|
NETIO_DbgPrint(DEBUG_CHECK, ("\n"));
|
||||||
|
|
||||||
|
#define CP CHECKPOINT
|
||||||
|
|
||||||
|
/* EOF */
|
1365
drivers/network/netio/netio.c
Normal file
1365
drivers/network/netio/netio.c
Normal file
File diff suppressed because it is too large
Load diff
4
drivers/network/netio/netio.spec
Normal file
4
drivers/network/netio/netio.spec
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
@ stdcall WskRegister(ptr ptr)
|
||||||
|
@ stdcall WskCaptureProviderNPI(ptr long ptr)
|
||||||
|
@ stdcall WskReleaseProviderNPI(ptr)
|
||||||
|
@ stdcall WskDeregister(ptr)
|
7
drivers/network/netio/netio_reg.inf
Normal file
7
drivers/network/netio/netio_reg.inf
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
; Netio driver
|
||||||
|
[AddReg]
|
||||||
|
HKLM,"SYSTEM\CurrentControlSet\Services\Netio","ErrorControl",0x00010001,0x00000001
|
||||||
|
HKLM,"SYSTEM\CurrentControlSet\Services\Netio","Group",0x00000000,"TDI"
|
||||||
|
HKLM,"SYSTEM\CurrentControlSet\Services\Netio","ImagePath",0x00020000,"system32\drivers\netio.sys"
|
||||||
|
HKLM,"SYSTEM\CurrentControlSet\Services\Netio","Start",0x00010001,0x00000001
|
||||||
|
HKLM,"SYSTEM\CurrentControlSet\Services\Netio","Type",0x00010001,0x00000001
|
39
drivers/network/tdihelpers/include/tdi_proto.h
Normal file
39
drivers/network/tdihelpers/include/tdi_proto.h
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
NTSTATUS TdiConnect(
|
||||||
|
PIRP * PendingIrp,
|
||||||
|
PFILE_OBJECT ConnectionObject,
|
||||||
|
PTDI_CONNECTION_INFORMATION ConnectionCallInfo,
|
||||||
|
PTDI_CONNECTION_INFORMATION ConnectionReturnInfo,
|
||||||
|
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
||||||
|
PVOID CompletionContext);
|
||||||
|
|
||||||
|
NTSTATUS TdiOpenConnectionEndpointFile(
|
||||||
|
PUNICODE_STRING DeviceName,
|
||||||
|
PHANDLE ConnectionHandle,
|
||||||
|
PFILE_OBJECT * ConnectionObject);
|
||||||
|
|
||||||
|
NTSTATUS TdiCloseDevice(HANDLE Handle, PFILE_OBJECT FileObject);
|
||||||
|
|
||||||
|
NTSTATUS TdiDisconnect(
|
||||||
|
PIRP * Irp,
|
||||||
|
PFILE_OBJECT TransportObject,
|
||||||
|
PLARGE_INTEGER Time,
|
||||||
|
USHORT Flags,
|
||||||
|
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
||||||
|
PVOID CompletionContext,
|
||||||
|
PTDI_CONNECTION_INFORMATION RequestConnectionInfo,
|
||||||
|
PTDI_CONNECTION_INFORMATION ReturnConnectionInfo);
|
||||||
|
|
||||||
|
NTSTATUS TdiQueryInformation(PFILE_OBJECT FileObject, LONG QueryType, PMDL MdlBuffer);
|
||||||
|
|
||||||
|
NTSTATUS TdiSetEventHandler(PFILE_OBJECT FileObject, LONG EventType, PVOID Handler, PVOID Context);
|
||||||
|
|
||||||
|
NTSTATUS TdiQueryDeviceControl(
|
||||||
|
PFILE_OBJECT FileObject,
|
||||||
|
ULONG IoControlCode,
|
||||||
|
PVOID InputBuffer,
|
||||||
|
ULONG InputBufferLength,
|
||||||
|
PVOID OutputBuffer,
|
||||||
|
ULONG OutputBufferLength,
|
||||||
|
PULONG Return);
|
84
drivers/network/tdihelpers/include/tdiconn.h
Normal file
84
drivers/network/tdihelpers/include/tdiconn.h
Normal file
|
@ -0,0 +1,84 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
typedef VOID *PTDI_CONNECTION_INFO_PAIR;
|
||||||
|
|
||||||
|
PTRANSPORT_ADDRESS TaCopyTransportAddress(PTRANSPORT_ADDRESS OtherAddress);
|
||||||
|
PTRANSPORT_ADDRESS TaBuildNullTransportAddress(UINT AddressType);
|
||||||
|
UINT TaLengthOfAddress(PTA_ADDRESS Addr);
|
||||||
|
UINT TaLengthOfTransportAddress(PTRANSPORT_ADDRESS Addr);
|
||||||
|
UINT TaLengthOfTransportAddressByType(UINT AddressType);
|
||||||
|
VOID TaCopyTransportAddressInPlace(PTRANSPORT_ADDRESS Target, PTRANSPORT_ADDRESS Source);
|
||||||
|
UINT TdiAddressSizeFromType(UINT Type);
|
||||||
|
UINT TdiAddressSizeFromName(PTRANSPORT_ADDRESS Name);
|
||||||
|
NTSTATUS TdiBuildConnectionInfoInPlace(PTDI_CONNECTION_INFORMATION ConnInfo, PTRANSPORT_ADDRESS Name);
|
||||||
|
NTSTATUS TdiBuildConnectionInfo(PTDI_CONNECTION_INFORMATION * ConnectionInfo, PTRANSPORT_ADDRESS Name);
|
||||||
|
NTSTATUS TdiBuildNullConnectionInfoInPlace(PTDI_CONNECTION_INFORMATION ConnInfo, ULONG Type);
|
||||||
|
NTSTATUS TdiBuildNullConnectionInfo(PTDI_CONNECTION_INFORMATION * ConnectionInfo, ULONG Type);
|
||||||
|
|
||||||
|
/* Taken from afd.h: */
|
||||||
|
/* tdi.c */
|
||||||
|
|
||||||
|
NTSTATUS TdiOpenAddressFile(PUNICODE_STRING DeviceName,
|
||||||
|
PTRANSPORT_ADDRESS Name,
|
||||||
|
ULONG ShareType,
|
||||||
|
PHANDLE AddressHandle,
|
||||||
|
PFILE_OBJECT * AddressObject);
|
||||||
|
|
||||||
|
NTSTATUS TdiAssociateAddressFile(HANDLE AddressHandle, PFILE_OBJECT ConnectionObject);
|
||||||
|
|
||||||
|
NTSTATUS TdiDisassociateAddressFile(PFILE_OBJECT ConnectionObject);
|
||||||
|
|
||||||
|
NTSTATUS TdiListen(
|
||||||
|
PIRP * Irp,
|
||||||
|
PFILE_OBJECT ConnectionObject,
|
||||||
|
PTDI_CONNECTION_INFORMATION * RequestConnectionInfo,
|
||||||
|
PTDI_CONNECTION_INFORMATION * ReturnConnectionInfo,
|
||||||
|
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
||||||
|
PVOID CompletionContext);
|
||||||
|
|
||||||
|
NTSTATUS TdiAccept(
|
||||||
|
PIRP * Irp,
|
||||||
|
PFILE_OBJECT AcceptConnectionObject,
|
||||||
|
PTDI_CONNECTION_INFORMATION RequestConnectionInfo,
|
||||||
|
PTDI_CONNECTION_INFORMATION ReturnConnectionInfo,
|
||||||
|
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
||||||
|
PVOID CompletionContext);
|
||||||
|
|
||||||
|
NTSTATUS TdiReceive(
|
||||||
|
PIRP * Irp,
|
||||||
|
PFILE_OBJECT ConnectionObject,
|
||||||
|
USHORT Flags,
|
||||||
|
PCHAR Buffer,
|
||||||
|
UINT BufferLength,
|
||||||
|
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
||||||
|
PVOID CompletionContext);
|
||||||
|
|
||||||
|
NTSTATUS TdiSend(
|
||||||
|
PIRP * Irp,
|
||||||
|
PFILE_OBJECT ConnectionObject,
|
||||||
|
USHORT Flags,
|
||||||
|
PCHAR Buffer,
|
||||||
|
UINT BufferLength,
|
||||||
|
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
||||||
|
PVOID CompletionContext);
|
||||||
|
|
||||||
|
NTSTATUS TdiReceiveDatagram(
|
||||||
|
PIRP * Irp,
|
||||||
|
PFILE_OBJECT TransportObject,
|
||||||
|
USHORT Flags,
|
||||||
|
PCHAR Buffer,
|
||||||
|
UINT BufferLength,
|
||||||
|
PTDI_CONNECTION_INFORMATION From,
|
||||||
|
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
||||||
|
PVOID CompletionContext);
|
||||||
|
|
||||||
|
NTSTATUS TdiSendDatagram(
|
||||||
|
PIRP * Irp,
|
||||||
|
PFILE_OBJECT TransportObject,
|
||||||
|
PCHAR Buffer,
|
||||||
|
UINT BufferLength,
|
||||||
|
PTDI_CONNECTION_INFORMATION To,
|
||||||
|
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
||||||
|
PVOID CompletionContext);
|
||||||
|
|
||||||
|
NTSTATUS TdiQueryMaxDatagramLength(PFILE_OBJECT FileObject, PUINT MaxDatagramLength);
|
|
@ -129,6 +129,7 @@ static NTSTATUS TdiOpenDevice(
|
||||||
OBJ_KERNEL_HANDLE,
|
OBJ_KERNEL_HANDLE,
|
||||||
NULL, /* Root directory */
|
NULL, /* Root directory */
|
||||||
NULL); /* Security descriptor */
|
NULL); /* Security descriptor */
|
||||||
|
DbgPrint("Into ZwCreateFile IRQL is %d...\n", KeGetCurrentIrql());
|
||||||
|
|
||||||
Status = ZwCreateFile(Handle, /* Return file handle */
|
Status = ZwCreateFile(Handle, /* Return file handle */
|
||||||
GENERIC_READ | GENERIC_WRITE | SYNCHRONIZE, /* Desired access */
|
GENERIC_READ | GENERIC_WRITE | SYNCHRONIZE, /* Desired access */
|
||||||
|
@ -141,6 +142,7 @@ static NTSTATUS TdiOpenDevice(
|
||||||
0, /* Create options */
|
0, /* Create options */
|
||||||
EaInfo, /* EA buffer */
|
EaInfo, /* EA buffer */
|
||||||
EaLength); /* EA length */
|
EaLength); /* EA length */
|
||||||
|
DbgPrint("Out of ZwCreateFile IRQL is %d...\n", KeGetCurrentIrql());
|
||||||
if (NT_SUCCESS(Status)) {
|
if (NT_SUCCESS(Status)) {
|
||||||
Status = ObReferenceObjectByHandle(*Handle, /* Handle to open file */
|
Status = ObReferenceObjectByHandle(*Handle, /* Handle to open file */
|
||||||
GENERIC_READ | GENERIC_WRITE | SYNCHRONIZE, /* Access mode */
|
GENERIC_READ | GENERIC_WRITE | SYNCHRONIZE, /* Access mode */
|
||||||
|
@ -320,12 +322,14 @@ NTSTATUS TdiOpenConnectionEndpointFile(
|
||||||
ContextArea = (PVOID*)(EaInfo->EaName + TDI_CONNECTION_CONTEXT_LENGTH + 1); /* 0-terminated */
|
ContextArea = (PVOID*)(EaInfo->EaName + TDI_CONNECTION_CONTEXT_LENGTH + 1); /* 0-terminated */
|
||||||
/* FIXME: Allocate context area */
|
/* FIXME: Allocate context area */
|
||||||
*ContextArea = NULL;
|
*ContextArea = NULL;
|
||||||
|
DbgPrint("Into TdiOpenDevice ...\n");
|
||||||
Status = TdiOpenDevice(DeviceName,
|
Status = TdiOpenDevice(DeviceName,
|
||||||
EaLength,
|
EaLength,
|
||||||
EaInfo,
|
EaInfo,
|
||||||
AFD_SHARE_UNIQUE,
|
AFD_SHARE_UNIQUE,
|
||||||
ConnectionHandle,
|
ConnectionHandle,
|
||||||
ConnectionObject);
|
ConnectionObject);
|
||||||
|
DbgPrint("Out of TdiOpenDevice ...\n");
|
||||||
ExFreePoolWithTag(EaInfo, TAG_AFD_EA_INFO);
|
ExFreePoolWithTag(EaInfo, TAG_AFD_EA_INFO);
|
||||||
return Status;
|
return Status;
|
||||||
}
|
}
|
||||||
|
@ -542,6 +546,61 @@ NTSTATUS TdiListen(
|
||||||
return STATUS_PENDING;
|
return STATUS_PENDING;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NTSTATUS TdiAccept(
|
||||||
|
PIRP *Irp,
|
||||||
|
PFILE_OBJECT AcceptConnectionObject,
|
||||||
|
PTDI_CONNECTION_INFORMATION RequestConnectionInfo,
|
||||||
|
PTDI_CONNECTION_INFORMATION ReturnConnectionInfo,
|
||||||
|
PIO_COMPLETION_ROUTINE CompletionRoutine,
|
||||||
|
PVOID CompletionContext)
|
||||||
|
/*
|
||||||
|
* FUNCTION: Listen on a connection endpoint for a connection request from a remote peer
|
||||||
|
* ARGUMENTS:
|
||||||
|
* CompletionRoutine = Routine to be called when IRP is completed
|
||||||
|
* CompletionContext = Context for CompletionRoutine
|
||||||
|
* RETURNS:
|
||||||
|
* Status of operation
|
||||||
|
* May return STATUS_PENDING
|
||||||
|
*/
|
||||||
|
{
|
||||||
|
PDEVICE_OBJECT DeviceObject;
|
||||||
|
|
||||||
|
AFD_DbgPrint(MAX_TRACE, ("Called\n"));
|
||||||
|
|
||||||
|
ASSERT(*Irp == NULL); /* TODO: why at all? We are overwriting it anyway ... */
|
||||||
|
|
||||||
|
if (!AcceptConnectionObject) {
|
||||||
|
AFD_DbgPrint(MIN_TRACE, ("Bad connection object.\n"));
|
||||||
|
return STATUS_INVALID_PARAMETER;
|
||||||
|
}
|
||||||
|
|
||||||
|
DeviceObject = IoGetRelatedDeviceObject(AcceptConnectionObject);
|
||||||
|
if (!DeviceObject) {
|
||||||
|
AFD_DbgPrint(MIN_TRACE, ("Bad device object.\n"));
|
||||||
|
return STATUS_INVALID_PARAMETER;
|
||||||
|
}
|
||||||
|
|
||||||
|
*Irp = TdiBuildInternalDeviceControlIrp(TDI_LISTEN, /* Sub function */
|
||||||
|
DeviceObject, /* Device object */
|
||||||
|
AcceptConnectionObject, /* File object */
|
||||||
|
NULL, /* Event */
|
||||||
|
NULL); /* Status */
|
||||||
|
if (*Irp == NULL)
|
||||||
|
return STATUS_INSUFFICIENT_RESOURCES;
|
||||||
|
|
||||||
|
TdiBuildAccept(*Irp, /* IRP */
|
||||||
|
DeviceObject, /* Device object */
|
||||||
|
AcceptConnectionObject, /* File object */
|
||||||
|
CompletionRoutine, /* Completion routine */
|
||||||
|
CompletionContext, /* Completion routine context */
|
||||||
|
RequestConnectionInfo, /* Request connection information */
|
||||||
|
ReturnConnectionInfo); /* Return connection information */
|
||||||
|
|
||||||
|
TdiCall(*Irp, DeviceObject, NULL /* Don't wait for completion */, NULL);
|
||||||
|
|
||||||
|
return STATUS_PENDING;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
NTSTATUS TdiSetEventHandler(
|
NTSTATUS TdiSetEventHandler(
|
||||||
PFILE_OBJECT FileObject,
|
PFILE_OBJECT FileObject,
|
|
@ -159,7 +159,8 @@ NTSTATUS TdiBuildNullConnectionInfoInPlace
|
||||||
sizeof(TDI_CONNECTION_INFORMATION) +
|
sizeof(TDI_CONNECTION_INFORMATION) +
|
||||||
TdiAddressSize);
|
TdiAddressSize);
|
||||||
|
|
||||||
ConnInfo->OptionsLength = sizeof(ULONG);
|
/* TODO: !! */
|
||||||
|
// ConnInfo->OptionsLength = sizeof(ULONG);
|
||||||
ConnInfo->RemoteAddressLength = TdiAddressSize;
|
ConnInfo->RemoteAddressLength = TdiAddressSize;
|
||||||
ConnInfo->RemoteAddress = TransportAddress =
|
ConnInfo->RemoteAddress = TransportAddress =
|
||||||
(PTRANSPORT_ADDRESS)&ConnInfo[1];
|
(PTRANSPORT_ADDRESS)&ConnInfo[1];
|
|
@ -404,6 +404,7 @@ union _DL_EUI48 {
|
||||||
DL_EI48 Ei48;
|
DL_EI48 Ei48;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
typedef union _DL_EUI48 DL_EUI48, *PDL_EUI48;
|
||||||
|
|
||||||
C_ASSERT(DL_ADDRESS_LENGTH_MAXIMUM >= sizeof(DL_EUI48));
|
C_ASSERT(DL_ADDRESS_LENGTH_MAXIMUM >= sizeof(DL_EUI48));
|
||||||
|
|
||||||
|
|
|
@ -360,11 +360,7 @@ typedef USHORT ADDRESS_FAMILY;
|
||||||
#define NI_MAXSERV 32
|
#define NI_MAXSERV 32
|
||||||
|
|
||||||
typedef struct sockaddr {
|
typedef struct sockaddr {
|
||||||
#if (_WIN32_WINNT < 0x0600)
|
|
||||||
u_short sa_family;
|
|
||||||
#else
|
|
||||||
ADDRESS_FAMILY sa_family;
|
ADDRESS_FAMILY sa_family;
|
||||||
#endif
|
|
||||||
CHAR sa_data[14];
|
CHAR sa_data[14];
|
||||||
} SOCKADDR, *PSOCKADDR, FAR *LPSOCKADDR;
|
} SOCKADDR, *PSOCKADDR, FAR *LPSOCKADDR;
|
||||||
|
|
||||||
|
@ -524,17 +520,9 @@ typedef struct _WSAMSG {
|
||||||
LPSOCKADDR name;
|
LPSOCKADDR name;
|
||||||
INT namelen;
|
INT namelen;
|
||||||
LPWSABUF lpBuffers;
|
LPWSABUF lpBuffers;
|
||||||
#if (_WIN32_WINNT >= 0x0600)
|
|
||||||
ULONG dwBufferCount;
|
ULONG dwBufferCount;
|
||||||
#else
|
|
||||||
DWORD dwBufferCount;
|
|
||||||
#endif
|
|
||||||
WSABUF Control;
|
WSABUF Control;
|
||||||
#if (_WIN32_WINNT >= 0x0600)
|
|
||||||
ULONG dwFlags;
|
ULONG dwFlags;
|
||||||
#else
|
|
||||||
DWORD dwFlags;
|
|
||||||
#endif
|
|
||||||
} WSAMSG, *PWSAMSG, *FAR LPWSAMSG;
|
} WSAMSG, *PWSAMSG, *FAR LPWSAMSG;
|
||||||
|
|
||||||
#if (_WIN32_WINNT >= 0x0600)
|
#if (_WIN32_WINNT >= 0x0600)
|
||||||
|
@ -547,9 +535,7 @@ typedef struct _WSACMSGHDR {
|
||||||
INT cmsg_type;
|
INT cmsg_type;
|
||||||
} WSACMSGHDR, *PWSACMSGHDR, FAR *LPWSACMSGHDR;
|
} WSACMSGHDR, *PWSACMSGHDR, FAR *LPWSACMSGHDR;
|
||||||
|
|
||||||
#if (_WIN32_WINNT >= 0x0600)
|
|
||||||
typedef WSACMSGHDR CMSGHDR, *PCMSGHDR;
|
typedef WSACMSGHDR CMSGHDR, *PCMSGHDR;
|
||||||
#endif
|
|
||||||
|
|
||||||
#define WSA_CMSGHDR_ALIGN(length) (((length) + TYPE_ALIGNMENT(WSACMSGHDR)-1) & \
|
#define WSA_CMSGHDR_ALIGN(length) (((length) + TYPE_ALIGNMENT(WSACMSGHDR)-1) & \
|
||||||
(~(TYPE_ALIGNMENT(WSACMSGHDR)-1)))
|
(~(TYPE_ALIGNMENT(WSACMSGHDR)-1)))
|
||||||
|
|
Loading…
Reference in a new issue