mirror of
https://github.com/reactos/reactos.git
synced 2024-11-04 13:52:30 +00:00
c2d0d784c7
- Create a branch to do a proper merge of USB work from a trunk base instead of from cmake-bringup - In the future, DO NOT under any circumstances branch another branch. This leads to merge problems! svn path=/branches/usb-bringup-trunk/; revision=55018
415 lines
9.8 KiB
C
415 lines
9.8 KiB
C
/*
|
|
* COPYRIGHT: See COPYING in the top level directory
|
|
* PROJECT: ReactOS WinSock 2 DLL
|
|
* FILE: misc/sndrcv.c
|
|
* PURPOSE: Send/receive functions
|
|
* PROGRAMMERS: Casper S. Hornstrup (chorns@users.sourceforge.net)
|
|
* REVISIONS:
|
|
* CSH 01/09-2000 Created
|
|
*/
|
|
|
|
#include "ws2_32.h"
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
INT
|
|
EXPORT
|
|
recv(IN SOCKET s,
|
|
OUT CHAR FAR* buf,
|
|
IN INT len,
|
|
IN INT flags)
|
|
{
|
|
DWORD Error;
|
|
DWORD BytesReceived;
|
|
WSABUF WSABuf;
|
|
|
|
WS_DbgPrint(MAX_TRACE, ("s (0x%X) buf (0x%X) len (0x%X) flags (0x%X).\n",
|
|
s,
|
|
buf,
|
|
len,
|
|
flags));
|
|
|
|
WSABuf.len = len;
|
|
WSABuf.buf = (CHAR FAR*)buf;
|
|
|
|
Error = WSARecv(s,
|
|
&WSABuf,
|
|
1,
|
|
&BytesReceived,
|
|
(LPDWORD)&flags,
|
|
NULL,
|
|
NULL);
|
|
|
|
if( Error )
|
|
return -1;
|
|
else
|
|
return BytesReceived;
|
|
}
|
|
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
INT
|
|
EXPORT
|
|
recvfrom(IN SOCKET s,
|
|
OUT CHAR FAR* buf,
|
|
IN INT len,
|
|
IN INT flags,
|
|
OUT LPSOCKADDR from,
|
|
IN OUT INT FAR* fromlen)
|
|
{
|
|
DWORD Error;
|
|
DWORD BytesReceived;
|
|
WSABUF WSABuf;
|
|
|
|
WS_DbgPrint(MAX_TRACE, ("s (0x%X) buf (0x%X) len (0x%X) flags (0x%X).\n",
|
|
s,
|
|
buf,
|
|
len,
|
|
flags));
|
|
|
|
WSABuf.len = len;
|
|
WSABuf.buf = (CHAR FAR*)buf;
|
|
|
|
Error = WSARecvFrom(s,
|
|
&WSABuf,
|
|
1,
|
|
&BytesReceived,
|
|
(LPDWORD)&flags,
|
|
from,
|
|
fromlen,
|
|
NULL,
|
|
NULL);
|
|
|
|
if( Error )
|
|
return -1;
|
|
else
|
|
return BytesReceived;
|
|
}
|
|
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
INT
|
|
EXPORT
|
|
send(IN SOCKET s,
|
|
IN CONST CHAR FAR* buf,
|
|
IN INT len,
|
|
IN INT flags)
|
|
{
|
|
DWORD BytesSent;
|
|
DWORD Error;
|
|
WSABUF WSABuf;
|
|
|
|
WS_DbgPrint(MAX_TRACE, ("s (0x%X) buf (0x%X) len (0x%X) flags (0x%X).\n",
|
|
s,
|
|
buf,
|
|
len,
|
|
flags));
|
|
|
|
WSABuf.len = len;
|
|
WSABuf.buf = (CHAR FAR*)buf;
|
|
|
|
Error = WSASend(s,
|
|
&WSABuf,
|
|
1,
|
|
&BytesSent,
|
|
flags,
|
|
NULL,
|
|
NULL);
|
|
|
|
if( Error )
|
|
{
|
|
WS_DbgPrint(MAX_TRACE,("Reporting error %d\n", Error));
|
|
return -1;
|
|
}
|
|
else
|
|
{
|
|
WS_DbgPrint(MAX_TRACE,("Read %d bytes\n", BytesSent));
|
|
return BytesSent;
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
INT
|
|
EXPORT
|
|
sendto(IN SOCKET s,
|
|
IN CONST CHAR FAR* buf,
|
|
IN INT len,
|
|
IN INT flags,
|
|
IN CONST struct sockaddr *to,
|
|
IN INT tolen)
|
|
{
|
|
DWORD Error;
|
|
DWORD BytesSent;
|
|
WSABUF WSABuf;
|
|
|
|
WS_DbgPrint(MAX_TRACE, ("s (0x%X) buf (0x%X) len (0x%X) flags (0x%X).\n",
|
|
s,
|
|
buf,
|
|
len,
|
|
flags));
|
|
|
|
WSABuf.len = len;
|
|
WSABuf.buf = (CHAR FAR*)buf;
|
|
|
|
Error = WSASendTo(s,
|
|
&WSABuf,
|
|
1,
|
|
&BytesSent,
|
|
flags,
|
|
to,
|
|
tolen,
|
|
NULL,
|
|
NULL);
|
|
|
|
if( Error )
|
|
return -1;
|
|
else
|
|
return BytesSent;
|
|
}
|
|
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
INT
|
|
EXPORT
|
|
WSARecv(IN SOCKET s,
|
|
IN OUT LPWSABUF lpBuffers,
|
|
IN DWORD dwBufferCount,
|
|
OUT LPDWORD lpNumberOfBytesRecvd,
|
|
IN OUT LPDWORD lpFlags,
|
|
IN LPWSAOVERLAPPED lpOverlapped,
|
|
IN LPWSAOVERLAPPED_COMPLETION_ROUTINE lpCompletionRoutine)
|
|
{
|
|
PCATALOG_ENTRY Provider;
|
|
INT Errno;
|
|
INT Code;
|
|
|
|
WS_DbgPrint(MAX_TRACE, ("Called.\n"));
|
|
|
|
if (!ReferenceProviderByHandle((HANDLE)s,
|
|
&Provider))
|
|
{
|
|
WSASetLastError(WSAENOTSOCK);
|
|
return SOCKET_ERROR;
|
|
}
|
|
|
|
assert(Provider->ProcTable.lpWSPRecv);
|
|
|
|
Code = Provider->ProcTable.lpWSPRecv(s,
|
|
lpBuffers,
|
|
dwBufferCount,
|
|
lpNumberOfBytesRecvd,
|
|
lpFlags,
|
|
lpOverlapped,
|
|
lpCompletionRoutine,
|
|
NULL /* lpThreadId */,
|
|
&Errno);
|
|
|
|
DereferenceProviderByPointer(Provider);
|
|
|
|
if (Code == SOCKET_ERROR)
|
|
WSASetLastError(Errno);
|
|
|
|
return Code;
|
|
}
|
|
|
|
|
|
/*
|
|
* @unimplemented
|
|
*/
|
|
INT
|
|
EXPORT
|
|
WSARecvDisconnect(IN SOCKET s,
|
|
OUT LPWSABUF lpInboundDisconnectData)
|
|
{
|
|
UNIMPLEMENTED
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
INT
|
|
EXPORT
|
|
WSARecvFrom(IN SOCKET s,
|
|
IN OUT LPWSABUF lpBuffers,
|
|
IN DWORD dwBufferCount,
|
|
OUT LPDWORD lpNumberOfBytesRecvd,
|
|
IN OUT LPDWORD lpFlags,
|
|
OUT LPSOCKADDR lpFrom,
|
|
IN OUT LPINT lpFromlen,
|
|
IN LPWSAOVERLAPPED lpOverlapped,
|
|
IN LPWSAOVERLAPPED_COMPLETION_ROUTINE lpCompletionRoutine)
|
|
{
|
|
PCATALOG_ENTRY Provider;
|
|
INT Errno;
|
|
INT Code;
|
|
|
|
WS_DbgPrint(MAX_TRACE, ("Called.\n"));
|
|
|
|
if (!ReferenceProviderByHandle((HANDLE)s, &Provider))
|
|
{
|
|
WSASetLastError(WSAENOTSOCK);
|
|
return SOCKET_ERROR;
|
|
}
|
|
|
|
assert(Provider->ProcTable.lpWSPRecvFrom);
|
|
|
|
Code = Provider->ProcTable.lpWSPRecvFrom(s,
|
|
lpBuffers,
|
|
dwBufferCount,
|
|
lpNumberOfBytesRecvd,
|
|
lpFlags,
|
|
lpFrom,
|
|
lpFromlen,
|
|
lpOverlapped,
|
|
lpCompletionRoutine,
|
|
NULL /* lpThreadId */,
|
|
&Errno);
|
|
|
|
DereferenceProviderByPointer(Provider);
|
|
|
|
if (Code == SOCKET_ERROR)
|
|
WSASetLastError(Errno);
|
|
|
|
return Code;
|
|
}
|
|
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
INT
|
|
EXPORT
|
|
WSASend(IN SOCKET s,
|
|
IN LPWSABUF lpBuffers,
|
|
IN DWORD dwBufferCount,
|
|
OUT LPDWORD lpNumberOfBytesSent,
|
|
IN DWORD dwFlags,
|
|
IN LPWSAOVERLAPPED lpOverlapped,
|
|
IN LPWSAOVERLAPPED_COMPLETION_ROUTINE lpCompletionRoutine)
|
|
{
|
|
PCATALOG_ENTRY Provider;
|
|
INT Errno;
|
|
INT Code;
|
|
|
|
WS_DbgPrint(MAX_TRACE, ("Called.\n"));
|
|
|
|
if (!ReferenceProviderByHandle((HANDLE)s, &Provider))
|
|
{
|
|
WSASetLastError(WSAENOTSOCK);
|
|
return SOCKET_ERROR;
|
|
}
|
|
|
|
assert(Provider->ProcTable.lpWSPSend);
|
|
|
|
Code = Provider->ProcTable.lpWSPSend(s,
|
|
lpBuffers,
|
|
dwBufferCount,
|
|
lpNumberOfBytesSent,
|
|
dwFlags,
|
|
lpOverlapped,
|
|
lpCompletionRoutine,
|
|
NULL /* lpThreadId */,
|
|
&Errno);
|
|
|
|
DereferenceProviderByPointer(Provider);
|
|
|
|
if (Code == SOCKET_ERROR)
|
|
WSASetLastError(Errno);
|
|
|
|
return Code;
|
|
}
|
|
|
|
|
|
/*
|
|
* @unimplemented
|
|
*/
|
|
INT
|
|
EXPORT
|
|
WSASendDisconnect(IN SOCKET s,
|
|
IN LPWSABUF lpOutboundDisconnectData)
|
|
{
|
|
UNIMPLEMENTED
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
INT
|
|
EXPORT
|
|
WSASendTo(IN SOCKET s,
|
|
IN LPWSABUF lpBuffers,
|
|
IN DWORD dwBufferCount,
|
|
OUT LPDWORD lpNumberOfBytesSent,
|
|
IN DWORD dwFlags,
|
|
IN CONST struct sockaddr *lpTo,
|
|
IN INT iToLen,
|
|
IN LPWSAOVERLAPPED lpOverlapped,
|
|
IN LPWSAOVERLAPPED_COMPLETION_ROUTINE lpCompletionRoutine)
|
|
{
|
|
PCATALOG_ENTRY Provider;
|
|
INT Errno;
|
|
INT Code;
|
|
|
|
WS_DbgPrint(MAX_TRACE, ("Called.\n"));
|
|
|
|
if (!ReferenceProviderByHandle((HANDLE)s, &Provider))
|
|
{
|
|
WSASetLastError(WSAENOTSOCK);
|
|
return SOCKET_ERROR;
|
|
}
|
|
|
|
assert(Provider->ProcTable.lpWSPSendTo);
|
|
|
|
#if (__W32API_MAJOR_VERSION < 2 || __W32API_MINOR_VERSION < 5)
|
|
Code = Provider->ProcTable.lpWSPSendTo(s,
|
|
lpBuffers,
|
|
dwBufferCount,
|
|
lpNumberOfBytesSent,
|
|
dwFlags,
|
|
(CONST LPSOCKADDR)lpTo,
|
|
iToLen,
|
|
lpOverlapped,
|
|
lpCompletionRoutine,
|
|
NULL /* lpThreadId */,
|
|
&Errno);
|
|
#else
|
|
Code = Provider->ProcTable.lpWSPSendTo(s,
|
|
lpBuffers,
|
|
dwBufferCount,
|
|
lpNumberOfBytesSent,
|
|
dwFlags,
|
|
lpTo,
|
|
iToLen,
|
|
lpOverlapped,
|
|
lpCompletionRoutine,
|
|
NULL /* lpThreadId */,
|
|
&Errno);
|
|
#endif /* __W32API_MAJOR_VERSION < 2 || __W32API_MINOR_VERSION < 5 */
|
|
|
|
DereferenceProviderByPointer(Provider);
|
|
|
|
if (Code == SOCKET_ERROR)
|
|
WSASetLastError(Errno);
|
|
else
|
|
WSASetLastError(0);
|
|
|
|
return Code;
|
|
}
|
|
|
|
/* EOF */
|