2015-03-09 17:37:02 +00:00
|
|
|
// Copyright 2015 Dolphin Emulator Project
|
2021-07-05 01:22:19 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2015-03-09 17:37:02 +00:00
|
|
|
|
2021-12-10 02:22:16 +00:00
|
|
|
#include "Common/ENetUtil.h"
|
2015-03-09 17:37:02 +00:00
|
|
|
|
2015-05-11 01:16:05 +00:00
|
|
|
#include "Common/CommonTypes.h"
|
|
|
|
|
2015-03-09 17:37:02 +00:00
|
|
|
namespace ENetUtil
|
|
|
|
{
|
|
|
|
void WakeupThread(ENetHost* host)
|
|
|
|
{
|
|
|
|
// 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-14 14:19:18 +00:00
|
|
|
int ENET_CALLBACK InterceptCallback(ENetHost* host, ENetEvent* event)
|
|
|
|
{
|
|
|
|
// wakeup packet received
|
|
|
|
if (host->receivedDataLength == 1 && host->receivedData[0] == 0)
|
|
|
|
{
|
|
|
|
event->type = (ENetEventType)42;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
2019-05-05 23:48:12 +00:00
|
|
|
} // namespace ENetUtil
|