mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-03 11:11:14 +00:00
ams_mitm: implement hid mitm
This commit is contained in:
parent
9c68bea16c
commit
5228768841
7 changed files with 196 additions and 8 deletions
27
stratosphere/ams_mitm/source/hid_mitm/hid_mitm_service.cpp
Normal file
27
stratosphere/ams_mitm/source/hid_mitm/hid_mitm_service.cpp
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018-2019 Atmosphère-NX
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms and conditions of the GNU General Public License,
|
||||||
|
* version 2, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
#include "hid_mitm_service.hpp"
|
||||||
|
#include "hid_shim.h"
|
||||||
|
|
||||||
|
namespace ams::mitm::hid {
|
||||||
|
|
||||||
|
Result HidMitmService::SetSupportedNpadStyleSet(const sf::ClientAppletResourceUserId &client_aruid, u32 style_set) {
|
||||||
|
/* This code applies only to hbl, guaranteed by the check in ShouldMitm. */
|
||||||
|
style_set |= TYPE_SYSTEM | TYPE_SYSTEM_EXT;
|
||||||
|
return hidSetSupportedNpadStyleSetFwd(this->forward_service.get(), static_cast<u64>(this->client_info.process_id), static_cast<u64>(client_aruid.GetValue()), static_cast<HidControllerType>(style_set));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -22,20 +22,24 @@ namespace ams::mitm::hid {
|
||||||
class HidMitmService : public sf::IMitmServiceObject {
|
class HidMitmService : public sf::IMitmServiceObject {
|
||||||
private:
|
private:
|
||||||
enum class CommandId {
|
enum class CommandId {
|
||||||
/* TODO */
|
SetSupportedNpadStyleSet = 100,
|
||||||
};
|
};
|
||||||
public:
|
public:
|
||||||
static bool ShouldMitm(const sm::MitmProcessInfo &client_info) {
|
static bool ShouldMitm(const sm::MitmProcessInfo &client_info) {
|
||||||
/* TODO */
|
/* TODO: Remove in Atmosphere 0.10.1. */
|
||||||
return false;
|
/* We will mitm:
|
||||||
|
* - hbl, to help homebrew not need to be recompiled.
|
||||||
|
*/
|
||||||
|
return client_info.override_status.IsHbl();
|
||||||
}
|
}
|
||||||
public:
|
public:
|
||||||
SF_MITM_SERVICE_OBJECT_CTOR(HidMitmService) { /* ... */ }
|
SF_MITM_SERVICE_OBJECT_CTOR(HidMitmService) { /* ... */ }
|
||||||
protected:
|
protected:
|
||||||
/* TODO */
|
/* Overridden commands. */
|
||||||
|
Result SetSupportedNpadStyleSet(const sf::ClientAppletResourceUserId &client_aruid, u32 style_set);
|
||||||
public:
|
public:
|
||||||
DEFINE_SERVICE_DISPATCH_TABLE {
|
DEFINE_SERVICE_DISPATCH_TABLE {
|
||||||
/* TODO */
|
MAKE_SERVICE_COMMAND_META(SetSupportedNpadStyleSet),
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
27
stratosphere/ams_mitm/source/hid_mitm/hid_shim.c
Normal file
27
stratosphere/ams_mitm/source/hid_mitm/hid_shim.c
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018-2019 Atmosphère-NX
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms and conditions of the GNU General Public License,
|
||||||
|
* version 2, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
#include "hid_shim.h"
|
||||||
|
#include <stratosphere/sf/sf_mitm_dispatch.h>
|
||||||
|
|
||||||
|
/* Command forwarders. */
|
||||||
|
Result hidSetSupportedNpadStyleSetFwd(Service* s, u64 process_id, u64 aruid, HidControllerType type) {
|
||||||
|
const struct {
|
||||||
|
u32 type;
|
||||||
|
u32 pad;
|
||||||
|
u64 aruid;
|
||||||
|
} in = { type, 0, aruid };
|
||||||
|
return serviceMitmDispatchIn(s, 100, in, .in_send_pid = true, .override_pid = process_id);
|
||||||
|
}
|
19
stratosphere/ams_mitm/source/hid_mitm/hid_shim.h
Normal file
19
stratosphere/ams_mitm/source/hid_mitm/hid_shim.h
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
/**
|
||||||
|
* @file hid_shim.h
|
||||||
|
* @brief Human Interface Devices Services (hid) IPC wrapper.
|
||||||
|
* @author SciresM
|
||||||
|
* @copyright libnx Authors
|
||||||
|
*/
|
||||||
|
#pragma once
|
||||||
|
#include <switch.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Command forwarders. */
|
||||||
|
Result hidSetSupportedNpadStyleSetFwd(Service* s, u64 process_id, u64 aruid, HidControllerType type);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
|
@ -25,3 +25,5 @@
|
||||||
#include "sf/impl/sf_impl_command_serialization.hpp"
|
#include "sf/impl/sf_impl_command_serialization.hpp"
|
||||||
|
|
||||||
#include "sf/hipc/sf_hipc_server_manager.hpp"
|
#include "sf/hipc/sf_hipc_server_manager.hpp"
|
||||||
|
|
||||||
|
#include "sf/sf_mitm_dispatch.h"
|
||||||
|
|
|
@ -0,0 +1,100 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018-2019 Atmosphère-NX
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms and conditions of the GNU General Public License,
|
||||||
|
* version 2, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
#pragma once
|
||||||
|
#include <switch.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
Handle target_session;
|
||||||
|
u32 context;
|
||||||
|
|
||||||
|
SfBufferAttrs buffer_attrs;
|
||||||
|
SfBuffer buffers[8];
|
||||||
|
|
||||||
|
bool in_send_pid;
|
||||||
|
|
||||||
|
u32 in_num_objects;
|
||||||
|
const Service* in_objects[8];
|
||||||
|
|
||||||
|
u32 in_num_handles;
|
||||||
|
Handle in_handles[8];
|
||||||
|
|
||||||
|
u32 out_num_objects;
|
||||||
|
Service* out_objects;
|
||||||
|
|
||||||
|
SfOutHandleAttrs out_handle_attrs;
|
||||||
|
Handle* out_handles;
|
||||||
|
|
||||||
|
u64 override_pid;
|
||||||
|
} SfMitmDispatchParams;
|
||||||
|
|
||||||
|
NX_INLINE Result serviceMitmDispatchImpl(
|
||||||
|
Service* s, u32 request_id,
|
||||||
|
const void* in_data, u32 in_data_size,
|
||||||
|
void* out_data, u32 out_data_size,
|
||||||
|
SfMitmDispatchParams disp
|
||||||
|
)
|
||||||
|
{
|
||||||
|
// Make a copy of the service struct, so that the compiler can assume that it won't be modified by function calls.
|
||||||
|
Service srv = *s;
|
||||||
|
|
||||||
|
void* in = serviceMakeRequest(&srv, request_id, disp.context,
|
||||||
|
in_data_size, disp.in_send_pid,
|
||||||
|
disp.buffer_attrs, disp.buffers,
|
||||||
|
disp.in_num_objects, disp.in_objects,
|
||||||
|
disp.in_num_handles, disp.in_handles);
|
||||||
|
|
||||||
|
if (in_data_size)
|
||||||
|
__builtin_memcpy(in, in_data, in_data_size);
|
||||||
|
|
||||||
|
if (disp.in_send_pid && disp.override_pid) {
|
||||||
|
const u64 pid = (disp.override_pid & 0x0000FFFFFFFFFFFFul) | 0xFFFE000000000000ul;
|
||||||
|
__builtin_memcpy((u8 *)armGetTls() + 0xC, &pid, sizeof(pid));
|
||||||
|
}
|
||||||
|
|
||||||
|
Result rc = svcSendSyncRequest(disp.target_session == INVALID_HANDLE ? s->session : disp.target_session);
|
||||||
|
if (R_SUCCEEDED(rc)) {
|
||||||
|
void* out = NULL;
|
||||||
|
rc = serviceParseResponse(&srv,
|
||||||
|
out_data_size, &out,
|
||||||
|
disp.out_num_objects, disp.out_objects,
|
||||||
|
disp.out_handle_attrs, disp.out_handles);
|
||||||
|
|
||||||
|
if (R_SUCCEEDED(rc) && out_data && out_data_size)
|
||||||
|
__builtin_memcpy(out_data, out, out_data_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define serviceMitmDispatch(_s,_rid,...) \
|
||||||
|
serviceMitmDispatchImpl((_s),(_rid),NULL,0,NULL,0,(SfMitmDispatchParams){ __VA_ARGS__ })
|
||||||
|
|
||||||
|
#define serviceMitmDispatchIn(_s,_rid,_in,...) \
|
||||||
|
serviceMitmDispatchImpl((_s),(_rid),&(_in),sizeof(_in),NULL,0,(SfMitmDispatchParams){ __VA_ARGS__ })
|
||||||
|
|
||||||
|
#define serviceMitmDispatchOut(_s,_rid,_out,...) \
|
||||||
|
serviceMitmDispatchImpl((_s),(_rid),NULL,0,&(_out),sizeof(_out),(SfMitmDispatchParams){ __VA_ARGS__ })
|
||||||
|
|
||||||
|
#define serviceMitmDispatchInOut(_s,_rid,_in,_out,...) \
|
||||||
|
serviceMitmDispatchImpl((_s),(_rid),&(_in),sizeof(_in),&(_out),sizeof(_out),(SfMitmDispatchParams){ __VA_ARGS__ })
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
|
@ -114,9 +114,18 @@ Result smAtmosphereMitmAcknowledgeSession(Service *srv_out, void *_out, SmServic
|
||||||
u64 keys_held;
|
u64 keys_held;
|
||||||
u64 flags;
|
u64 flags;
|
||||||
} *out = _out;
|
} *out = _out;
|
||||||
|
_Static_assert(sizeof(*out) == 0x20, "sizeof(*out) == 0x20");
|
||||||
|
|
||||||
return serviceDispatchInOut(&g_smAtmosphereMitmSrv, 65003, name, *out,
|
Handle tmp_handle;
|
||||||
.out_num_objects = 1,
|
|
||||||
.out_objects = srv_out,
|
Result rc = serviceDispatchInOut(&g_smAtmosphereMitmSrv, 65003, name, *out,
|
||||||
|
.out_handle_attrs = { SfOutHandleAttr_HipcMove },
|
||||||
|
.out_handles = &tmp_handle,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if (R_SUCCEEDED(rc)) {
|
||||||
|
serviceCreate(srv_out, tmp_handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue