mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
124 lines
3.5 KiB
124 lines
3.5 KiB
//////////////////////////////////////////////////////////
|
|
//
|
|
// Copyright (c) 2001 Microsoft Corporation
|
|
//
|
|
// Module Name:
|
|
// send.cpp
|
|
//
|
|
// Abstract:
|
|
// This module contains code which implements send
|
|
// commands from the dll
|
|
//
|
|
//////////////////////////////////////////////////////////
|
|
|
|
#include "stdafx.h"
|
|
|
|
///////////////////////////////////////////////////////////////////////
|
|
// Public functions
|
|
///////////////////////////////////////////////////////////////////////
|
|
|
|
// --------------------------------------------------------------------
|
|
//
|
|
// Function: DoSendDatagram
|
|
//
|
|
// Arguments: TdiHandle -- handle of address object
|
|
// pTransportAddress -- TA to send data to
|
|
// pucBuffer -- data buffer to send
|
|
// ulBufferLength -- length of data buffer
|
|
//
|
|
// Returns: none
|
|
//
|
|
// Descript: This function causes the driver to send a datagram
|
|
//
|
|
//---------------------------------------------------------------------
|
|
|
|
|
|
VOID
|
|
DoSendDatagram(ULONG ulTdiHandle,
|
|
PTRANSPORT_ADDRESS pTransportAddress,
|
|
PUCHAR pucBuffer,
|
|
ULONG ulBufferLength)
|
|
{
|
|
RECEIVE_BUFFER ReceiveBuffer; // return info from command
|
|
SEND_BUFFER SendBuffer; // arguments for command
|
|
|
|
//
|
|
// set up arguments
|
|
//
|
|
SendBuffer.TdiHandle = ulTdiHandle;
|
|
|
|
memcpy(&SendBuffer.COMMAND_ARGS.SendArgs.TransAddr,
|
|
pTransportAddress,
|
|
(FIELD_OFFSET(TRANSPORT_ADDRESS, Address)
|
|
+ FIELD_OFFSET(TA_ADDRESS, Address)
|
|
+ pTransportAddress->Address[0].AddressLength));
|
|
|
|
SendBuffer.COMMAND_ARGS.SendArgs.ulBufferLength = ulBufferLength;
|
|
SendBuffer.COMMAND_ARGS.SendArgs.pucUserModeBuffer = pucBuffer;
|
|
|
|
//
|
|
// call the driver
|
|
//
|
|
NTSTATUS lStatus = TdiLibDeviceIO(ulSENDDATAGRAM,
|
|
&SendBuffer,
|
|
&ReceiveBuffer);
|
|
|
|
if (lStatus != STATUS_SUCCESS)
|
|
{
|
|
_tprintf(TEXT("DoSendDatagram: failure, status = %s\n"), TdiLibStatusMessage(lStatus));
|
|
}
|
|
}
|
|
|
|
|
|
// --------------------------------------------------------------------
|
|
//
|
|
// Function: DoSend
|
|
//
|
|
// Arguments: TdiHandle -- handle of endpoint
|
|
// pucBuffer -- data buffer to send
|
|
// ulBufferLength -- length of data buffer
|
|
// ulSendFlags -- send options
|
|
//
|
|
// Returns: none
|
|
//
|
|
// Descript: This function causes the driver to send data over
|
|
// a connection
|
|
//
|
|
//---------------------------------------------------------------------
|
|
|
|
|
|
VOID
|
|
DoSend(ULONG ulTdiHandle,
|
|
PUCHAR pucBuffer,
|
|
ULONG ulBufferLength,
|
|
ULONG ulSendFlags)
|
|
{
|
|
RECEIVE_BUFFER ReceiveBuffer; // return info from command
|
|
SEND_BUFFER SendBuffer; // arguments for command
|
|
|
|
//
|
|
// set up arguments
|
|
//
|
|
SendBuffer.TdiHandle = ulTdiHandle;
|
|
|
|
SendBuffer.COMMAND_ARGS.SendArgs.ulFlags = ulSendFlags;
|
|
SendBuffer.COMMAND_ARGS.SendArgs.ulBufferLength = ulBufferLength;
|
|
SendBuffer.COMMAND_ARGS.SendArgs.pucUserModeBuffer = pucBuffer;
|
|
|
|
//
|
|
// call the driver
|
|
//
|
|
NTSTATUS lStatus = TdiLibDeviceIO(ulSEND,
|
|
&SendBuffer,
|
|
&ReceiveBuffer);
|
|
|
|
if (lStatus != STATUS_SUCCESS)
|
|
{
|
|
_tprintf(TEXT("DoSend: failure, status = %s\n"), TdiLibStatusMessage(lStatus));
|
|
}
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
// end of file send.cpp
|
|
////////////////////////////////////////////////////////////////////
|
|
|