2018-01-18 20:35:03 +01:00
|
|
|
// Copyright 2018 yuzu emulator team
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#include "core/hle/ipc_helpers.h"
|
2018-03-25 11:41:00 +02:00
|
|
|
#include "core/hle/service/sockets/bsd.h"
|
2018-01-18 20:35:03 +01:00
|
|
|
|
|
|
|
namespace Service {
|
|
|
|
namespace Sockets {
|
|
|
|
|
2018-03-25 11:41:00 +02:00
|
|
|
void BSD::RegisterClient(Kernel::HLERequestContext& ctx) {
|
2018-01-18 20:35:03 +01:00
|
|
|
LOG_WARNING(Service, "(STUBBED) called");
|
|
|
|
|
2018-01-24 01:52:18 +01:00
|
|
|
IPC::ResponseBuilder rb{ctx, 3};
|
2018-01-18 20:35:03 +01:00
|
|
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.Push<u32>(0); // bsd errno
|
|
|
|
}
|
|
|
|
|
2018-03-25 11:41:00 +02:00
|
|
|
void BSD::StartMonitoring(Kernel::HLERequestContext& ctx) {
|
2018-02-22 11:04:23 +01:00
|
|
|
LOG_WARNING(Service, "(STUBBED) called");
|
|
|
|
|
|
|
|
IPC::ResponseBuilder rb{ctx, 3};
|
|
|
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.Push<u32>(0); // bsd errno
|
|
|
|
}
|
|
|
|
|
2018-03-25 11:41:00 +02:00
|
|
|
void BSD::Socket(Kernel::HLERequestContext& ctx) {
|
2018-01-18 20:35:03 +01:00
|
|
|
IPC::RequestParser rp{ctx};
|
|
|
|
|
|
|
|
u32 domain = rp.Pop<u32>();
|
|
|
|
u32 type = rp.Pop<u32>();
|
|
|
|
u32 protocol = rp.Pop<u32>();
|
|
|
|
|
|
|
|
LOG_WARNING(Service, "(STUBBED) called domain=%u type=%u protocol=%u", domain, type, protocol);
|
|
|
|
|
|
|
|
u32 fd = next_fd++;
|
|
|
|
|
2018-01-24 01:52:18 +01:00
|
|
|
IPC::ResponseBuilder rb{ctx, 4};
|
2018-01-18 20:35:03 +01:00
|
|
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.Push<u32>(fd);
|
|
|
|
rb.Push<u32>(0); // bsd errno
|
|
|
|
}
|
|
|
|
|
2018-03-25 11:41:00 +02:00
|
|
|
void BSD::Connect(Kernel::HLERequestContext& ctx) {
|
2018-01-18 20:35:03 +01:00
|
|
|
LOG_WARNING(Service, "(STUBBED) called");
|
|
|
|
|
2018-01-24 01:52:18 +01:00
|
|
|
IPC::ResponseBuilder rb{ctx, 4};
|
2018-01-18 20:35:03 +01:00
|
|
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.Push<u32>(0); // ret
|
|
|
|
rb.Push<u32>(0); // bsd errno
|
|
|
|
}
|
|
|
|
|
2018-03-25 11:41:00 +02:00
|
|
|
void BSD::SendTo(Kernel::HLERequestContext& ctx) {
|
2018-01-18 20:35:03 +01:00
|
|
|
LOG_WARNING(Service, "(STUBBED) called");
|
|
|
|
|
2018-01-24 01:52:18 +01:00
|
|
|
IPC::ResponseBuilder rb{ctx, 4};
|
2018-01-18 20:35:03 +01:00
|
|
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.Push<u32>(0); // ret
|
|
|
|
rb.Push<u32>(0); // bsd errno
|
|
|
|
}
|
|
|
|
|
2018-03-25 11:41:00 +02:00
|
|
|
void BSD::Close(Kernel::HLERequestContext& ctx) {
|
2018-01-30 07:29:47 +01:00
|
|
|
LOG_WARNING(Service, "(STUBBED) called");
|
|
|
|
|
|
|
|
IPC::ResponseBuilder rb{ctx, 4};
|
|
|
|
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.Push<u32>(0); // ret
|
|
|
|
rb.Push<u32>(0); // bsd errno
|
|
|
|
}
|
|
|
|
|
2018-03-25 11:41:00 +02:00
|
|
|
BSD::BSD(const char* name) : ServiceFramework(name) {
|
|
|
|
static const FunctionInfo functions[] = {
|
|
|
|
{0, &BSD::RegisterClient, "RegisterClient"},
|
|
|
|
{1, &BSD::StartMonitoring, "StartMonitoring"},
|
|
|
|
{2, &BSD::Socket, "Socket"},
|
|
|
|
{11, &BSD::SendTo, "SendTo"},
|
|
|
|
{14, &BSD::Connect, "Connect"},
|
|
|
|
{26, &BSD::Close, "Close"},
|
|
|
|
};
|
2018-01-18 20:35:03 +01:00
|
|
|
RegisterHandlers(functions);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace Sockets
|
|
|
|
} // namespace Service
|