Compare commits
16 Commits
android-14
...
android-14
Author | SHA1 | Date | |
---|---|---|---|
efff6adeeb | |||
d93b530ac8 | |||
f21340f7aa | |||
e0c894408a | |||
257a1c884d | |||
c100d7e802 | |||
4ce6762945 | |||
fe3702223f | |||
83aa66b17d | |||
8d7a55be5b | |||
de58618421 | |||
e6847c65a8 | |||
b5bde8451c | |||
2d4e7c8264 | |||
50bcfa5fb9 | |||
efc50485b8 |
@ -290,6 +290,7 @@ find_package(lz4 REQUIRED)
|
|||||||
find_package(nlohmann_json 3.8 REQUIRED)
|
find_package(nlohmann_json 3.8 REQUIRED)
|
||||||
find_package(Opus 1.3 MODULE)
|
find_package(Opus 1.3 MODULE)
|
||||||
find_package(RenderDoc MODULE)
|
find_package(RenderDoc MODULE)
|
||||||
|
find_package(SimpleIni MODULE)
|
||||||
find_package(stb MODULE)
|
find_package(stb MODULE)
|
||||||
find_package(VulkanMemoryAllocator CONFIG)
|
find_package(VulkanMemoryAllocator CONFIG)
|
||||||
find_package(ZLIB 1.2 REQUIRED)
|
find_package(ZLIB 1.2 REQUIRED)
|
||||||
|
19
CMakeModules/FindSimpleIni.cmake
Normal file
19
CMakeModules/FindSimpleIni.cmake
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
# SPDX-FileCopyrightText: 2023 Alexandre Bouvier <contact@amb.tf>
|
||||||
|
#
|
||||||
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
|
find_path(SimpleIni_INCLUDE_DIR SimpleIni.h)
|
||||||
|
|
||||||
|
include(FindPackageHandleStandardArgs)
|
||||||
|
find_package_handle_standard_args(SimpleIni
|
||||||
|
REQUIRED_VARS SimpleIni_INCLUDE_DIR
|
||||||
|
)
|
||||||
|
|
||||||
|
if (SimpleIni_FOUND AND NOT TARGET SimpleIni::SimpleIni)
|
||||||
|
add_library(SimpleIni::SimpleIni INTERFACE IMPORTED)
|
||||||
|
set_target_properties(SimpleIni::SimpleIni PROPERTIES
|
||||||
|
INTERFACE_INCLUDE_DIRECTORIES "${SimpleIni_INCLUDE_DIR}"
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
mark_as_advanced(SimpleIni_INCLUDE_DIR)
|
@ -1,7 +1,6 @@
|
|||||||
| Pull Request | Commit | Title | Author | Merged? |
|
| Pull Request | Commit | Title | Author | Merged? |
|
||||||
|----|----|----|----|----|
|
|----|----|----|----|----|
|
||||||
| [11535](https://github.com/yuzu-emu/yuzu//pull/11535) | [`50bcfa5fb`](https://github.com/yuzu-emu/yuzu//pull/11535/files) | renderer_vulkan: Introduce separate cmd buffer for uploads | [GPUCode](https://github.com/GPUCode/) | Yes |
|
| [12074](https://github.com/yuzu-emu/yuzu//pull/12074) | [`15f35b865`](https://github.com/yuzu-emu/yuzu//pull/12074/files) | Implement Native Code Execution (NCE) | [GPUCode](https://github.com/GPUCode/) | Yes |
|
||||||
| [12074](https://github.com/yuzu-emu/yuzu//pull/12074) | [`643250874`](https://github.com/yuzu-emu/yuzu//pull/12074/files) | Implement Native Code Execution (NCE) | [GPUCode](https://github.com/GPUCode/) | Yes |
|
|
||||||
|
|
||||||
|
|
||||||
End of merge log. You can find the original README.md below the break.
|
End of merge log. You can find the original README.md below the break.
|
||||||
|
4
externals/CMakeLists.txt
vendored
4
externals/CMakeLists.txt
vendored
@ -296,4 +296,6 @@ if (YUZU_CRASH_DUMPS AND NOT TARGET libbreakpad_client)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
# SimpleIni
|
# SimpleIni
|
||||||
add_subdirectory(simpleini)
|
if (NOT TARGET SimpleIni::SimpleIni)
|
||||||
|
add_subdirectory(simpleini)
|
||||||
|
endif()
|
||||||
|
@ -27,6 +27,8 @@ object InputHandler {
|
|||||||
0x054C -> getInputDS5ButtonKey(event.keyCode)
|
0x054C -> getInputDS5ButtonKey(event.keyCode)
|
||||||
0x057E -> getInputJoyconButtonKey(event.keyCode)
|
0x057E -> getInputJoyconButtonKey(event.keyCode)
|
||||||
0x1532 -> getInputRazerButtonKey(event.keyCode)
|
0x1532 -> getInputRazerButtonKey(event.keyCode)
|
||||||
|
0x3537 -> getInputRedmagicButtonKey(event.keyCode)
|
||||||
|
0x358A -> getInputBackboneLabsButtonKey(event.keyCode)
|
||||||
else -> getInputGenericButtonKey(event.keyCode)
|
else -> getInputGenericButtonKey(event.keyCode)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -227,6 +229,42 @@ object InputHandler {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun getInputRedmagicButtonKey(key: Int): Int {
|
||||||
|
return when (key) {
|
||||||
|
KeyEvent.KEYCODE_BUTTON_A -> NativeLibrary.ButtonType.BUTTON_B
|
||||||
|
KeyEvent.KEYCODE_BUTTON_B -> NativeLibrary.ButtonType.BUTTON_A
|
||||||
|
KeyEvent.KEYCODE_BUTTON_X -> NativeLibrary.ButtonType.BUTTON_Y
|
||||||
|
KeyEvent.KEYCODE_BUTTON_Y -> NativeLibrary.ButtonType.BUTTON_X
|
||||||
|
KeyEvent.KEYCODE_BUTTON_L1 -> NativeLibrary.ButtonType.TRIGGER_L
|
||||||
|
KeyEvent.KEYCODE_BUTTON_R1 -> NativeLibrary.ButtonType.TRIGGER_R
|
||||||
|
KeyEvent.KEYCODE_BUTTON_L2 -> NativeLibrary.ButtonType.TRIGGER_ZL
|
||||||
|
KeyEvent.KEYCODE_BUTTON_R2 -> NativeLibrary.ButtonType.TRIGGER_ZR
|
||||||
|
KeyEvent.KEYCODE_BUTTON_THUMBL -> NativeLibrary.ButtonType.STICK_L
|
||||||
|
KeyEvent.KEYCODE_BUTTON_THUMBR -> NativeLibrary.ButtonType.STICK_R
|
||||||
|
KeyEvent.KEYCODE_BUTTON_START -> NativeLibrary.ButtonType.BUTTON_PLUS
|
||||||
|
KeyEvent.KEYCODE_BUTTON_SELECT -> NativeLibrary.ButtonType.BUTTON_MINUS
|
||||||
|
else -> -1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun getInputBackboneLabsButtonKey(key: Int): Int {
|
||||||
|
return when (key) {
|
||||||
|
KeyEvent.KEYCODE_BUTTON_A -> NativeLibrary.ButtonType.BUTTON_B
|
||||||
|
KeyEvent.KEYCODE_BUTTON_B -> NativeLibrary.ButtonType.BUTTON_A
|
||||||
|
KeyEvent.KEYCODE_BUTTON_X -> NativeLibrary.ButtonType.BUTTON_Y
|
||||||
|
KeyEvent.KEYCODE_BUTTON_Y -> NativeLibrary.ButtonType.BUTTON_X
|
||||||
|
KeyEvent.KEYCODE_BUTTON_L1 -> NativeLibrary.ButtonType.TRIGGER_L
|
||||||
|
KeyEvent.KEYCODE_BUTTON_R1 -> NativeLibrary.ButtonType.TRIGGER_R
|
||||||
|
KeyEvent.KEYCODE_BUTTON_L2 -> NativeLibrary.ButtonType.TRIGGER_ZL
|
||||||
|
KeyEvent.KEYCODE_BUTTON_R2 -> NativeLibrary.ButtonType.TRIGGER_ZR
|
||||||
|
KeyEvent.KEYCODE_BUTTON_THUMBL -> NativeLibrary.ButtonType.STICK_L
|
||||||
|
KeyEvent.KEYCODE_BUTTON_THUMBR -> NativeLibrary.ButtonType.STICK_R
|
||||||
|
KeyEvent.KEYCODE_BUTTON_START -> NativeLibrary.ButtonType.BUTTON_PLUS
|
||||||
|
KeyEvent.KEYCODE_BUTTON_SELECT -> NativeLibrary.ButtonType.BUTTON_MINUS
|
||||||
|
else -> -1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private fun getInputGenericButtonKey(key: Int): Int {
|
private fun getInputGenericButtonKey(key: Int): Int {
|
||||||
return when (key) {
|
return when (key) {
|
||||||
KeyEvent.KEYCODE_BUTTON_A -> NativeLibrary.ButtonType.BUTTON_A
|
KeyEvent.KEYCODE_BUTTON_A -> NativeLibrary.ButtonType.BUTTON_A
|
||||||
|
@ -621,6 +621,8 @@ public:
|
|||||||
|
|
||||||
void Protect(size_t virtual_offset, size_t length, bool read, bool write, bool execute) {}
|
void Protect(size_t virtual_offset, size_t length, bool read, bool write, bool execute) {}
|
||||||
|
|
||||||
|
void EnableDirectMappedAddress() {}
|
||||||
|
|
||||||
u8* backing_base{nullptr};
|
u8* backing_base{nullptr};
|
||||||
u8* virtual_base{nullptr};
|
u8* virtual_base{nullptr};
|
||||||
};
|
};
|
||||||
|
@ -1215,7 +1215,7 @@ void KProcess::LoadModule(CodeSet code_set, KProcessAddress base_addr) {
|
|||||||
ReprotectSegment(code_set.RODataSegment(), Svc::MemoryPermission::Read);
|
ReprotectSegment(code_set.RODataSegment(), Svc::MemoryPermission::Read);
|
||||||
ReprotectSegment(code_set.DataSegment(), Svc::MemoryPermission::ReadWrite);
|
ReprotectSegment(code_set.DataSegment(), Svc::MemoryPermission::ReadWrite);
|
||||||
|
|
||||||
#ifdef ARCHITECTURE_arm64
|
#ifdef HAS_NCE
|
||||||
if (Settings::IsNceEnabled()) {
|
if (Settings::IsNceEnabled()) {
|
||||||
auto& buffer = m_kernel.System().DeviceMemory().buffer;
|
auto& buffer = m_kernel.System().DeviceMemory().buffer;
|
||||||
const auto& code = code_set.CodeSegment();
|
const auto& code = code_set.CodeSegment();
|
||||||
|
@ -122,7 +122,8 @@ void Cabinet::DisplayCompleted(bool apply_changes, std::string_view amiibo_name)
|
|||||||
Service::NFP::RegisterInfoPrivate register_info{};
|
Service::NFP::RegisterInfoPrivate register_info{};
|
||||||
std::memcpy(register_info.amiibo_name.data(), amiibo_name.data(),
|
std::memcpy(register_info.amiibo_name.data(), amiibo_name.data(),
|
||||||
std::min(amiibo_name.size(), register_info.amiibo_name.size() - 1));
|
std::min(amiibo_name.size(), register_info.amiibo_name.size() - 1));
|
||||||
|
register_info.mii_store_data.BuildRandom(Mii::Age::All, Mii::Gender::All, Mii::Race::All);
|
||||||
|
register_info.mii_store_data.SetNickname({u'y', u'u', u'z', u'u'});
|
||||||
nfp_device->SetRegisterInfoPrivate(register_info);
|
nfp_device->SetRegisterInfoPrivate(register_info);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -19,19 +19,8 @@
|
|||||||
|
|
||||||
namespace Service::Set {
|
namespace Service::Set {
|
||||||
|
|
||||||
namespace {
|
Result GetFirmwareVersionImpl(FirmwareVersionFormat& out_firmware, Core::System& system,
|
||||||
constexpr u64 SYSTEM_VERSION_FILE_MINOR_REVISION_OFFSET = 0x05;
|
GetFirmwareVersionType type) {
|
||||||
|
|
||||||
enum class GetFirmwareVersionType {
|
|
||||||
Version1,
|
|
||||||
Version2,
|
|
||||||
};
|
|
||||||
|
|
||||||
void GetFirmwareVersionImpl(Core::System& system, HLERequestContext& ctx,
|
|
||||||
GetFirmwareVersionType type) {
|
|
||||||
ASSERT_MSG(ctx.GetWriteBufferSize() == 0x100,
|
|
||||||
"FirmwareVersion output buffer must be 0x100 bytes in size!");
|
|
||||||
|
|
||||||
constexpr u64 FirmwareVersionSystemDataId = 0x0100000000000809;
|
constexpr u64 FirmwareVersionSystemDataId = 0x0100000000000809;
|
||||||
auto& fsc = system.GetFileSystemController();
|
auto& fsc = system.GetFileSystemController();
|
||||||
|
|
||||||
@ -52,39 +41,34 @@ void GetFirmwareVersionImpl(Core::System& system, HLERequestContext& ctx,
|
|||||||
FileSys::SystemArchive::SynthesizeSystemArchive(FirmwareVersionSystemDataId));
|
FileSys::SystemArchive::SynthesizeSystemArchive(FirmwareVersionSystemDataId));
|
||||||
}
|
}
|
||||||
|
|
||||||
const auto early_exit_failure = [&ctx](std::string_view desc, Result code) {
|
const auto early_exit_failure = [](std::string_view desc, Result code) {
|
||||||
LOG_ERROR(Service_SET, "General failure while attempting to resolve firmware version ({}).",
|
LOG_ERROR(Service_SET, "General failure while attempting to resolve firmware version ({}).",
|
||||||
desc);
|
desc);
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
return code;
|
||||||
rb.Push(code);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const auto ver_file = romfs->GetFile("file");
|
const auto ver_file = romfs->GetFile("file");
|
||||||
if (ver_file == nullptr) {
|
if (ver_file == nullptr) {
|
||||||
early_exit_failure("The system version archive didn't contain the file 'file'.",
|
return early_exit_failure("The system version archive didn't contain the file 'file'.",
|
||||||
FileSys::ERROR_INVALID_ARGUMENT);
|
FileSys::ERROR_INVALID_ARGUMENT);
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
auto data = ver_file->ReadAllBytes();
|
auto data = ver_file->ReadAllBytes();
|
||||||
if (data.size() != 0x100) {
|
if (data.size() != sizeof(FirmwareVersionFormat)) {
|
||||||
early_exit_failure("The system version file 'file' was not the correct size.",
|
return early_exit_failure("The system version file 'file' was not the correct size.",
|
||||||
FileSys::ERROR_OUT_OF_BOUNDS);
|
FileSys::ERROR_OUT_OF_BOUNDS);
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::memcpy(&out_firmware, data.data(), sizeof(FirmwareVersionFormat));
|
||||||
|
|
||||||
// If the command is GetFirmwareVersion (as opposed to GetFirmwareVersion2), hardware will
|
// If the command is GetFirmwareVersion (as opposed to GetFirmwareVersion2), hardware will
|
||||||
// zero out the REVISION_MINOR field.
|
// zero out the REVISION_MINOR field.
|
||||||
if (type == GetFirmwareVersionType::Version1) {
|
if (type == GetFirmwareVersionType::Version1) {
|
||||||
data[SYSTEM_VERSION_FILE_MINOR_REVISION_OFFSET] = 0;
|
out_firmware.revision_minor = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx.WriteBuffer(data);
|
return ResultSuccess;
|
||||||
|
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
|
||||||
rb.Push(ResultSuccess);
|
|
||||||
}
|
}
|
||||||
} // Anonymous namespace
|
|
||||||
|
|
||||||
void SET_SYS::SetLanguageCode(HLERequestContext& ctx) {
|
void SET_SYS::SetLanguageCode(HLERequestContext& ctx) {
|
||||||
IPC::RequestParser rp{ctx};
|
IPC::RequestParser rp{ctx};
|
||||||
@ -98,12 +82,32 @@ void SET_SYS::SetLanguageCode(HLERequestContext& ctx) {
|
|||||||
|
|
||||||
void SET_SYS::GetFirmwareVersion(HLERequestContext& ctx) {
|
void SET_SYS::GetFirmwareVersion(HLERequestContext& ctx) {
|
||||||
LOG_DEBUG(Service_SET, "called");
|
LOG_DEBUG(Service_SET, "called");
|
||||||
GetFirmwareVersionImpl(system, ctx, GetFirmwareVersionType::Version1);
|
|
||||||
|
FirmwareVersionFormat firmware_data{};
|
||||||
|
const auto result =
|
||||||
|
GetFirmwareVersionImpl(firmware_data, system, GetFirmwareVersionType::Version1);
|
||||||
|
|
||||||
|
if (result.IsSuccess()) {
|
||||||
|
ctx.WriteBuffer(firmware_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
|
rb.Push(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SET_SYS::GetFirmwareVersion2(HLERequestContext& ctx) {
|
void SET_SYS::GetFirmwareVersion2(HLERequestContext& ctx) {
|
||||||
LOG_DEBUG(Service_SET, "called");
|
LOG_DEBUG(Service_SET, "called");
|
||||||
GetFirmwareVersionImpl(system, ctx, GetFirmwareVersionType::Version2);
|
|
||||||
|
FirmwareVersionFormat firmware_data{};
|
||||||
|
const auto result =
|
||||||
|
GetFirmwareVersionImpl(firmware_data, system, GetFirmwareVersionType::Version2);
|
||||||
|
|
||||||
|
if (result.IsSuccess()) {
|
||||||
|
ctx.WriteBuffer(firmware_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
|
rb.Push(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SET_SYS::GetAccountSettings(HLERequestContext& ctx) {
|
void SET_SYS::GetAccountSettings(HLERequestContext& ctx) {
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "common/uuid.h"
|
#include "common/uuid.h"
|
||||||
|
#include "core/hle/result.h"
|
||||||
#include "core/hle/service/service.h"
|
#include "core/hle/service/service.h"
|
||||||
#include "core/hle/service/time/clock_types.h"
|
#include "core/hle/service/time/clock_types.h"
|
||||||
|
|
||||||
@ -12,6 +13,29 @@ class System;
|
|||||||
}
|
}
|
||||||
|
|
||||||
namespace Service::Set {
|
namespace Service::Set {
|
||||||
|
enum class LanguageCode : u64;
|
||||||
|
enum class GetFirmwareVersionType {
|
||||||
|
Version1,
|
||||||
|
Version2,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct FirmwareVersionFormat {
|
||||||
|
u8 major;
|
||||||
|
u8 minor;
|
||||||
|
u8 micro;
|
||||||
|
INSERT_PADDING_BYTES(1);
|
||||||
|
u8 revision_major;
|
||||||
|
u8 revision_minor;
|
||||||
|
INSERT_PADDING_BYTES(2);
|
||||||
|
std::array<char, 0x20> platform;
|
||||||
|
std::array<u8, 0x40> version_hash;
|
||||||
|
std::array<char, 0x18> display_version;
|
||||||
|
std::array<char, 0x80> display_title;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(FirmwareVersionFormat) == 0x100, "FirmwareVersionFormat is an invalid size");
|
||||||
|
|
||||||
|
Result GetFirmwareVersionImpl(FirmwareVersionFormat& out_firmware, Core::System& system,
|
||||||
|
GetFirmwareVersionType type);
|
||||||
|
|
||||||
class SET_SYS final : public ServiceFramework<SET_SYS> {
|
class SET_SYS final : public ServiceFramework<SET_SYS> {
|
||||||
public:
|
public:
|
||||||
|
@ -11,6 +11,11 @@
|
|||||||
#include "core/hle/service/time/errors.h"
|
#include "core/hle/service/time/errors.h"
|
||||||
#include "core/hle/service/time/time_zone_types.h"
|
#include "core/hle/service/time/time_zone_types.h"
|
||||||
|
|
||||||
|
// Defined by WinBase.h on Windows
|
||||||
|
#ifdef GetCurrentTime
|
||||||
|
#undef GetCurrentTime
|
||||||
|
#endif
|
||||||
|
|
||||||
namespace Service::Time::Clock {
|
namespace Service::Time::Clock {
|
||||||
|
|
||||||
enum class TimeType : u8 {
|
enum class TimeType : u8 {
|
||||||
|
@ -165,7 +165,7 @@ std::optional<VAddr> AppLoader_NSO::LoadModule(Kernel::KProcess& process, Core::
|
|||||||
patch->PatchText(program_image, code);
|
patch->PatchText(program_image, code);
|
||||||
|
|
||||||
// Add patch section size to the module size.
|
// Add patch section size to the module size.
|
||||||
image_size += patch->GetSectionSize();
|
image_size += static_cast<u32>(patch->GetSectionSize());
|
||||||
} else if (patch) {
|
} else if (patch) {
|
||||||
// Relocate code patch and copy to the program_image.
|
// Relocate code patch and copy to the program_image.
|
||||||
patch->RelocateAndCopy(load_base, code, program_image, &process.GetPostHandlers());
|
patch->RelocateAndCopy(load_base, code, program_image, &process.GetPostHandlers());
|
||||||
|
@ -7,4 +7,4 @@ add_library(frontend_common STATIC
|
|||||||
)
|
)
|
||||||
|
|
||||||
create_target_directory_groups(frontend_common)
|
create_target_directory_groups(frontend_common)
|
||||||
target_link_libraries(frontend_common PUBLIC core SimpleIni PRIVATE common Boost::headers)
|
target_link_libraries(frontend_common PUBLIC core SimpleIni::SimpleIni PRIVATE common Boost::headers)
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
#include "common/settings.h"
|
#include "common/settings.h"
|
||||||
|
|
||||||
|
#define SI_NO_CONVERSION
|
||||||
#include <SimpleIni.h>
|
#include <SimpleIni.h>
|
||||||
#include <boost/algorithm/string/replace.hpp>
|
#include <boost/algorithm/string/replace.hpp>
|
||||||
|
|
||||||
|
@ -47,6 +47,7 @@
|
|||||||
#include "core/hle/service/am/applet_ae.h"
|
#include "core/hle/service/am/applet_ae.h"
|
||||||
#include "core/hle/service/am/applet_oe.h"
|
#include "core/hle/service/am/applet_oe.h"
|
||||||
#include "core/hle/service/am/applets/applets.h"
|
#include "core/hle/service/am/applets/applets.h"
|
||||||
|
#include "core/hle/service/set/set_sys.h"
|
||||||
#include "yuzu/multiplayer/state.h"
|
#include "yuzu/multiplayer/state.h"
|
||||||
#include "yuzu/util/controller_navigation.h"
|
#include "yuzu/util/controller_navigation.h"
|
||||||
|
|
||||||
@ -1048,7 +1049,12 @@ void GMainWindow::InitializeWidgets() {
|
|||||||
statusBar()->addPermanentWidget(label);
|
statusBar()->addPermanentWidget(label);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO (flTobi): Add the widget when multiplayer is fully implemented
|
firmware_label = new QLabel();
|
||||||
|
firmware_label->setObjectName(QStringLiteral("FirmwareLabel"));
|
||||||
|
firmware_label->setVisible(false);
|
||||||
|
firmware_label->setFocusPolicy(Qt::NoFocus);
|
||||||
|
statusBar()->addPermanentWidget(firmware_label);
|
||||||
|
|
||||||
statusBar()->addPermanentWidget(multiplayer_state->GetStatusText(), 0);
|
statusBar()->addPermanentWidget(multiplayer_state->GetStatusText(), 0);
|
||||||
statusBar()->addPermanentWidget(multiplayer_state->GetStatusIcon(), 0);
|
statusBar()->addPermanentWidget(multiplayer_state->GetStatusIcon(), 0);
|
||||||
|
|
||||||
@ -2165,6 +2171,10 @@ void GMainWindow::OnEmulationStopped() {
|
|||||||
emu_frametime_label->setVisible(false);
|
emu_frametime_label->setVisible(false);
|
||||||
renderer_status_button->setEnabled(!UISettings::values.has_broken_vulkan);
|
renderer_status_button->setEnabled(!UISettings::values.has_broken_vulkan);
|
||||||
|
|
||||||
|
if (!firmware_label->text().isEmpty()) {
|
||||||
|
firmware_label->setVisible(true);
|
||||||
|
}
|
||||||
|
|
||||||
current_game_path.clear();
|
current_game_path.clear();
|
||||||
|
|
||||||
// When closing the game, destroy the GLWindow to clear the context after the game is closed
|
// When closing the game, destroy the GLWindow to clear the context after the game is closed
|
||||||
@ -4591,6 +4601,7 @@ void GMainWindow::UpdateStatusBar() {
|
|||||||
emu_speed_label->setVisible(!Settings::values.use_multi_core.GetValue());
|
emu_speed_label->setVisible(!Settings::values.use_multi_core.GetValue());
|
||||||
game_fps_label->setVisible(true);
|
game_fps_label->setVisible(true);
|
||||||
emu_frametime_label->setVisible(true);
|
emu_frametime_label->setVisible(true);
|
||||||
|
firmware_label->setVisible(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GMainWindow::UpdateGPUAccuracyButton() {
|
void GMainWindow::UpdateGPUAccuracyButton() {
|
||||||
@ -4810,6 +4821,8 @@ void GMainWindow::OnReinitializeKeys(ReinitializeKeyBehavior behavior) {
|
|||||||
"games."));
|
"games."));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SetFirmwareVersion();
|
||||||
|
|
||||||
if (behavior == ReinitializeKeyBehavior::Warning) {
|
if (behavior == ReinitializeKeyBehavior::Warning) {
|
||||||
game_list->PopulateAsync(UISettings::values.game_dirs);
|
game_list->PopulateAsync(UISettings::values.game_dirs);
|
||||||
}
|
}
|
||||||
@ -4837,7 +4850,7 @@ bool GMainWindow::CheckSystemArchiveDecryption() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool GMainWindow::CheckFirmwarePresence() {
|
bool GMainWindow::CheckFirmwarePresence() {
|
||||||
constexpr u64 MiiEditId = 0x0100000000001009ull;
|
constexpr u64 MiiEditId = static_cast<u64>(Service::AM::Applets::AppletProgramId::MiiEdit);
|
||||||
|
|
||||||
auto bis_system = system->GetFileSystemController().GetSystemNANDContents();
|
auto bis_system = system->GetFileSystemController().GetSystemNANDContents();
|
||||||
if (!bis_system) {
|
if (!bis_system) {
|
||||||
@ -4852,6 +4865,28 @@ bool GMainWindow::CheckFirmwarePresence() {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GMainWindow::SetFirmwareVersion() {
|
||||||
|
Service::Set::FirmwareVersionFormat firmware_data{};
|
||||||
|
const auto result = Service::Set::GetFirmwareVersionImpl(
|
||||||
|
firmware_data, *system, Service::Set::GetFirmwareVersionType::Version2);
|
||||||
|
|
||||||
|
if (result.IsError() || !CheckFirmwarePresence()) {
|
||||||
|
LOG_INFO(Frontend, "Installed firmware: No firmware available");
|
||||||
|
firmware_label->setVisible(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
firmware_label->setVisible(true);
|
||||||
|
|
||||||
|
const std::string display_version(firmware_data.display_version.data());
|
||||||
|
const std::string display_title(firmware_data.display_title.data());
|
||||||
|
|
||||||
|
LOG_INFO(Frontend, "Installed firmware: {}", display_title);
|
||||||
|
|
||||||
|
firmware_label->setText(QString::fromStdString(display_version));
|
||||||
|
firmware_label->setToolTip(QString::fromStdString(display_title));
|
||||||
|
}
|
||||||
|
|
||||||
bool GMainWindow::SelectRomFSDumpTarget(const FileSys::ContentProvider& installed, u64 program_id,
|
bool GMainWindow::SelectRomFSDumpTarget(const FileSys::ContentProvider& installed, u64 program_id,
|
||||||
u64* selected_title_id, u8* selected_content_record_type) {
|
u64* selected_title_id, u8* selected_content_record_type) {
|
||||||
using ContentInfo = std::tuple<u64, FileSys::TitleType, FileSys::ContentRecordType>;
|
using ContentInfo = std::tuple<u64, FileSys::TitleType, FileSys::ContentRecordType>;
|
||||||
|
@ -458,6 +458,7 @@ private:
|
|||||||
bool CheckDarkMode();
|
bool CheckDarkMode();
|
||||||
bool CheckSystemArchiveDecryption();
|
bool CheckSystemArchiveDecryption();
|
||||||
bool CheckFirmwarePresence();
|
bool CheckFirmwarePresence();
|
||||||
|
void SetFirmwareVersion();
|
||||||
void ConfigureFilesystemProvider(const std::string& filepath);
|
void ConfigureFilesystemProvider(const std::string& filepath);
|
||||||
/**
|
/**
|
||||||
* Open (or not) the right confirm dialog based on current setting and game exit lock
|
* Open (or not) the right confirm dialog based on current setting and game exit lock
|
||||||
@ -512,6 +513,7 @@ private:
|
|||||||
QLabel* game_fps_label = nullptr;
|
QLabel* game_fps_label = nullptr;
|
||||||
QLabel* emu_frametime_label = nullptr;
|
QLabel* emu_frametime_label = nullptr;
|
||||||
QLabel* tas_label = nullptr;
|
QLabel* tas_label = nullptr;
|
||||||
|
QLabel* firmware_label = nullptr;
|
||||||
QPushButton* gpu_accuracy_button = nullptr;
|
QPushButton* gpu_accuracy_button = nullptr;
|
||||||
QPushButton* renderer_status_button = nullptr;
|
QPushButton* renderer_status_button = nullptr;
|
||||||
QPushButton* dock_status_button = nullptr;
|
QPushButton* dock_status_button = nullptr;
|
||||||
|
Reference in New Issue
Block a user