2018-03-29 18:06:51 -07:00
|
|
|
// Copyright 2018 yuzu emulator team
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#include "common/logging/log.h"
|
|
|
|
#include "core/hle/ipc_helpers.h"
|
2018-06-04 02:27:32 -07:00
|
|
|
#include "core/hle/kernel/event.h"
|
2018-06-04 04:43:02 -07:00
|
|
|
#include "core/hle/service/hid/hid.h"
|
2018-03-29 18:06:51 -07:00
|
|
|
#include "core/hle/service/nfp/nfp.h"
|
|
|
|
#include "core/hle/service/nfp/nfp_user.h"
|
|
|
|
|
2018-04-19 18:41:44 -07:00
|
|
|
namespace Service::NFP {
|
2018-03-29 18:06:51 -07:00
|
|
|
|
|
|
|
Module::Interface::Interface(std::shared_ptr<Module> module, const char* name)
|
|
|
|
: ServiceFramework(name), module(std::move(module)) {}
|
|
|
|
|
2018-04-21 22:04:24 -07:00
|
|
|
class IUser final : public ServiceFramework<IUser> {
|
|
|
|
public:
|
|
|
|
IUser() : ServiceFramework("IUser") {
|
|
|
|
static const FunctionInfo functions[] = {
|
|
|
|
{0, &IUser::Initialize, "Initialize"},
|
2018-05-13 03:08:58 -07:00
|
|
|
{1, nullptr, "Finalize"},
|
2018-06-04 02:27:32 -07:00
|
|
|
{2, &IUser::ListDevices, "ListDevices"},
|
2018-05-13 03:08:58 -07:00
|
|
|
{3, nullptr, "StartDetection"},
|
|
|
|
{4, nullptr, "StopDetection"},
|
|
|
|
{5, nullptr, "Mount"},
|
|
|
|
{6, nullptr, "Unmount"},
|
|
|
|
{7, nullptr, "OpenApplicationArea"},
|
|
|
|
{8, nullptr, "GetApplicationArea"},
|
|
|
|
{9, nullptr, "SetApplicationArea"},
|
|
|
|
{10, nullptr, "Flush"},
|
|
|
|
{11, nullptr, "Restore"},
|
|
|
|
{12, nullptr, "CreateApplicationArea"},
|
|
|
|
{13, nullptr, "GetTagInfo"},
|
|
|
|
{14, nullptr, "GetRegisterInfo"},
|
|
|
|
{15, nullptr, "GetCommonInfo"},
|
|
|
|
{16, nullptr, "GetModelInfo"},
|
2018-06-04 02:27:32 -07:00
|
|
|
{17, &IUser::AttachActivateEvent, "AttachActivateEvent"},
|
|
|
|
{18, &IUser::AttachDeactivateEvent, "AttachDeactivateEvent"},
|
|
|
|
{19, &IUser::GetState, "GetState"},
|
|
|
|
{20, &IUser::GetDeviceState, "GetDeviceState"},
|
|
|
|
{21, &IUser::GetNpadId, "GetNpadId"},
|
2018-05-13 03:08:58 -07:00
|
|
|
{22, nullptr, "GetApplicationArea2"},
|
2018-06-04 07:51:52 -07:00
|
|
|
{23, &IUser::AttachAvailabilityChangeEvent, "AttachAvailabilityChangeEvent"},
|
2018-05-13 03:08:58 -07:00
|
|
|
{24, nullptr, "RecreateApplicationArea"},
|
2018-04-21 22:04:24 -07:00
|
|
|
};
|
|
|
|
RegisterHandlers(functions);
|
2018-06-04 02:27:32 -07:00
|
|
|
|
|
|
|
activate_event = Kernel::Event::Create(Kernel::ResetType::OneShot, "IUser:ActivateEvent");
|
|
|
|
deactivate_event =
|
|
|
|
Kernel::Event::Create(Kernel::ResetType::OneShot, "IUser:DeactivateEvent");
|
2018-06-04 07:51:52 -07:00
|
|
|
availability_change_event =
|
|
|
|
Kernel::Event::Create(Kernel::ResetType::OneShot, "IUser:AvailabilityChangeEvent");
|
2018-04-21 22:04:24 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2018-06-04 02:27:32 -07:00
|
|
|
enum class State : u32 {
|
|
|
|
NonInitialized = 0,
|
|
|
|
Initialized = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum class DeviceState : u32 {
|
|
|
|
Initialized = 0,
|
|
|
|
};
|
|
|
|
|
2018-04-21 22:04:24 -07:00
|
|
|
void Initialize(Kernel::HLERequestContext& ctx) {
|
2018-07-02 09:13:26 -07:00
|
|
|
LOG_WARNING(Service_NFP, "(STUBBED) called");
|
2018-06-04 02:27:32 -07:00
|
|
|
|
|
|
|
state = State::Initialized;
|
|
|
|
|
2018-04-21 22:04:24 -07:00
|
|
|
IPC::ResponseBuilder rb{ctx, 2};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
}
|
2018-06-04 02:27:32 -07:00
|
|
|
|
|
|
|
void ListDevices(Kernel::HLERequestContext& ctx) {
|
2018-06-04 04:43:02 -07:00
|
|
|
IPC::RequestParser rp{ctx};
|
|
|
|
const u32 array_size = rp.Pop<u32>();
|
|
|
|
|
|
|
|
ctx.WriteBuffer(&device_handle, sizeof(device_handle));
|
|
|
|
|
2018-07-02 09:13:26 -07:00
|
|
|
LOG_WARNING(Service_NFP, "(STUBBED) called, array_size={}", array_size);
|
2018-06-04 04:43:02 -07:00
|
|
|
|
2018-06-04 02:27:32 -07:00
|
|
|
IPC::ResponseBuilder rb{ctx, 3};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
2018-06-04 07:51:52 -07:00
|
|
|
rb.Push<u32>(0);
|
2018-06-04 02:27:32 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void AttachActivateEvent(Kernel::HLERequestContext& ctx) {
|
2018-06-04 07:51:52 -07:00
|
|
|
IPC::RequestParser rp{ctx};
|
|
|
|
const u64 dev_handle = rp.Pop<u64>();
|
2018-07-02 09:13:26 -07:00
|
|
|
LOG_WARNING(Service_NFP, "(STUBBED) called, dev_handle=0x{:X}", dev_handle);
|
2018-06-04 07:51:52 -07:00
|
|
|
|
2018-06-04 02:27:32 -07:00
|
|
|
IPC::ResponseBuilder rb{ctx, 2, 1};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.PushCopyObjects(activate_event);
|
|
|
|
}
|
|
|
|
|
|
|
|
void AttachDeactivateEvent(Kernel::HLERequestContext& ctx) {
|
2018-06-04 07:51:52 -07:00
|
|
|
IPC::RequestParser rp{ctx};
|
|
|
|
const u64 dev_handle = rp.Pop<u64>();
|
2018-07-02 09:13:26 -07:00
|
|
|
LOG_WARNING(Service_NFP, "(STUBBED) called, dev_handle=0x{:X}", dev_handle);
|
2018-06-04 07:51:52 -07:00
|
|
|
|
2018-06-04 02:27:32 -07:00
|
|
|
IPC::ResponseBuilder rb{ctx, 2, 1};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.PushCopyObjects(deactivate_event);
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetState(Kernel::HLERequestContext& ctx) {
|
2018-07-02 09:13:26 -07:00
|
|
|
LOG_WARNING(Service_NFP, "(STUBBED) called");
|
2018-06-04 02:27:32 -07:00
|
|
|
IPC::ResponseBuilder rb{ctx, 3};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.Push<u32>(static_cast<u32>(state));
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetDeviceState(Kernel::HLERequestContext& ctx) {
|
2018-07-02 09:13:26 -07:00
|
|
|
LOG_WARNING(Service_NFP, "(STUBBED) called");
|
2018-06-04 02:27:32 -07:00
|
|
|
IPC::ResponseBuilder rb{ctx, 3};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.Push<u32>(static_cast<u32>(device_state));
|
|
|
|
}
|
|
|
|
|
|
|
|
void GetNpadId(Kernel::HLERequestContext& ctx) {
|
2018-06-04 04:43:02 -07:00
|
|
|
IPC::RequestParser rp{ctx};
|
|
|
|
const u64 dev_handle = rp.Pop<u64>();
|
2018-07-02 09:13:26 -07:00
|
|
|
LOG_WARNING(Service_NFP, "(STUBBED) called, dev_handle=0x{:X}", dev_handle);
|
2018-06-04 02:27:32 -07:00
|
|
|
IPC::ResponseBuilder rb{ctx, 3};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
2018-06-04 04:43:02 -07:00
|
|
|
rb.Push<u32>(npad_id);
|
2018-06-04 02:27:32 -07:00
|
|
|
}
|
|
|
|
|
2018-06-04 07:51:52 -07:00
|
|
|
void AttachAvailabilityChangeEvent(Kernel::HLERequestContext& ctx) {
|
|
|
|
IPC::RequestParser rp{ctx};
|
|
|
|
const u64 dev_handle = rp.Pop<u64>();
|
2018-07-02 09:13:26 -07:00
|
|
|
LOG_WARNING(Service_NFP, "(STUBBED) called, dev_handle=0x{:X}", dev_handle);
|
2018-06-04 07:51:52 -07:00
|
|
|
|
|
|
|
IPC::ResponseBuilder rb{ctx, 2, 1};
|
|
|
|
rb.Push(RESULT_SUCCESS);
|
|
|
|
rb.PushCopyObjects(availability_change_event);
|
|
|
|
}
|
|
|
|
|
2018-06-04 04:43:02 -07:00
|
|
|
const u64 device_handle{0xDEAD};
|
|
|
|
const HID::ControllerID npad_id{HID::Controller_Player1};
|
2018-06-04 02:27:32 -07:00
|
|
|
State state{State::NonInitialized};
|
|
|
|
DeviceState device_state{DeviceState::Initialized};
|
|
|
|
Kernel::SharedPtr<Kernel::Event> activate_event;
|
|
|
|
Kernel::SharedPtr<Kernel::Event> deactivate_event;
|
2018-06-04 07:51:52 -07:00
|
|
|
Kernel::SharedPtr<Kernel::Event> availability_change_event;
|
2018-04-21 22:04:24 -07:00
|
|
|
};
|
|
|
|
|
2018-04-22 19:02:18 -07:00
|
|
|
void Module::Interface::CreateUserInterface(Kernel::HLERequestContext& ctx) {
|
2018-07-02 09:13:26 -07:00
|
|
|
LOG_DEBUG(Service_NFP, "called");
|
2018-04-21 22:04:24 -07:00
|
|
|
IPC::ResponseBuilder rb{ctx, 2, 0, 1};
|
2018-03-29 18:06:51 -07:00
|
|
|
rb.Push(RESULT_SUCCESS);
|
2018-04-21 22:04:24 -07:00
|
|
|
rb.PushIpcInterface<IUser>();
|
2018-03-29 18:06:51 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void InstallInterfaces(SM::ServiceManager& service_manager) {
|
|
|
|
auto module = std::make_shared<Module>();
|
|
|
|
std::make_shared<NFP_User>(module)->InstallAsService(service_manager);
|
|
|
|
}
|
|
|
|
|
2018-04-19 18:41:44 -07:00
|
|
|
} // namespace Service::NFP
|