2015-03-09 18:37:02 +01:00
|
|
|
// Copyright 2015 Dolphin Emulator Project
|
2021-07-05 03:22:19 +02:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2015-03-09 18:37:02 +01:00
|
|
|
|
2021-12-09 18:22:16 -08:00
|
|
|
#include "Common/ENetUtil.h"
|
2015-03-09 18:37:02 +01:00
|
|
|
|
2015-05-10 20:16:05 -05:00
|
|
|
#include "Common/CommonTypes.h"
|
|
|
|
|
2015-03-09 18:37:02 +01:00
|
|
|
namespace ENetUtil
|
|
|
|
{
|
|
|
|
void WakeupThread(ENetHost* host)
|
|
|
|
{
|
2016-06-24 10:43:46 +02:00
|
|
|
// Send ourselves a spurious message. This is hackier than it should be.
|
|
|
|
// comex reported this as https://github.com/lsalzman/enet/issues/23, so
|
|
|
|
// hopefully there will be a better way to do it in the future.
|
|
|
|
ENetAddress address;
|
|
|
|
if (host->address.port != 0)
|
|
|
|
address.port = host->address.port;
|
|
|
|
else
|
|
|
|
enet_socket_get_address(host->socket, &address);
|
|
|
|
address.host = 0x0100007f; // localhost
|
|
|
|
u8 byte = 0;
|
|
|
|
ENetBuffer buf;
|
|
|
|
buf.data = &byte;
|
|
|
|
buf.dataLength = 1;
|
|
|
|
enet_socket_send(host->socket, &address, &buf, 1);
|
2015-03-09 18:37:02 +01:00
|
|
|
}
|
|
|
|
|
2015-03-14 15:19:18 +01:00
|
|
|
int ENET_CALLBACK InterceptCallback(ENetHost* host, ENetEvent* event)
|
|
|
|
{
|
2016-06-24 10:43:46 +02:00
|
|
|
// wakeup packet received
|
|
|
|
if (host->receivedDataLength == 1 && host->receivedData[0] == 0)
|
|
|
|
{
|
|
|
|
event->type = (ENetEventType)42;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
2015-03-14 15:19:18 +01:00
|
|
|
}
|
2019-05-05 23:48:12 +00:00
|
|
|
} // namespace ENetUtil
|