mirror of
https://github.com/moonlight-stream/moonlight-common-c.git
synced 2025-08-17 08:55:48 +00:00
Fix error propagation from WinSock functions. Fix cleanup of sockets. Allow the handshake to be interrupted.
This commit is contained in:
parent
d6c77b0323
commit
2f83dba24c
@ -37,7 +37,10 @@ void LiStopConnection(void) {
|
|||||||
Limelog("done\n");
|
Limelog("done\n");
|
||||||
}
|
}
|
||||||
if (stage == STAGE_HANDSHAKE) {
|
if (stage == STAGE_HANDSHAKE) {
|
||||||
|
Limelog("Terminating handshake...");
|
||||||
|
terminateHandshake();
|
||||||
stage--;
|
stage--;
|
||||||
|
Limelog("done\n");
|
||||||
}
|
}
|
||||||
if (stage == STAGE_PLATFORM_INIT) {
|
if (stage == STAGE_PLATFORM_INIT) {
|
||||||
Limelog("Cleaning up platform...");
|
Limelog("Cleaning up platform...");
|
||||||
@ -70,12 +73,6 @@ int LiStartConnection(IP_ADDRESS host, PSTREAM_CONFIGURATION streamConfig, PDECO
|
|||||||
LC_ASSERT(stage == STAGE_HANDSHAKE);
|
LC_ASSERT(stage == STAGE_HANDSHAKE);
|
||||||
Limelog("done\n");
|
Limelog("done\n");
|
||||||
|
|
||||||
Limelog("Initializing video stream...");
|
|
||||||
initializeVideoStream(host, streamConfig, drCallbacks);
|
|
||||||
stage++;
|
|
||||||
LC_ASSERT(stage == STAGE_VIDEO_STREAM_INIT);
|
|
||||||
Limelog("done\n");
|
|
||||||
|
|
||||||
Limelog("Initializing control stream...");
|
Limelog("Initializing control stream...");
|
||||||
err = initializeControlStream(host, streamConfig);
|
err = initializeControlStream(host, streamConfig);
|
||||||
if (err != 0) {
|
if (err != 0) {
|
||||||
@ -86,6 +83,12 @@ int LiStartConnection(IP_ADDRESS host, PSTREAM_CONFIGURATION streamConfig, PDECO
|
|||||||
LC_ASSERT(stage == STAGE_CONTROL_STREAM_INIT);
|
LC_ASSERT(stage == STAGE_CONTROL_STREAM_INIT);
|
||||||
Limelog("done\n");
|
Limelog("done\n");
|
||||||
|
|
||||||
|
Limelog("Initializing video stream...");
|
||||||
|
initializeVideoStream(host, streamConfig, drCallbacks);
|
||||||
|
stage++;
|
||||||
|
LC_ASSERT(stage == STAGE_VIDEO_STREAM_INIT);
|
||||||
|
Limelog("done\n");
|
||||||
|
|
||||||
Limelog("Starting control stream...");
|
Limelog("Starting control stream...");
|
||||||
err = startControlStream();
|
err = startControlStream();
|
||||||
if (err != 0) {
|
if (err != 0) {
|
||||||
|
@ -8,7 +8,7 @@ typedef struct _NVCTL_PACKET_HEADER {
|
|||||||
} NVCTL_PACKET_HEADER, *PNVCTL_PACKET_HEADER;
|
} NVCTL_PACKET_HEADER, *PNVCTL_PACKET_HEADER;
|
||||||
|
|
||||||
IP_ADDRESS host;
|
IP_ADDRESS host;
|
||||||
SOCKET ctlSock;
|
SOCKET ctlSock = INVALID_SOCKET;
|
||||||
STREAM_CONFIGURATION streamConfig;
|
STREAM_CONFIGURATION streamConfig;
|
||||||
PLT_THREAD heartbeatThread;
|
PLT_THREAD heartbeatThread;
|
||||||
PLT_THREAD jitterThread;
|
PLT_THREAD jitterThread;
|
||||||
|
@ -23,61 +23,75 @@ const char PACKET4 [] = {
|
|||||||
0x01, 0x01, 0x00, 0x0
|
0x01, 0x01, 0x00, 0x0
|
||||||
};
|
};
|
||||||
|
|
||||||
|
SOCKET sock = INVALID_SOCKET;
|
||||||
|
|
||||||
static int waitAndDiscardResponse(SOCKET sock) {
|
static int waitAndDiscardResponse(SOCKET sock) {
|
||||||
char temp[256];
|
char temp[256];
|
||||||
return recv(sock, temp, sizeof(temp), 0);
|
return recv(sock, temp, sizeof(temp), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void terminateHandshake(void) {
|
||||||
|
if (sock != INVALID_SOCKET) {
|
||||||
|
closesocket(sock);
|
||||||
|
sock = INVALID_SOCKET;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
int performHandshake(IP_ADDRESS host) {
|
int performHandshake(IP_ADDRESS host) {
|
||||||
SOCKET s;
|
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
s = connectTcpSocket(host, 47991);
|
sock = connectTcpSocket(host, 47991);
|
||||||
if (s == INVALID_SOCKET) {
|
if (sock == INVALID_SOCKET) {
|
||||||
return LastSocketError();
|
return LastSocketError();
|
||||||
}
|
}
|
||||||
|
|
||||||
enableNoDelay(s);
|
enableNoDelay(sock);
|
||||||
|
|
||||||
err = send(s, HELLO, sizeof(HELLO), 0);
|
err = send(sock, HELLO, sizeof(HELLO), 0);
|
||||||
if (err == SOCKET_ERROR) {
|
if (err == SOCKET_ERROR) {
|
||||||
goto CleanupError;
|
goto CleanupError;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = waitAndDiscardResponse(s);
|
err = waitAndDiscardResponse(sock);
|
||||||
if (err == SOCKET_ERROR) {
|
if (err == SOCKET_ERROR) {
|
||||||
goto CleanupError;
|
goto CleanupError;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = send(s, PACKET2, sizeof(PACKET2), 0);
|
err = send(sock, PACKET2, sizeof(PACKET2), 0);
|
||||||
if (err == SOCKET_ERROR) {
|
if (err == SOCKET_ERROR) {
|
||||||
goto CleanupError;
|
goto CleanupError;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = waitAndDiscardResponse(s);
|
err = waitAndDiscardResponse(sock);
|
||||||
if (err == SOCKET_ERROR) {
|
if (err == SOCKET_ERROR) {
|
||||||
goto CleanupError;
|
goto CleanupError;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = send(s, PACKET3, sizeof(PACKET3), 0);
|
err = send(sock, PACKET3, sizeof(PACKET3), 0);
|
||||||
if (err == SOCKET_ERROR) {
|
if (err == SOCKET_ERROR) {
|
||||||
goto CleanupError;
|
goto CleanupError;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = waitAndDiscardResponse(s);
|
err = waitAndDiscardResponse(sock);
|
||||||
if (err == SOCKET_ERROR) {
|
if (err == SOCKET_ERROR) {
|
||||||
goto CleanupError;
|
goto CleanupError;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = send(s, PACKET4, sizeof(PACKET4), 0);
|
err = send(sock, PACKET4, sizeof(PACKET4), 0);
|
||||||
if (err == SOCKET_ERROR) {
|
if (err == SOCKET_ERROR) {
|
||||||
goto CleanupError;
|
goto CleanupError;
|
||||||
}
|
}
|
||||||
|
|
||||||
closesocket(s);
|
closesocket(sock);
|
||||||
|
sock = INVALID_SOCKET;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
CleanupError:
|
CleanupError:
|
||||||
closesocket(s);
|
closesocket(sock);
|
||||||
|
sock = INVALID_SOCKET;
|
||||||
|
|
||||||
return LastSocketError();
|
return LastSocketError();
|
||||||
}
|
}
|
@ -18,6 +18,7 @@ void destroyControlStream(void);
|
|||||||
void requestIdrFrame(void);
|
void requestIdrFrame(void);
|
||||||
|
|
||||||
int performHandshake(IP_ADDRESS host);
|
int performHandshake(IP_ADDRESS host);
|
||||||
|
void terminateHandshake(void);
|
||||||
|
|
||||||
void initializeVideoDepacketizer(void);
|
void initializeVideoDepacketizer(void);
|
||||||
void destroyVideoDepacketizer(void);
|
void destroyVideoDepacketizer(void);
|
||||||
|
@ -5,6 +5,7 @@ SOCKET bindUdpSocket(unsigned short port) {
|
|||||||
SOCKET s;
|
SOCKET s;
|
||||||
struct sockaddr_in addr;
|
struct sockaddr_in addr;
|
||||||
int val;
|
int val;
|
||||||
|
int err;
|
||||||
|
|
||||||
s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
|
s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
|
||||||
if (s == INVALID_SOCKET) {
|
if (s == INVALID_SOCKET) {
|
||||||
@ -15,7 +16,9 @@ SOCKET bindUdpSocket(unsigned short port) {
|
|||||||
addr.sin_family = AF_INET;
|
addr.sin_family = AF_INET;
|
||||||
addr.sin_port = htons(port);
|
addr.sin_port = htons(port);
|
||||||
if (bind(s, (struct sockaddr*) &addr, sizeof(addr)) == SOCKET_ERROR) {
|
if (bind(s, (struct sockaddr*) &addr, sizeof(addr)) == SOCKET_ERROR) {
|
||||||
|
err = LastSocketError();
|
||||||
closesocket(s);
|
closesocket(s);
|
||||||
|
SetLastSocketError(err);
|
||||||
return INVALID_SOCKET;
|
return INVALID_SOCKET;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -28,6 +31,7 @@ SOCKET bindUdpSocket(unsigned short port) {
|
|||||||
SOCKET connectTcpSocket(IP_ADDRESS dstaddr, unsigned short port) {
|
SOCKET connectTcpSocket(IP_ADDRESS dstaddr, unsigned short port) {
|
||||||
SOCKET s;
|
SOCKET s;
|
||||||
struct sockaddr_in addr;
|
struct sockaddr_in addr;
|
||||||
|
int err;
|
||||||
|
|
||||||
s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
|
s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
|
||||||
if (s == INVALID_SOCKET) {
|
if (s == INVALID_SOCKET) {
|
||||||
@ -39,7 +43,9 @@ SOCKET connectTcpSocket(IP_ADDRESS dstaddr, unsigned short port) {
|
|||||||
addr.sin_port = htons(port);
|
addr.sin_port = htons(port);
|
||||||
memcpy(&addr.sin_addr, &dstaddr, sizeof(dstaddr));
|
memcpy(&addr.sin_addr, &dstaddr, sizeof(dstaddr));
|
||||||
if (connect(s, (struct sockaddr*) &addr, sizeof(addr)) == SOCKET_ERROR) {
|
if (connect(s, (struct sockaddr*) &addr, sizeof(addr)) == SOCKET_ERROR) {
|
||||||
|
err = LastSocketError();
|
||||||
closesocket(s);
|
closesocket(s);
|
||||||
|
SetLastSocketError(err);
|
||||||
return INVALID_SOCKET;
|
return INVALID_SOCKET;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
|
#define SetLastSocketError(x) WSASetLastError(x)
|
||||||
#define LastSocketError() WSAGetLastError()
|
#define LastSocketError() WSAGetLastError()
|
||||||
#else
|
#else
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
@ -13,6 +14,7 @@
|
|||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#define SOCKET int
|
#define SOCKET int
|
||||||
#define LastSocketError() errno
|
#define LastSocketError() errno
|
||||||
|
#define SetLastSocketError(x) errno = x
|
||||||
#define INVALID_SOCKET -1
|
#define INVALID_SOCKET -1
|
||||||
#define SOCKET_ERROR -1
|
#define SOCKET_ERROR -1
|
||||||
#define closesocket(x) close(x)
|
#define closesocket(x) close(x)
|
||||||
|
@ -7,8 +7,8 @@ PDECODER_RENDERER_CALLBACKS callbacks;
|
|||||||
PSTREAM_CONFIGURATION configuration;
|
PSTREAM_CONFIGURATION configuration;
|
||||||
IP_ADDRESS remoteHost;
|
IP_ADDRESS remoteHost;
|
||||||
|
|
||||||
SOCKET rtpSocket;
|
SOCKET rtpSocket = INVALID_SOCKET;
|
||||||
SOCKET firstFrameSocket;
|
SOCKET firstFrameSocket = INVALID_SOCKET;
|
||||||
|
|
||||||
LINKED_BLOCKING_QUEUE packetQueue;
|
LINKED_BLOCKING_QUEUE packetQueue;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user