early-access version 4124

This commit is contained in:
pineappleEA 2024-02-09 05:47:18 +01:00
parent 3308f3bac8
commit 5a87b5c400
9 changed files with 28 additions and 16 deletions

View file

@ -1,7 +1,7 @@
yuzu emulator early access yuzu emulator early access
============= =============
This is the source code for early-access 4123. This is the source code for early-access 4124.
## Legal Notice ## Legal Notice

View file

@ -259,13 +259,20 @@ fun runGitCommand(command: List<String>): String {
} }
fun getGitVersion(): String { fun getGitVersion(): String {
val gitVersion = runGitCommand(listOf("git", "describe", "--always", "--long")) val gitVersion = runGitCommand(
listOf(
"git",
"describe",
"--always",
"--long"
)
).replace(Regex("(-0)?-[^-]+$"), "")
val versionName = if (System.getenv("GITHUB_ACTIONS") != null) { val versionName = if (System.getenv("GITHUB_ACTIONS") != null) {
System.getenv("GIT_TAG_NAME") ?: gitVersion System.getenv("GIT_TAG_NAME") ?: gitVersion
} else { } else {
gitVersion gitVersion
} }
return versionName.replace(Regex("(-0)?-[^-]+$"), "").ifEmpty { "0.0" } return versionName.ifEmpty { "0.0" }
} }
fun getGitHash(): String = fun getGitHash(): String =

View file

