/* * 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 #include #include #include /* * @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 */