2019-03-26 01:31:16 +01:00
|
|
|
// Copyright 2019 yuzu Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include "common/string_util.h"
|
|
|
|
#include "core/hle/ipc_helpers.h"
|
|
|
|
#include "core/hle/service/service.h"
|
|
|
|
#include "core/hle/service/sm/sm.h"
|
|
|
|
#include "yuzu_tester/service/yuzutest.h"
|
|
|
|
|
|
|
|
namespace Service::Yuzu {
|
|
|
|
|
2019-04-05 00:05:57 +02:00
|
|
|
constexpr u64 SERVICE_VERSION = 0x00000002;
|
2019-03-26 01:31:16 +01:00
|
|
|
|
|
|
|
class YuzuTest final : public ServiceFramework<YuzuTest> {
|
|
|
|
public:
|
2019-04-05 00:05:57 +02:00
|
|
|
explicit YuzuTest(std::string data,
|
|
|
|
std::function<void(std::vector<TestResult>)> finish_callback)
|
2019-03-26 01:31:16 +01:00
|
|
|
: ServiceFramework{"yuzutest"}, data(std::move(data)),
|
|
|
|
finish_callback(std::move(finish_callback)) {
|
|
|
|
static const FunctionInfo functions[] = {
|
|
|
|
{0, &YuzuTest::Initialize, "Initialize"},
|
|
|
|
{1, &YuzuTest::GetServiceVersion, "GetServiceVersion"},
|
|
|
|
{2, &YuzuTest::GetData, "GetData"},
|
2019-04-05 00:05:57 +02:00
|
|
|
{10, &YuzuTest::StartIndividual, "StartIndividual"},
|
|
|
|
{20, &YuzuTest::FinishIndividual, "FinishIndividual"},
|
|
|
|
{100, &YuzuTest::ExitProgram, "ExitProgram"},
|
2019-03-26 01:31:16 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
RegisterHandlers(functions);
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
void Initialize(Kernel::HLERequestContext& ctx) {
|
|
|
|
LOG_DEBUG(Frontend, "called");
|
|
|
|
IPC::ResponseBuilder rb{ctx, 2};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetServiceVersion(Kernel::HLERequestContext& ctx) {
|
|
|
|
LOG_DEBUG(Frontend, "called");
|
|
|
|
IPC::ResponseBuilder rb{ctx, 4};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.Push(SERVICE_VERSION);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetData(Kernel::HLERequestContext& ctx) {
|
|
|
|
LOG_DEBUG(Frontend, "called");
|
|
|
|
const auto size = ctx.GetWriteBufferSize();
|
|
|
|
const auto write_size = std::min(size, data.size());
|
|
|
|
ctx.WriteBuffer(data.data(), write_size);
|
|
|
|
|
|
|
|
IPC::ResponseBuilder rb{ctx, 3};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.Push<u32>(write_size);
|
|
|
|
}
|
|
|
|
|
2019-04-05 00:05:57 +02:00
|
|
|
void StartIndividual(Kernel::HLERequestContext& ctx) {
|
|
|
|
LOG_DEBUG(Frontend, "called");
|
2019-03-26 01:31:16 +01:00
|
|
|
|
|
|
|
IPC::ResponseBuilder rb{ctx, 2};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
}
|
|
|
|
|
2019-04-05 00:05:57 +02:00
|
|
|
void FinishIndividual(Kernel::HLERequestContext& ctx) {
|
2019-03-26 01:31:16 +01:00
|
|
|
IPC::RequestParser rp{ctx};
|
|
|
|
|
2019-04-05 00:05:57 +02:00
|
|
|
const auto code = rp.PopRaw<u32>();
|
|
|
|
|
|
|
|
const auto result_data_raw = ctx.ReadBuffer();
|
|
|
|
const auto test_name_raw = ctx.ReadBuffer(1);
|
|
|
|
|
|
|
|
const auto data = Common::StringFromFixedZeroTerminatedBuffer(
|
|
|
|
reinterpret_cast<const char*>(result_data_raw.data()), result_data_raw.size());
|
|
|
|
const auto test_name = Common::StringFromFixedZeroTerminatedBuffer(
|
|
|
|
reinterpret_cast<const char*>(test_name_raw.data()), test_name_raw.size());
|
|
|
|
|
|
|
|
LOG_INFO(Frontend, "called, result_code={:08X}, data={}, name={}", code, data, test_name);
|
|
|
|
|
|
|
|
results.push_back({code, data, test_name});
|
2019-03-26 01:31:16 +01:00
|
|
|
|
|
|
|
IPC::ResponseBuilder rb{ctx, 2};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
}
|
|
|
|
|
2019-04-05 00:05:57 +02:00
|
|
|
void ExitProgram(Kernel::HLERequestContext& ctx) {
|
2019-03-26 01:31:16 +01:00
|
|
|
LOG_DEBUG(Frontend, "called");
|
|
|
|
|
|
|
|
IPC::ResponseBuilder rb{ctx, 2};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
|
2019-04-05 00:05:57 +02:00
|
|
|
finish_callback(results);
|
2019-03-26 01:31:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
std::string data;
|
|
|
|
|
2019-04-05 00:05:57 +02:00
|
|
|
std::vector<TestResult> results;
|
|
|
|
std::function<void(std::vector<TestResult>)> finish_callback;
|
2019-03-26 01:31:16 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
void InstallInterfaces(SM::ServiceManager& sm, std::string data,
|
2019-04-05 00:05:57 +02:00
|
|
|
std::function<void(std::vector<TestResult>)> finish_callback) {
|
2019-03-26 01:31:16 +01:00
|
|
|
std::make_shared<YuzuTest>(data, finish_callback)->InstallAsService(sm);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace Service::Yuzu
|