@ -270,7 +270,7 @@ class OutLargeData {
public: public:
static_assert(std::is_trivially_copyable_v<T>, "LargeData type must be trivially copyable"); static_assert(std::is_trivially_copyable_v<T>, "LargeData type must be trivially copyable");
static_assert((A & BufferAttr_In) == 0, "OutLargeData attr must not be In"); static_assert((A & BufferAttr_In) == 0, "OutLargeData attr must not be In");
static constexpr BufferAttr Attr = static_cast<BufferAttr>(A | BufferAttr_In | BufferAttr_FixedSize); static constexpr BufferAttr Attr = static_cast<BufferAttr>(A | BufferAttr_Out | BufferAttr_FixedSize);
using Type = T; using Type = T;
/* implicit */ OutLargeData(const OutLargeData& t) : raw(t.raw) {} /* implicit */ OutLargeData(const OutLargeData& t) : raw(t.raw) {}

View file

@ -508,13 +508,8 @@ void IHidSystemServer::RegisterAppletResourceUserId(HLERequestContext& ctx) {
Result result = GetResourceManager()->RegisterAppletResourceUserId( Result result = GetResourceManager()->RegisterAppletResourceUserId(
parameters.applet_resource_user_id, parameters.enable_input); parameters.applet_resource_user_id, parameters.enable_input);
if (result.IsSuccess()) {
// result = GetResourceManager()->GetNpad()->RegisterAppletResourceUserId(
// parameters.applet_resource_user_id);
}
IPC::ResponseBuilder rb{ctx, 2}; IPC::ResponseBuilder rb{ctx, 2};
rb.Push(ResultSuccess); rb.Push(result);
} }
void IHidSystemServer::UnregisterAppletResourceUserId(HLERequestContext& ctx) { void IHidSystemServer::UnregisterAppletResourceUserId(HLERequestContext& ctx) {
@ -524,8 +519,6 @@ void IHidSystemServer::UnregisterAppletResourceUserId(HLERequestContext& ctx) {
LOG_INFO(Service_HID, "called, applet_resource_user_id={}", applet_resource_user_id); LOG_INFO(Service_HID, "called, applet_resource_user_id={}", applet_resource_user_id);
GetResourceManager()->UnregisterAppletResourceUserId(applet_resource_user_id); GetResourceManager()->UnregisterAppletResourceUserId(applet_resource_user_id);
// GetResourceManager()->GetNpad()->UnregisterAppletResourceUserId(applet_resource_user_id);
// GetResourceManager()->GetPalma()->UnregisterAppletResourceUserId(applet_resource_user_id);
IPC::ResponseBuilder rb{ctx, 2}; IPC::ResponseBuilder rb{ctx, 2};
rb.Push(ResultSuccess); rb.Push(ResultSuccess);

View file

@ -314,6 +314,7 @@ void ResourceManager::UnregisterAppletResourceUserId(u64 aruid) {
std::scoped_lock lock{shared_mutex}; std::scoped_lock lock{shared_mutex};
applet_resource->UnregisterAppletResourceUserId(aruid); applet_resource->UnregisterAppletResourceUserId(aruid);
npad->UnregisterAppletResourceUserId(aruid); npad->UnregisterAppletResourceUserId(aruid);
// palma->UnregisterAppletResourceUserId(aruid);
} }
Result ResourceManager::GetSharedMemoryHandle(Kernel::KSharedMemory** out_handle, u64 aruid) { Result ResourceManager::GetSharedMemoryHandle(Kernel::KSharedMemory** out_handle, u64 aruid) {
@ -324,6 +325,7 @@ Result ResourceManager::GetSharedMemoryHandle(Kernel::KSharedMemory** out_handle
void ResourceManager::FreeAppletResourceId(u64 aruid) { void ResourceManager::FreeAppletResourceId(u64 aruid) {
std::scoped_lock lock{shared_mutex}; std::scoped_lock lock{shared_mutex};
applet_resource->FreeAppletResourceId(aruid); applet_resource->FreeAppletResourceId(aruid);
npad->FreeAppletResourceId(aruid);
} }
void ResourceManager::EnableInput(u64 aruid, bool is_enabled) { void ResourceManager::EnableInput(u64 aruid, bool is_enabled) {

View file

@ -117,6 +117,10 @@ Result NPad::ActivateNpadResource(u64 aruid) {
return npad_resource.Activate(aruid); return npad_resource.Activate(aruid);
} }
void NPad::FreeAppletResourceId(u64 aruid) {
return npad_resource.FreeAppletResourceId(aruid);
}
void NPad::ControllerUpdate(Core::HID::ControllerTriggerType type, std::size_t controller_idx) { void NPad::ControllerUpdate(Core::HID::ControllerTriggerType type, std::size_t controller_idx) {
if (type == Core::HID::ControllerTriggerType::All) { if (type == Core::HID::ControllerTriggerType::All) {
ControllerUpdate(Core::HID::ControllerTriggerType::Connected, controller_idx); ControllerUpdate(Core::HID::ControllerTriggerType::Connected, controller_idx);

View file

@ -58,6 +58,8 @@ public:
Result ActivateNpadResource(); Result ActivateNpadResource();
Result ActivateNpadResource(u64 aruid); Result ActivateNpadResource(u64 aruid);
void FreeAppletResourceId(u64 aruid);
// When the controller is requesting an update for the shared memory // When the controller is requesting an update for the shared memory
void OnUpdate(const Core::Timing::CoreTiming& core_timing); void OnUpdate(const Core::Timing::CoreTiming& core_timing);

View file

@ -67,7 +67,7 @@ Result NPadResource::RegisterAppletResourceUserId(u64 aruid) {
void NPadResource::UnregisterAppletResourceUserId(u64 aruid) { void NPadResource::UnregisterAppletResourceUserId(u64 aruid) {
const u64 aruid_index = GetIndexFromAruid(aruid); const u64 aruid_index = GetIndexFromAruid(aruid);
DestroyStyleSetUpdateEvents(aruid); FreeAppletResourceId(aruid);
if (aruid_index < AruidIndexMax) { if (aruid_index < AruidIndexMax) {
state[aruid_index] = {}; state[aruid_index] = {};
registration_list.flag[aruid_index] = RegistrationStatus::PendingDelete; registration_list.flag[aruid_index] = RegistrationStatus::PendingDelete;
@ -80,14 +80,18 @@ void NPadResource::UnregisterAppletResourceUserId(u64 aruid) {
} }
} }
void NPadResource::DestroyStyleSetUpdateEvents(u64 aruid) { void NPadResource::FreeAppletResourceId(u64 aruid) {
const u64 aruid_index = GetIndexFromAruid(aruid); const u64 aruid_index = GetIndexFromAruid(aruid);
if (aruid_index >= AruidIndexMax) { if (aruid_index >= AruidIndexMax) {
return; return;
} }
for (auto& controller_state : state[aruid_index].controller_state) { auto& aruid_data = state[aruid_index];
aruid_data.flag.is_assigned.Assign(false);
for (auto& controller_state : aruid_data.controller_state) {
if (!controller_state.is_styleset_update_event_initialized) { if (!controller_state.is_styleset_update_event_initialized) {
continue; continue;
} }

View file

@ -55,7 +55,7 @@ public:
Result RegisterAppletResourceUserId(u64 aruid); Result RegisterAppletResourceUserId(u64 aruid);
void UnregisterAppletResourceUserId(u64 aruid); void UnregisterAppletResourceUserId(u64 aruid);
void DestroyStyleSetUpdateEvents(u64 aruid); void FreeAppletResourceId(u64 aruid);
Result Activate(u64 aruid); Result Activate(u64 aruid);
Result Activate(); Result Activate();