mirror of
https://github.com/yuzu-emu/yuzu-mainline.git
synced 2025-08-24 06:31:11 +00:00
Compare commits
5 commits
master
...
mainline-0
Author | SHA1 | Date | |
---|---|---|---|
|
da3bc89219 | ||
|
84f78caf3d | ||
|
f83d8cd6cb | ||
|
b7b5426603 | ||
|
d1c7176c5b |
|
@ -140,7 +140,7 @@ struct Values {
|
||||||
Category::LibraryApplet};
|
Category::LibraryApplet};
|
||||||
Setting<AppletMode> data_erase_applet_mode{linkage, AppletMode::HLE, "data_erase_applet_mode",
|
Setting<AppletMode> data_erase_applet_mode{linkage, AppletMode::HLE, "data_erase_applet_mode",
|
||||||
Category::LibraryApplet};
|
Category::LibraryApplet};
|
||||||
Setting<AppletMode> error_applet_mode{linkage, AppletMode::HLE, "error_applet_mode",
|
Setting<AppletMode> error_applet_mode{linkage, AppletMode::LLE, "error_applet_mode",
|
||||||
Category::LibraryApplet};
|
Category::LibraryApplet};
|
||||||
Setting<AppletMode> net_connect_applet_mode{linkage, AppletMode::HLE, "net_connect_applet_mode",
|
Setting<AppletMode> net_connect_applet_mode{linkage, AppletMode::HLE, "net_connect_applet_mode",
|
||||||
Category::LibraryApplet};
|
Category::LibraryApplet};
|
||||||
|
|
|
@ -1047,9 +1047,12 @@ add_library(core STATIC
|
||||||
hle/service/spl/spl_module.h
|
hle/service/spl/spl_module.h
|
||||||
hle/service/spl/spl_results.h
|
hle/service/spl/spl_results.h
|
||||||
hle/service/spl/spl_types.h
|
hle/service/spl/spl_types.h
|
||||||
|
hle/service/ssl/cert_store.cpp
|
||||||
|
hle/service/ssl/cert_store.h
|
||||||
hle/service/ssl/ssl.cpp
|
hle/service/ssl/ssl.cpp
|
||||||
hle/service/ssl/ssl.h
|
hle/service/ssl/ssl.h
|
||||||
hle/service/ssl/ssl_backend.h
|
hle/service/ssl/ssl_backend.h
|
||||||
|
hle/service/ssl/ssl_types.h
|
||||||
hle/service/usb/usb.cpp
|
hle/service/usb/usb.cpp
|
||||||
hle/service/usb/usb.h
|
hle/service/usb/usb.h
|
||||||
hle/service/vi/application_display_service.cpp
|
hle/service/vi/application_display_service.cpp
|
||||||
|
|
|
@ -25,8 +25,8 @@
|
||||||
#include "core/hle/service/acc/async_context.h"
|
#include "core/hle/service/acc/async_context.h"
|
||||||
#include "core/hle/service/acc/errors.h"
|
#include "core/hle/service/acc/errors.h"
|
||||||
#include "core/hle/service/acc/profile_manager.h"
|
#include "core/hle/service/acc/profile_manager.h"
|
||||||
|
#include "core/hle/service/cmif_serialization.h"
|
||||||
#include "core/hle/service/glue/glue_manager.h"
|
#include "core/hle/service/glue/glue_manager.h"
|
||||||
#include "core/hle/service/ipc_helpers.h"
|
|
||||||
#include "core/hle/service/server_manager.h"
|
#include "core/hle/service/server_manager.h"
|
||||||
#include "core/loader/loader.h"
|
#include "core/loader/loader.h"
|
||||||
|
|
||||||
|
@ -74,12 +74,12 @@ static void SanitizeJPEGImageSize(std::vector<u8>& image) {
|
||||||
|
|
||||||
class IManagerForSystemService final : public ServiceFramework<IManagerForSystemService> {
|
class IManagerForSystemService final : public ServiceFramework<IManagerForSystemService> {
|
||||||
public:
|
public:
|
||||||
explicit IManagerForSystemService(Core::System& system_, Common::UUID)
|
explicit IManagerForSystemService(Core::System& system_, Common::UUID uuid)
|
||||||
: ServiceFramework{system_, "IManagerForSystemService"} {
|
: ServiceFramework{system_, "IManagerForSystemService"}, account_id{uuid} {
|
||||||
// clang-format off
|
// clang-format off
|
||||||
static const FunctionInfo functions[] = {
|
static const FunctionInfo functions[] = {
|
||||||
{0, &IManagerForSystemService::CheckAvailability, "CheckAvailability"},
|
{0, D<&IManagerForSystemService::CheckAvailability>, "CheckAvailability"},
|
||||||
{1, nullptr, "GetAccountId"},
|
{1, D<&IManagerForSystemService::GetAccountId>, "GetAccountId"},
|
||||||
{2, nullptr, "EnsureIdTokenCacheAsync"},
|
{2, nullptr, "EnsureIdTokenCacheAsync"},
|
||||||
{3, nullptr, "LoadIdTokenCache"},
|
{3, nullptr, "LoadIdTokenCache"},
|
||||||
{100, nullptr, "SetSystemProgramIdentification"},
|
{100, nullptr, "SetSystemProgramIdentification"},
|
||||||
|
@ -109,11 +109,18 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void CheckAvailability(HLERequestContext& ctx) {
|
Result CheckAvailability() {
|
||||||
LOG_WARNING(Service_ACC, "(STUBBED) called");
|
LOG_WARNING(Service_ACC, "(STUBBED) called");
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
R_SUCCEED();
|
||||||
rb.Push(ResultSuccess);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Result GetAccountId(Out<u64> out_account_id) {
|
||||||
|
LOG_WARNING(Service_ACC, "(STUBBED) called");
|
||||||
|
*out_account_id = account_id.Hash();
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Common::UUID account_id;
|
||||||
};
|
};
|
||||||
|
|
||||||
// 3.0.0+
|
// 3.0.0+
|
||||||
|
|
|
@ -23,7 +23,7 @@ ACC_U1::ACC_U1(std::shared_ptr<Module> module_, std::shared_ptr<ProfileManager>
|
||||||
{99, nullptr, "DebugActivateOpenContextRetention"},
|
{99, nullptr, "DebugActivateOpenContextRetention"},
|
||||||
{100, nullptr, "GetUserRegistrationNotifier"},
|
{100, nullptr, "GetUserRegistrationNotifier"},
|
||||||
{101, nullptr, "GetUserStateChangeNotifier"},
|
{101, nullptr, "GetUserStateChangeNotifier"},
|
||||||
{102, nullptr, "GetBaasAccountManagerForSystemService"},
|
{102, &ACC_U1::GetBaasAccountManagerForSystemService, "GetBaasAccountManagerForSystemService"},
|
||||||
{103, nullptr, "GetBaasUserAvailabilityChangeNotifier"},
|
{103, nullptr, "GetBaasUserAvailabilityChangeNotifier"},
|
||||||
{104, nullptr, "GetProfileUpdateNotifier"},
|
{104, nullptr, "GetProfileUpdateNotifier"},
|
||||||
{105, nullptr, "CheckNetworkServiceAvailabilityAsync"},
|
{105, nullptr, "CheckNetworkServiceAvailabilityAsync"},
|
||||||
|
|
|
@ -48,11 +48,6 @@ enum class SystemButtonType {
|
||||||
CaptureButtonLongPressing,
|
CaptureButtonLongPressing,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class SysPlatformRegion : s32 {
|
|
||||||
Global = 1,
|
|
||||||
Terra = 2,
|
|
||||||
};
|
|
||||||
|
|
||||||
struct AppletProcessLaunchReason {
|
struct AppletProcessLaunchReason {
|
||||||
u8 flag;
|
u8 flag;
|
||||||
INSERT_PADDING_BYTES(3);
|
INSERT_PADDING_BYTES(3);
|
||||||
|
|
|
@ -260,9 +260,9 @@ Result ICommonStateGetter::GetAppletLaunchedHistory(
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ICommonStateGetter::GetSettingsPlatformRegion(
|
Result ICommonStateGetter::GetSettingsPlatformRegion(
|
||||||
Out<SysPlatformRegion> out_settings_platform_region) {
|
Out<Set::PlatformRegion> out_settings_platform_region) {
|
||||||
LOG_INFO(Service_AM, "called");
|
LOG_INFO(Service_AM, "called");
|
||||||
*out_settings_platform_region = SysPlatformRegion::Global;
|
*out_settings_platform_region = Set::PlatformRegion::Global;
|
||||||
R_SUCCEED();
|
R_SUCCEED();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#include "core/hle/service/cmif_types.h"
|
#include "core/hle/service/cmif_types.h"
|
||||||
#include "core/hle/service/pm/pm.h"
|
#include "core/hle/service/pm/pm.h"
|
||||||
#include "core/hle/service/service.h"
|
#include "core/hle/service/service.h"
|
||||||
|
#include "core/hle/service/set/settings_types.h"
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
class KReadableEvent;
|
class KReadableEvent;
|
||||||
|
@ -50,7 +51,7 @@ private:
|
||||||
Result GetOperationModeSystemInfo(Out<u32> out_operation_mode_system_info);
|
Result GetOperationModeSystemInfo(Out<u32> out_operation_mode_system_info);
|
||||||
Result GetAppletLaunchedHistory(Out<s32> out_count,
|
Result GetAppletLaunchedHistory(Out<s32> out_count,
|
||||||
OutArray<AppletId, BufferAttr_HipcMapAlias> out_applet_ids);
|
OutArray<AppletId, BufferAttr_HipcMapAlias> out_applet_ids);
|
||||||
Result GetSettingsPlatformRegion(Out<SysPlatformRegion> out_settings_platform_region);
|
Result GetSettingsPlatformRegion(Out<Set::PlatformRegion> out_settings_platform_region);
|
||||||
Result SetRequestExitToLibraryAppletAtExecuteNextProgramEnabled();
|
Result SetRequestExitToLibraryAppletAtExecuteNextProgramEnabled();
|
||||||
|
|
||||||
void SetCpuBoostMode(HLERequestContext& ctx);
|
void SetCpuBoostMode(HLERequestContext& ctx);
|
||||||
|
|
|
@ -18,7 +18,7 @@ public:
|
||||||
// clang-format off
|
// clang-format off
|
||||||
static const FunctionInfo functions[] = {
|
static const FunctionInfo functions[] = {
|
||||||
{0, C<&ErrorReportContext::SubmitContext>, "SubmitContext"},
|
{0, C<&ErrorReportContext::SubmitContext>, "SubmitContext"},
|
||||||
{1, nullptr, "CreateReportV0"},
|
{1, C<&ErrorReportContext::CreateReportV0>, "CreateReportV0"},
|
||||||
{2, nullptr, "SetInitialLaunchSettingsCompletionTime"},
|
{2, nullptr, "SetInitialLaunchSettingsCompletionTime"},
|
||||||
{3, nullptr, "ClearInitialLaunchSettingsCompletionTime"},
|
{3, nullptr, "ClearInitialLaunchSettingsCompletionTime"},
|
||||||
{4, nullptr, "UpdatePowerOnTime"},
|
{4, nullptr, "UpdatePowerOnTime"},
|
||||||
|
@ -28,7 +28,8 @@ public:
|
||||||
{8, nullptr, "ClearApplicationLaunchTime"},
|
{8, nullptr, "ClearApplicationLaunchTime"},
|
||||||
{9, nullptr, "SubmitAttachment"},
|
{9, nullptr, "SubmitAttachment"},
|
||||||
{10, nullptr, "CreateReportWithAttachments"},
|
{10, nullptr, "CreateReportWithAttachments"},
|
||||||
{11, nullptr, "CreateReport"},
|
{11, C<&ErrorReportContext::CreateReportV1>, "CreateReportV1"},
|
||||||
|
{12, C<&ErrorReportContext::CreateReport>, "CreateReport"},
|
||||||
{20, nullptr, "RegisterRunningApplet"},
|
{20, nullptr, "RegisterRunningApplet"},
|
||||||
{21, nullptr, "UnregisterRunningApplet"},
|
{21, nullptr, "UnregisterRunningApplet"},
|
||||||
{22, nullptr, "UpdateAppletSuspendedDuration"},
|
{22, nullptr, "UpdateAppletSuspendedDuration"},
|
||||||
|
@ -40,10 +41,37 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Result SubmitContext(InBuffer<BufferAttr_HipcMapAlias> buffer_a,
|
Result SubmitContext(InBuffer<BufferAttr_HipcMapAlias> context_entry,
|
||||||
InBuffer<BufferAttr_HipcMapAlias> buffer_b) {
|
InBuffer<BufferAttr_HipcMapAlias> field_list) {
|
||||||
LOG_WARNING(Service_SET, "(STUBBED) called, buffer_a_size={}, buffer_b_size={}",
|
LOG_WARNING(Service_SET, "(STUBBED) called, context_entry_size={}, field_list_size={}",
|
||||||
buffer_a.size(), buffer_b.size());
|
context_entry.size(), field_list.size());
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result CreateReportV0(u32 report_type, InBuffer<BufferAttr_HipcMapAlias> context_entry,
|
||||||
|
InBuffer<BufferAttr_HipcMapAlias> report_list,
|
||||||
|
InBuffer<BufferAttr_HipcMapAlias> report_meta_data) {
|
||||||
|
LOG_WARNING(Service_SET, "(STUBBED) called, report_type={:#x}", report_type);
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result CreateReportV1(u32 report_type, u32 unknown,
|
||||||
|
InBuffer<BufferAttr_HipcMapAlias> context_entry,
|
||||||
|
InBuffer<BufferAttr_HipcMapAlias> report_list,
|
||||||
|
InBuffer<BufferAttr_HipcMapAlias> report_meta_data) {
|
||||||
|
LOG_WARNING(Service_SET, "(STUBBED) called, report_type={:#x}, unknown={:#x}", report_type,
|
||||||
|
unknown);
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result CreateReport(u32 report_type, u32 unknown, u32 create_report_option_flag,
|
||||||
|
InBuffer<BufferAttr_HipcMapAlias> context_entry,
|
||||||
|
InBuffer<BufferAttr_HipcMapAlias> report_list,
|
||||||
|
InBuffer<BufferAttr_HipcMapAlias> report_meta_data) {
|
||||||
|
LOG_WARNING(
|
||||||
|
Service_SET,
|
||||||
|
"(STUBBED) called, report_type={:#x}, unknown={:#x}, create_report_option_flag={:#x}",
|
||||||
|
report_type, unknown, create_report_option_flag);
|
||||||
R_SUCCEED();
|
R_SUCCEED();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -71,7 +71,7 @@ FSP_SRV::FSP_SRV(Core::System& system_)
|
||||||
{28, nullptr, "DeleteSaveDataFileSystemBySaveDataAttribute"},
|
{28, nullptr, "DeleteSaveDataFileSystemBySaveDataAttribute"},
|
||||||
{30, nullptr, "OpenGameCardStorage"},
|
{30, nullptr, "OpenGameCardStorage"},
|
||||||
{31, nullptr, "OpenGameCardFileSystem"},
|
{31, nullptr, "OpenGameCardFileSystem"},
|
||||||
{32, nullptr, "ExtendSaveDataFileSystem"},
|
{32, D<&FSP_SRV::ExtendSaveDataFileSystem>, "ExtendSaveDataFileSystem"},
|
||||||
{33, nullptr, "DeleteCacheStorage"},
|
{33, nullptr, "DeleteCacheStorage"},
|
||||||
{34, D<&FSP_SRV::GetCacheStorageSize>, "GetCacheStorageSize"},
|
{34, D<&FSP_SRV::GetCacheStorageSize>, "GetCacheStorageSize"},
|
||||||
{35, nullptr, "CreateSaveDataFileSystemByHashSalt"},
|
{35, nullptr, "CreateSaveDataFileSystemByHashSalt"},
|
||||||
|
@ -79,9 +79,9 @@ FSP_SRV::FSP_SRV(Core::System& system_)
|
||||||
{51, D<&FSP_SRV::OpenSaveDataFileSystem>, "OpenSaveDataFileSystem"},
|
{51, D<&FSP_SRV::OpenSaveDataFileSystem>, "OpenSaveDataFileSystem"},
|
||||||
{52, D<&FSP_SRV::OpenSaveDataFileSystemBySystemSaveDataId>, "OpenSaveDataFileSystemBySystemSaveDataId"},
|
{52, D<&FSP_SRV::OpenSaveDataFileSystemBySystemSaveDataId>, "OpenSaveDataFileSystemBySystemSaveDataId"},
|
||||||
{53, D<&FSP_SRV::OpenReadOnlySaveDataFileSystem>, "OpenReadOnlySaveDataFileSystem"},
|
{53, D<&FSP_SRV::OpenReadOnlySaveDataFileSystem>, "OpenReadOnlySaveDataFileSystem"},
|
||||||
{57, nullptr, "ReadSaveDataFileSystemExtraDataBySaveDataSpaceId"},
|
{57, D<&FSP_SRV::ReadSaveDataFileSystemExtraDataBySaveDataSpaceId>, "ReadSaveDataFileSystemExtraDataBySaveDataSpaceId"},
|
||||||
{58, nullptr, "ReadSaveDataFileSystemExtraData"},
|
{58, D<&FSP_SRV::ReadSaveDataFileSystemExtraData>, "ReadSaveDataFileSystemExtraData"},
|
||||||
{59, nullptr, "WriteSaveDataFileSystemExtraData"},
|
{59, D<&FSP_SRV::WriteSaveDataFileSystemExtraData>, "WriteSaveDataFileSystemExtraData"},
|
||||||
{60, nullptr, "OpenSaveDataInfoReader"},
|
{60, nullptr, "OpenSaveDataInfoReader"},
|
||||||
{61, D<&FSP_SRV::OpenSaveDataInfoReaderBySaveDataSpaceId>, "OpenSaveDataInfoReaderBySaveDataSpaceId"},
|
{61, D<&FSP_SRV::OpenSaveDataInfoReaderBySaveDataSpaceId>, "OpenSaveDataInfoReaderBySaveDataSpaceId"},
|
||||||
{62, D<&FSP_SRV::OpenSaveDataInfoReaderOnlyCacheStorage>, "OpenSaveDataInfoReaderOnlyCacheStorage"},
|
{62, D<&FSP_SRV::OpenSaveDataInfoReaderOnlyCacheStorage>, "OpenSaveDataInfoReaderOnlyCacheStorage"},
|
||||||
|
@ -90,8 +90,8 @@ FSP_SRV::FSP_SRV(Core::System& system_)
|
||||||
{66, nullptr, "WriteSaveDataFileSystemExtraData2"},
|
{66, nullptr, "WriteSaveDataFileSystemExtraData2"},
|
||||||
{67, D<&FSP_SRV::FindSaveDataWithFilter>, "FindSaveDataWithFilter"},
|
{67, D<&FSP_SRV::FindSaveDataWithFilter>, "FindSaveDataWithFilter"},
|
||||||
{68, nullptr, "OpenSaveDataInfoReaderBySaveDataFilter"},
|
{68, nullptr, "OpenSaveDataInfoReaderBySaveDataFilter"},
|
||||||
{69, nullptr, "ReadSaveDataFileSystemExtraDataBySaveDataAttribute"},
|
{69, D<&FSP_SRV::ReadSaveDataFileSystemExtraDataBySaveDataAttribute>, "ReadSaveDataFileSystemExtraDataBySaveDataAttribute"},
|
||||||
{70, D<&FSP_SRV::WriteSaveDataFileSystemExtraDataBySaveDataAttribute>, "WriteSaveDataFileSystemExtraDataBySaveDataAttribute"},
|
{70, D<&FSP_SRV::WriteSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute>, "WriteSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute"},
|
||||||
{71, D<&FSP_SRV::ReadSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute>, "ReadSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute"},
|
{71, D<&FSP_SRV::ReadSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute>, "ReadSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute"},
|
||||||
{80, nullptr, "OpenSaveDataMetaFile"},
|
{80, nullptr, "OpenSaveDataMetaFile"},
|
||||||
{81, nullptr, "OpenSaveDataTransferManager"},
|
{81, nullptr, "OpenSaveDataTransferManager"},
|
||||||
|
@ -317,9 +317,23 @@ Result FSP_SRV::FindSaveDataWithFilter(Out<s64> out_count,
|
||||||
R_THROW(FileSys::ResultTargetNotFound);
|
R_THROW(FileSys::ResultTargetNotFound);
|
||||||
}
|
}
|
||||||
|
|
||||||
Result FSP_SRV::WriteSaveDataFileSystemExtraDataBySaveDataAttribute() {
|
Result FSP_SRV::WriteSaveDataFileSystemExtraData(InBuffer<BufferAttr_HipcMapAlias> buffer,
|
||||||
LOG_WARNING(Service_FS, "(STUBBED) called.");
|
FileSys::SaveDataSpaceId space_id,
|
||||||
|
u64 save_data_id) {
|
||||||
|
LOG_WARNING(Service_FS, "(STUBBED) called, space_id={}, save_data_id={:016X}", space_id,
|
||||||
|
save_data_id);
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result FSP_SRV::WriteSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute(
|
||||||
|
InBuffer<BufferAttr_HipcMapAlias> buffer, InBuffer<BufferAttr_HipcMapAlias> mask_buffer,
|
||||||
|
FileSys::SaveDataSpaceId space_id, FileSys::SaveDataAttribute attribute) {
|
||||||
|
LOG_WARNING(Service_FS,
|
||||||
|
"(STUBBED) called, space_id={}, attribute.program_id={:016X}\n"
|
||||||
|
"attribute.user_id={:016X}{:016X}, attribute.save_id={:016X}\n"
|
||||||
|
"attribute.type={}, attribute.rank={}, attribute.index={}",
|
||||||
|
space_id, attribute.program_id, attribute.user_id[1], attribute.user_id[0],
|
||||||
|
attribute.system_save_data_id, attribute.type, attribute.rank, attribute.index);
|
||||||
R_SUCCEED();
|
R_SUCCEED();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -341,6 +355,38 @@ Result FSP_SRV::ReadSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute(
|
||||||
R_SUCCEED();
|
R_SUCCEED();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Result FSP_SRV::ReadSaveDataFileSystemExtraData(OutBuffer<BufferAttr_HipcMapAlias> out_buffer,
|
||||||
|
u64 save_data_id) {
|
||||||
|
// Stub, backend needs an impl to read/write the SaveDataExtraData
|
||||||
|
LOG_WARNING(Service_FS, "(STUBBED) called, save_data_id={:016X}", save_data_id);
|
||||||
|
std::memset(out_buffer.data(), 0, out_buffer.size());
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result FSP_SRV::ReadSaveDataFileSystemExtraDataBySaveDataAttribute(
|
||||||
|
OutBuffer<BufferAttr_HipcMapAlias> out_buffer, FileSys::SaveDataSpaceId space_id,
|
||||||
|
FileSys::SaveDataAttribute attribute) {
|
||||||
|
// Stub, backend needs an impl to read/write the SaveDataExtraData
|
||||||
|
LOG_WARNING(Service_FS,
|
||||||
|
"(STUBBED) called, space_id={}, attribute.program_id={:016X}\n"
|
||||||
|
"attribute.user_id={:016X}{:016X}, attribute.save_id={:016X}\n"
|
||||||
|
"attribute.type={}, attribute.rank={}, attribute.index={}",
|
||||||
|
space_id, attribute.program_id, attribute.user_id[1], attribute.user_id[0],
|
||||||
|
attribute.system_save_data_id, attribute.type, attribute.rank, attribute.index);
|
||||||
|
std::memset(out_buffer.data(), 0, out_buffer.size());
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result FSP_SRV::ReadSaveDataFileSystemExtraDataBySaveDataSpaceId(
|
||||||
|
OutBuffer<BufferAttr_HipcMapAlias> out_buffer, FileSys::SaveDataSpaceId space_id,
|
||||||
|
u64 save_data_id) {
|
||||||
|
// Stub, backend needs an impl to read/write the SaveDataExtraData
|
||||||
|
LOG_WARNING(Service_FS, "(STUBBED) called, space_id={}, save_data_id={:016X}", space_id,
|
||||||
|
save_data_id);
|
||||||
|
std::memset(out_buffer.data(), 0, out_buffer.size());
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
Result FSP_SRV::OpenSaveDataTransferProhibiter(
|
Result FSP_SRV::OpenSaveDataTransferProhibiter(
|
||||||
OutInterface<ISaveDataTransferProhibiter> out_prohibiter, u64 id) {
|
OutInterface<ISaveDataTransferProhibiter> out_prohibiter, u64 id) {
|
||||||
LOG_WARNING(Service_FS, "(STUBBED) called, id={:016X}", id);
|
LOG_WARNING(Service_FS, "(STUBBED) called, id={:016X}", id);
|
||||||
|
@ -476,6 +522,16 @@ Result FSP_SRV::FlushAccessLogOnSdCard() {
|
||||||
R_SUCCEED();
|
R_SUCCEED();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Result FSP_SRV::ExtendSaveDataFileSystem(FileSys::SaveDataSpaceId space_id, u64 save_data_id,
|
||||||
|
s64 available_size, s64 journal_size) {
|
||||||
|
// We don't have an index of save data ids, so we can't implement this.
|
||||||
|
LOG_WARNING(Service_FS,
|
||||||
|
"(STUBBED) called, space_id={}, save_data_id={:016X}, available_size={:#x}, "
|
||||||
|
"journal_size={:#x}",
|
||||||
|
space_id, save_data_id, available_size, journal_size);
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
Result FSP_SRV::GetCacheStorageSize(s32 index, Out<s64> out_data_size, Out<s64> out_journal_size) {
|
Result FSP_SRV::GetCacheStorageSize(s32 index, Out<s64> out_data_size, Out<s64> out_journal_size) {
|
||||||
LOG_WARNING(Service_FS, "(STUBBED) called with index={}", index);
|
LOG_WARNING(Service_FS, "(STUBBED) called with index={}", index);
|
||||||
|
|
||||||
|
|
|
@ -70,7 +70,19 @@ private:
|
||||||
Result FindSaveDataWithFilter(Out<s64> out_count, OutBuffer<BufferAttr_HipcMapAlias> out_buffer,
|
Result FindSaveDataWithFilter(Out<s64> out_count, OutBuffer<BufferAttr_HipcMapAlias> out_buffer,
|
||||||
FileSys::SaveDataSpaceId space_id,
|
FileSys::SaveDataSpaceId space_id,
|
||||||
FileSys::SaveDataFilter filter);
|
FileSys::SaveDataFilter filter);
|
||||||
Result WriteSaveDataFileSystemExtraDataBySaveDataAttribute();
|
Result WriteSaveDataFileSystemExtraData(InBuffer<BufferAttr_HipcMapAlias> buffer,
|
||||||
|
FileSys::SaveDataSpaceId space_id, u64 save_data_id);
|
||||||
|
Result WriteSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute(
|
||||||
|
InBuffer<BufferAttr_HipcMapAlias> buffer, InBuffer<BufferAttr_HipcMapAlias> mask_buffer,
|
||||||
|
FileSys::SaveDataSpaceId space_id, FileSys::SaveDataAttribute attribute);
|
||||||
|
Result ReadSaveDataFileSystemExtraData(OutBuffer<BufferAttr_HipcMapAlias> out_buffer,
|
||||||
|
u64 save_data_id);
|
||||||
|
Result ReadSaveDataFileSystemExtraDataBySaveDataAttribute(
|
||||||
|
OutBuffer<BufferAttr_HipcMapAlias> out_buffer, FileSys::SaveDataSpaceId space_id,
|
||||||
|
FileSys::SaveDataAttribute attribute);
|
||||||
|
Result ReadSaveDataFileSystemExtraDataBySaveDataSpaceId(
|
||||||
|
OutBuffer<BufferAttr_HipcMapAlias> out_buffer, FileSys::SaveDataSpaceId space_id,
|
||||||
|
u64 save_data_id);
|
||||||
Result ReadSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute(
|
Result ReadSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute(
|
||||||
FileSys::SaveDataSpaceId space_id, FileSys::SaveDataAttribute attribute,
|
FileSys::SaveDataSpaceId space_id, FileSys::SaveDataAttribute attribute,
|
||||||
InBuffer<BufferAttr_HipcMapAlias> mask_buffer,
|
InBuffer<BufferAttr_HipcMapAlias> mask_buffer,
|
||||||
|
@ -91,6 +103,8 @@ private:
|
||||||
Result GetProgramIndexForAccessLog(Out<AccessLogVersion> out_access_log_version,
|
Result GetProgramIndexForAccessLog(Out<AccessLogVersion> out_access_log_version,
|
||||||
Out<u32> out_access_log_program_index);
|
Out<u32> out_access_log_program_index);
|
||||||
Result OpenMultiCommitManager(OutInterface<IMultiCommitManager> out_interface);
|
Result OpenMultiCommitManager(OutInterface<IMultiCommitManager> out_interface);
|
||||||
|
Result ExtendSaveDataFileSystem(FileSys::SaveDataSpaceId space_id, u64 save_data_id,
|
||||||
|
s64 available_size, s64 journal_size);
|
||||||
Result GetCacheStorageSize(s32 index, Out<s64> out_data_size, Out<s64> out_journal_size);
|
Result GetCacheStorageSize(s32 index, Out<s64> out_data_size, Out<s64> out_journal_size);
|
||||||
|
|
||||||
FileSystemController& fsc;
|
FileSystemController& fsc;
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
#include "core/hle/service/cmif_serialization.h"
|
#include "core/hle/service/cmif_serialization.h"
|
||||||
|
#include "core/hle/service/ldn/ldn_results.h"
|
||||||
#include "core/hle/service/ldn/monitor_service.h"
|
#include "core/hle/service/ldn/monitor_service.h"
|
||||||
|
|
||||||
namespace Service::LDN {
|
namespace Service::LDN {
|
||||||
|
@ -17,7 +18,7 @@ IMonitorService::IMonitorService(Core::System& system_)
|
||||||
{4, nullptr, "GetSecurityParameterForMonitor"},
|
{4, nullptr, "GetSecurityParameterForMonitor"},
|
||||||
{5, nullptr, "GetNetworkConfigForMonitor"},
|
{5, nullptr, "GetNetworkConfigForMonitor"},
|
||||||
{100, C<&IMonitorService::InitializeMonitor>, "InitializeMonitor"},
|
{100, C<&IMonitorService::InitializeMonitor>, "InitializeMonitor"},
|
||||||
{101, nullptr, "FinalizeMonitor"},
|
{101, C<&IMonitorService::FinalizeMonitor>, "FinalizeMonitor"},
|
||||||
};
|
};
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
|
@ -27,16 +28,18 @@ IMonitorService::IMonitorService(Core::System& system_)
|
||||||
IMonitorService::~IMonitorService() = default;
|
IMonitorService::~IMonitorService() = default;
|
||||||
|
|
||||||
Result IMonitorService::GetStateForMonitor(Out<State> out_state) {
|
Result IMonitorService::GetStateForMonitor(Out<State> out_state) {
|
||||||
LOG_INFO(Service_LDN, "called");
|
LOG_WARNING(Service_LDN, "(STUBBED) called");
|
||||||
|
*out_state = State::None;
|
||||||
*out_state = state;
|
|
||||||
R_SUCCEED();
|
R_SUCCEED();
|
||||||
}
|
}
|
||||||
|
|
||||||
Result IMonitorService::InitializeMonitor() {
|
Result IMonitorService::InitializeMonitor() {
|
||||||
LOG_INFO(Service_LDN, "called");
|
LOG_INFO(Service_LDN, "called");
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
state = State::Initialized;
|
Result IMonitorService::FinalizeMonitor() {
|
||||||
|
LOG_INFO(Service_LDN, "called");
|
||||||
R_SUCCEED();
|
R_SUCCEED();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,7 @@ public:
|
||||||
private:
|
private:
|
||||||
Result GetStateForMonitor(Out<State> out_state);
|
Result GetStateForMonitor(Out<State> out_state);
|
||||||
Result InitializeMonitor();
|
Result InitializeMonitor();
|
||||||
|
Result FinalizeMonitor();
|
||||||
|
|
||||||
State state{State::None};
|
State state{State::None};
|
||||||
};
|
};
|
||||||
|
|
|
@ -243,6 +243,11 @@ enum class TvResolution : u32 {
|
||||||
Resolution480p,
|
Resolution480p,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum class PlatformRegion : s32 {
|
||||||
|
Global = 1,
|
||||||
|
Terra = 2,
|
||||||
|
};
|
||||||
|
|
||||||
constexpr std::array<LanguageCode, 18> available_language_codes = {{
|
constexpr std::array<LanguageCode, 18> available_language_codes = {{
|
||||||
LanguageCode::JA,
|
LanguageCode::JA,
|
||||||
LanguageCode::EN_US,
|
LanguageCode::EN_US,
|
||||||
|
|
|
@ -272,8 +272,8 @@ ISystemSettingsServer::ISystemSettingsServer(Core::System& system_)
|
||||||
{180, nullptr, "SetZoomFlag"},
|
{180, nullptr, "SetZoomFlag"},
|
||||||
{181, nullptr, "GetT"},
|
{181, nullptr, "GetT"},
|
||||||
{182, nullptr, "SetT"},
|
{182, nullptr, "SetT"},
|
||||||
{183, nullptr, "GetPlatformRegion"},
|
{183, C<&ISystemSettingsServer::GetPlatformRegion>, "GetPlatformRegion"},
|
||||||
{184, nullptr, "SetPlatformRegion"},
|
{184, C<&ISystemSettingsServer::SetPlatformRegion>, "SetPlatformRegion"},
|
||||||
{185, C<&ISystemSettingsServer::GetHomeMenuSchemeModel>, "GetHomeMenuSchemeModel"},
|
{185, C<&ISystemSettingsServer::GetHomeMenuSchemeModel>, "GetHomeMenuSchemeModel"},
|
||||||
{186, nullptr, "GetMemoryUsageRateFlag"},
|
{186, nullptr, "GetMemoryUsageRateFlag"},
|
||||||
{187, C<&ISystemSettingsServer::GetTouchScreenMode>, "GetTouchScreenMode"},
|
{187, C<&ISystemSettingsServer::GetTouchScreenMode>, "GetTouchScreenMode"},
|
||||||
|
@ -1250,6 +1250,18 @@ Result ISystemSettingsServer::GetHomeMenuScheme(Out<HomeMenuScheme> out_home_men
|
||||||
R_SUCCEED();
|
R_SUCCEED();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Result ISystemSettingsServer::GetPlatformRegion(Out<PlatformRegion> out_platform_region) {
|
||||||
|
LOG_WARNING(Service_SET, "(STUBBED) called");
|
||||||
|
|
||||||
|
*out_platform_region = PlatformRegion::Global;
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result ISystemSettingsServer::SetPlatformRegion(PlatformRegion platform_region) {
|
||||||
|
LOG_WARNING(Service_SET, "(STUBBED) called");
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
Result ISystemSettingsServer::GetHomeMenuSchemeModel(Out<u32> out_home_menu_scheme_model) {
|
Result ISystemSettingsServer::GetHomeMenuSchemeModel(Out<u32> out_home_menu_scheme_model) {
|
||||||
LOG_WARNING(Service_SET, "(STUBBED) called");
|
LOG_WARNING(Service_SET, "(STUBBED) called");
|
||||||
|
|
||||||
|
|
|
@ -149,6 +149,8 @@ public:
|
||||||
Result GetHomeMenuScheme(Out<HomeMenuScheme> out_home_menu_scheme);
|
Result GetHomeMenuScheme(Out<HomeMenuScheme> out_home_menu_scheme);
|
||||||
Result GetHomeMenuSchemeModel(Out<u32> out_home_menu_scheme_model);
|
Result GetHomeMenuSchemeModel(Out<u32> out_home_menu_scheme_model);
|
||||||
Result GetTouchScreenMode(Out<TouchScreenMode> out_touch_screen_mode);
|
Result GetTouchScreenMode(Out<TouchScreenMode> out_touch_screen_mode);
|
||||||
|
Result GetPlatformRegion(Out<PlatformRegion> out_platform_region);
|
||||||
|
Result SetPlatformRegion(PlatformRegion platform_region);
|
||||||
Result SetTouchScreenMode(TouchScreenMode touch_screen_mode);
|
Result SetTouchScreenMode(TouchScreenMode touch_screen_mode);
|
||||||
Result GetFieldTestingFlag(Out<bool> out_field_testing_flag);
|
Result GetFieldTestingFlag(Out<bool> out_field_testing_flag);
|
||||||
Result GetPanelCrcMode(Out<s32> out_panel_crc_mode);
|
Result GetPanelCrcMode(Out<s32> out_panel_crc_mode);
|
||||||
|
|
156
src/core/hle/service/ssl/cert_store.cpp
Normal file
156
src/core/hle/service/ssl/cert_store.cpp
Normal file
|
@ -0,0 +1,156 @@
|
||||||
|
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#include "common/alignment.h"
|
||||||
|
#include "core/core.h"
|
||||||
|
#include "core/file_sys/content_archive.h"
|
||||||
|
#include "core/file_sys/nca_metadata.h"
|
||||||
|
#include "core/file_sys/registered_cache.h"
|
||||||
|
#include "core/file_sys/romfs.h"
|
||||||
|
#include "core/hle/service/filesystem/filesystem.h"
|
||||||
|
#include "core/hle/service/ssl/cert_store.h"
|
||||||
|
|
||||||
|
namespace Service::SSL {
|
||||||
|
|
||||||
|
// https://switchbrew.org/wiki/SSL_services#CertStore
|
||||||
|
|
||||||
|
CertStore::CertStore(Core::System& system) {
|
||||||
|
constexpr u64 CertStoreDataId = 0x0100000000000800ULL;
|
||||||
|
|
||||||
|
auto& fsc = system.GetFileSystemController();
|
||||||
|
|
||||||
|
// Attempt to load certificate data from storage
|
||||||
|
const auto nca =
|
||||||
|
fsc.GetSystemNANDContents()->GetEntry(CertStoreDataId, FileSys::ContentRecordType::Data);
|
||||||
|
if (!nca) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const auto romfs = nca->GetRomFS();
|
||||||
|
if (!romfs) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const auto extracted = FileSys::ExtractRomFS(romfs);
|
||||||
|
if (!extracted) {
|
||||||
|
LOG_ERROR(Service_SSL, "CertStore could not be extracted, corrupt RomFS?");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const auto cert_store_file = extracted->GetFile("ssl_TrustedCerts.bdf");
|
||||||
|
if (!cert_store_file) {
|
||||||
|
LOG_ERROR(Service_SSL, "Failed to find trusted certificates in CertStore");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Read and verify the header.
|
||||||
|
CertStoreHeader header;
|
||||||
|
cert_store_file->ReadObject(std::addressof(header));
|
||||||
|
|
||||||
|
if (header.magic != Common::MakeMagic('s', 's', 'l', 'T')) {
|
||||||
|
LOG_ERROR(Service_SSL, "Invalid certificate store magic");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ensure the file can contains the number of entries it says it does.
|
||||||
|
const u64 expected_size = sizeof(header) + sizeof(CertStoreEntry) * header.num_entries;
|
||||||
|
const u64 actual_size = cert_store_file->GetSize();
|
||||||
|
if (actual_size < expected_size) {
|
||||||
|
LOG_ERROR(Service_SSL, "Size mismatch, expected at least {} bytes, got {}", expected_size,
|
||||||
|
actual_size);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Read entries.
|
||||||
|
std::vector<CertStoreEntry> entries(header.num_entries);
|
||||||
|
cert_store_file->ReadArray(entries.data(), header.num_entries, sizeof(header));
|
||||||
|
|
||||||
|
// Insert into memory store.
|
||||||
|
for (const auto& entry : entries) {
|
||||||
|
m_certs.emplace(entry.certificate_id,
|
||||||
|
Certificate{
|
||||||
|
.status = entry.certificate_status,
|
||||||
|
.der_data = cert_store_file->ReadBytes(
|
||||||
|
entry.der_size, entry.der_offset + sizeof(header)),
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CertStore::~CertStore() = default;
|
||||||
|
|
||||||
|
template <typename F>
|
||||||
|
void CertStore::ForEachCertificate(std::span<const CaCertificateId> certificate_ids, F&& f) {
|
||||||
|
if (certificate_ids.size() == 1 && certificate_ids.front() == CaCertificateId::All) {
|
||||||
|
for (const auto& entry : m_certs) {
|
||||||
|
f(entry);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (const auto certificate_id : certificate_ids) {
|
||||||
|
const auto entry = m_certs.find(certificate_id);
|
||||||
|
if (entry == m_certs.end()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
f(*entry);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Result CertStore::GetCertificates(u32* out_num_entries, std::span<u8> out_data,
|
||||||
|
std::span<const CaCertificateId> certificate_ids) {
|
||||||
|
// Ensure the buffer is large enough to hold the output.
|
||||||
|
u32 required_size;
|
||||||
|
R_TRY(this->GetCertificateBufSize(std::addressof(required_size), out_num_entries,
|
||||||
|
certificate_ids));
|
||||||
|
R_UNLESS(out_data.size_bytes() >= required_size, ResultUnknown);
|
||||||
|
|
||||||
|
// Make parallel arrays.
|
||||||
|
std::vector<BuiltInCertificateInfo> cert_infos;
|
||||||
|
std::vector<u8> der_datas;
|
||||||
|
|
||||||
|
const u32 der_data_offset = (*out_num_entries + 1) * sizeof(BuiltInCertificateInfo);
|
||||||
|
u32 cur_der_offset = der_data_offset;
|
||||||
|
|
||||||
|
// Fill output.
|
||||||
|
this->ForEachCertificate(certificate_ids, [&](auto& entry) {
|
||||||
|
const auto& [status, cur_der_data] = entry.second;
|
||||||
|
BuiltInCertificateInfo cert_info{
|
||||||
|
.cert_id = entry.first,
|
||||||
|
.status = status,
|
||||||
|
.der_size = cur_der_data.size(),
|
||||||
|
.der_offset = cur_der_offset,
|
||||||
|
};
|
||||||
|
|
||||||
|
cert_infos.push_back(cert_info);
|
||||||
|
der_datas.insert(der_datas.end(), cur_der_data.begin(), cur_der_data.end());
|
||||||
|
cur_der_offset += static_cast<u32>(cur_der_data.size());
|
||||||
|
});
|
||||||
|
|
||||||
|
// Append terminator entry.
|
||||||
|
cert_infos.push_back(BuiltInCertificateInfo{
|
||||||
|
.cert_id = CaCertificateId::All,
|
||||||
|
.status = TrustedCertStatus::Invalid,
|
||||||
|
.der_size = 0,
|
||||||
|
.der_offset = 0,
|
||||||
|
});
|
||||||
|
|
||||||
|
// Write to output span.
|
||||||
|
std::memcpy(out_data.data(), cert_infos.data(),
|
||||||
|
cert_infos.size() * sizeof(BuiltInCertificateInfo));
|
||||||
|
std::memcpy(out_data.data() + der_data_offset, der_datas.data(), der_datas.size());
|
||||||
|
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
Result CertStore::GetCertificateBufSize(u32* out_size, u32* out_num_entries,
|
||||||
|
std::span<const CaCertificateId> certificate_ids) {
|
||||||
|
// Output size is at least the size of the terminator entry.
|
||||||
|
*out_size = sizeof(BuiltInCertificateInfo);
|
||||||
|
*out_num_entries = 0;
|
||||||
|
|
||||||
|
this->ForEachCertificate(certificate_ids, [&](auto& entry) {
|
||||||
|
*out_size += sizeof(BuiltInCertificateInfo);
|
||||||
|
*out_size += Common::AlignUp(static_cast<u32>(entry.second.der_data.size()), 4);
|
||||||
|
(*out_num_entries)++;
|
||||||
|
});
|
||||||
|
|
||||||
|
R_SUCCEED();
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Service::SSL
|
42
src/core/hle/service/ssl/cert_store.h
Normal file
42
src/core/hle/service/ssl/cert_store.h
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
#include <span>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
#include "core/hle/result.h"
|
||||||
|
#include "core/hle/service/ssl/ssl_types.h"
|
||||||
|
|
||||||
|
namespace Core {
|
||||||
|
class System;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace Service::SSL {
|
||||||
|
|
||||||
|
class CertStore {
|
||||||
|
public:
|
||||||
|
explicit CertStore(Core::System& system);
|
||||||
|
~CertStore();
|
||||||
|
|
||||||
|
Result GetCertificates(u32* out_num_entries, std::span<u8> out_data,
|
||||||
|
std::span<const CaCertificateId> certificate_ids);
|
||||||
|
Result GetCertificateBufSize(u32* out_size, u32* out_num_entries,
|
||||||
|
std::span<const CaCertificateId> certificate_ids);
|
||||||
|
|
||||||
|
private:
|
||||||
|
template <typename F>
|
||||||
|
void ForEachCertificate(std::span<const CaCertificateId> certs, F&& f);
|
||||||
|
|
||||||
|
private:
|
||||||
|
struct Certificate {
|
||||||
|
TrustedCertStatus status;
|
||||||
|
std::vector<u8> der_data;
|
||||||
|
};
|
||||||
|
|
||||||
|
std::map<CaCertificateId, Certificate> m_certs;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace Service::SSL
|
|
@ -5,11 +5,13 @@
|
||||||
|
|
||||||
#include "core/core.h"
|
#include "core/core.h"
|
||||||
#include "core/hle/result.h"
|
#include "core/hle/result.h"
|
||||||
|
#include "core/hle/service/cmif_serialization.h"
|
||||||
#include "core/hle/service/ipc_helpers.h"
|
#include "core/hle/service/ipc_helpers.h"
|
||||||
#include "core/hle/service/server_manager.h"
|
#include "core/hle/service/server_manager.h"
|
||||||
#include "core/hle/service/service.h"
|
#include "core/hle/service/service.h"
|
||||||
#include "core/hle/service/sm/sm.h"
|
#include "core/hle/service/sm/sm.h"
|
||||||
#include "core/hle/service/sockets/bsd.h"
|
#include "core/hle/service/sockets/bsd.h"
|
||||||
|
#include "core/hle/service/ssl/cert_store.h"
|
||||||
#include "core/hle/service/ssl/ssl.h"
|
#include "core/hle/service/ssl/ssl.h"
|
||||||
#include "core/hle/service/ssl/ssl_backend.h"
|
#include "core/hle/service/ssl/ssl_backend.h"
|
||||||
#include "core/internal_network/network.h"
|
#include "core/internal_network/network.h"
|
||||||
|
@ -492,13 +494,14 @@ private:
|
||||||
|
|
||||||
class ISslService final : public ServiceFramework<ISslService> {
|
class ISslService final : public ServiceFramework<ISslService> {
|
||||||
public:
|
public:
|
||||||
explicit ISslService(Core::System& system_) : ServiceFramework{system_, "ssl"} {
|
explicit ISslService(Core::System& system_)
|
||||||
|
: ServiceFramework{system_, "ssl"}, cert_store{system} {
|
||||||
// clang-format off
|
// clang-format off
|
||||||
static const FunctionInfo functions[] = {
|
static const FunctionInfo functions[] = {
|
||||||
{0, &ISslService::CreateContext, "CreateContext"},
|
{0, &ISslService::CreateContext, "CreateContext"},
|
||||||
{1, nullptr, "GetContextCount"},
|
{1, nullptr, "GetContextCount"},
|
||||||
{2, nullptr, "GetCertificates"},
|
{2, D<&ISslService::GetCertificates>, "GetCertificates"},
|
||||||
{3, nullptr, "GetCertificateBufSize"},
|
{3, D<&ISslService::GetCertificateBufSize>, "GetCertificateBufSize"},
|
||||||
{4, nullptr, "DebugIoctl"},
|
{4, nullptr, "DebugIoctl"},
|
||||||
{5, &ISslService::SetInterfaceVersion, "SetInterfaceVersion"},
|
{5, &ISslService::SetInterfaceVersion, "SetInterfaceVersion"},
|
||||||
{6, nullptr, "FlushSessionCache"},
|
{6, nullptr, "FlushSessionCache"},
|
||||||
|
@ -540,6 +543,22 @@ private:
|
||||||
IPC::ResponseBuilder rb{ctx, 2};
|
IPC::ResponseBuilder rb{ctx, 2};
|
||||||
rb.Push(ResultSuccess);
|
rb.Push(ResultSuccess);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Result GetCertificateBufSize(
|
||||||
|
Out<u32> out_size, InArray<CaCertificateId, BufferAttr_HipcMapAlias> certificate_ids) {
|
||||||
|
LOG_INFO(Service_SSL, "called");
|
||||||
|
u32 num_entries;
|
||||||
|
R_RETURN(cert_store.GetCertificateBufSize(out_size, &num_entries, certificate_ids));
|
||||||
|
}
|
||||||
|
|
||||||
|
Result GetCertificates(Out<u32> out_num_entries, OutBuffer<BufferAttr_HipcMapAlias> out_buffer,
|
||||||
|
InArray<CaCertificateId, BufferAttr_HipcMapAlias> certificate_ids) {
|
||||||
|
LOG_INFO(Service_SSL, "called");
|
||||||
|
R_RETURN(cert_store.GetCertificates(out_num_entries, out_buffer, certificate_ids));
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
CertStore cert_store;
|
||||||
};
|
};
|
||||||
|
|
||||||
void LoopProcess(Core::System& system) {
|
void LoopProcess(Core::System& system) {
|
||||||
|
|
107
src/core/hle/service/ssl/ssl_types.h
Normal file
107
src/core/hle/service/ssl/ssl_types.h
Normal file
|
@ -0,0 +1,107 @@
|
||||||
|
// SPDX-FileCopyrightText: Copyright 2024 yuzu Emulator Project
|
||||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "common/common_types.h"
|
||||||
|
|
||||||
|
namespace Service::SSL {
|
||||||
|
|
||||||
|
enum class CaCertificateId : s32 {
|
||||||
|
All = -1,
|
||||||
|
NintendoCAG3 = 1,
|
||||||
|
NintendoClass2CAG3 = 2,
|
||||||
|
NintendoRootCAG4 = 3,
|
||||||
|
AmazonRootCA1 = 1000,
|
||||||
|
StarfieldServicesRootCertificateAuthorityG2 = 1001,
|
||||||
|
AddTrustExternalCARoot = 1002,
|
||||||
|
COMODOCertificationAuthority = 1003,
|
||||||
|
UTNDATACorpSGC = 1004,
|
||||||
|
UTNUSERFirstHardware = 1005,
|
||||||
|
BaltimoreCyberTrustRoot = 1006,
|
||||||
|
CybertrustGlobalRoot = 1007,
|
||||||
|
VerizonGlobalRootCA = 1008,
|
||||||
|
DigiCertAssuredIDRootCA = 1009,
|
||||||
|
DigiCertAssuredIDRootG2 = 1010,
|
||||||
|
DigiCertGlobalRootCA = 1011,
|
||||||
|
DigiCertGlobalRootG2 = 1012,
|
||||||
|
DigiCertHighAssuranceEVRootCA = 1013,
|
||||||
|
EntrustnetCertificationAuthority2048 = 1014,
|
||||||
|
EntrustRootCertificationAuthority = 1015,
|
||||||
|
EntrustRootCertificationAuthorityG2 = 1016,
|
||||||
|
GeoTrustGlobalCA2 = 1017,
|
||||||
|
GeoTrustGlobalCA = 1018,
|
||||||
|
GeoTrustPrimaryCertificationAuthorityG3 = 1019,
|
||||||
|
GeoTrustPrimaryCertificationAuthority = 1020,
|
||||||
|
GlobalSignRootCA = 1021,
|
||||||
|
GlobalSignRootCAR2 = 1022,
|
||||||
|
GlobalSignRootCAR3 = 1023,
|
||||||
|
GoDaddyClass2CertificationAuthority = 1024,
|
||||||
|
GoDaddyRootCertificateAuthorityG2 = 1025,
|
||||||
|
StarfieldClass2CertificationAuthority = 1026,
|
||||||
|
StarfieldRootCertificateAuthorityG2 = 1027,
|
||||||
|
thawtePrimaryRootCAG3 = 1028,
|
||||||
|
thawtePrimaryRootCA = 1029,
|
||||||
|
VeriSignClass3PublicPrimaryCertificationAuthorityG3 = 1030,
|
||||||
|
VeriSignClass3PublicPrimaryCertificationAuthorityG5 = 1031,
|
||||||
|
VeriSignUniversalRootCertificationAuthority = 1032,
|
||||||
|
DSTRootCAX3 = 1033,
|
||||||
|
USERTrustRsaCertificationAuthority = 1034,
|
||||||
|
ISRGRootX10 = 1035,
|
||||||
|
USERTrustEccCertificationAuthority = 1036,
|
||||||
|
COMODORsaCertificationAuthority = 1037,
|
||||||
|
COMODOEccCertificationAuthority = 1038,
|
||||||
|
AmazonRootCA2 = 1039,
|
||||||
|
AmazonRootCA3 = 1040,
|
||||||
|
AmazonRootCA4 = 1041,
|
||||||
|
DigiCertAssuredIDRootG3 = 1042,
|
||||||
|
DigiCertGlobalRootG3 = 1043,
|
||||||
|
DigiCertTrustedRootG4 = 1044,
|
||||||
|
EntrustRootCertificationAuthorityEC1 = 1045,
|
||||||
|
EntrustRootCertificationAuthorityG4 = 1046,
|
||||||
|
GlobalSignECCRootCAR4 = 1047,
|
||||||
|
GlobalSignECCRootCAR5 = 1048,
|
||||||
|
GlobalSignECCRootCAR6 = 1049,
|
||||||
|
GTSRootR1 = 1050,
|
||||||
|
GTSRootR2 = 1051,
|
||||||
|
GTSRootR3 = 1052,
|
||||||
|
GTSRootR4 = 1053,
|
||||||
|
SecurityCommunicationRootCA = 1054,
|
||||||
|
GlobalSignRootE4 = 1055,
|
||||||
|
GlobalSignRootR4 = 1056,
|
||||||
|
TTeleSecGlobalRootClass2 = 1057,
|
||||||
|
DigiCertTLSECCP384RootG5 = 1058,
|
||||||
|
DigiCertTLSRSA4096RootG5 = 1059,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum class TrustedCertStatus : s32 {
|
||||||
|
Invalid = -1,
|
||||||
|
Removed = 0,
|
||||||
|
EnabledTrusted = 1,
|
||||||
|
EnabledNotTrusted = 2,
|
||||||
|
Revoked = 3,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct BuiltInCertificateInfo {
|
||||||
|
CaCertificateId cert_id;
|
||||||
|
TrustedCertStatus status;
|
||||||
|
u64 der_size;
|
||||||
|
u64 der_offset;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(BuiltInCertificateInfo) == 0x18, "BuiltInCertificateInfo has incorrect size.");
|
||||||
|
|
||||||
|
struct CertStoreHeader {
|
||||||
|
u32 magic;
|
||||||
|
u32 num_entries;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(CertStoreHeader) == 0x8, "CertStoreHeader has incorrect size.");
|
||||||
|
|
||||||
|
struct CertStoreEntry {
|
||||||
|
CaCertificateId certificate_id;
|
||||||
|
TrustedCertStatus certificate_status;
|
||||||
|
u32 der_size;
|
||||||
|
u32 der_offset;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(CertStoreEntry) == 0x10, "CertStoreEntry has incorrect size.");
|
||||||
|
|
||||||
|
} // namespace Service::SSL
|
|
@ -1488,7 +1488,10 @@ void BufferCache<P>::ImmediateUploadMemory([[maybe_unused]] Buffer& buffer,
|
||||||
std::span<const u8> upload_span;
|
std::span<const u8> upload_span;
|
||||||
const DAddr device_addr = buffer.CpuAddr() + copy.dst_offset;
|
const DAddr device_addr = buffer.CpuAddr() + copy.dst_offset;
|
||||||
if (IsRangeGranular(device_addr, copy.size)) {
|
if (IsRangeGranular(device_addr, copy.size)) {
|
||||||
upload_span = std::span(device_memory.GetPointer<u8>(device_addr), copy.size);
|
auto* const ptr = device_memory.GetPointer<u8>(device_addr);
|
||||||
|
if (ptr != nullptr) {
|
||||||
|
upload_span = std::span(ptr, copy.size);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (immediate_buffer.empty()) {
|
if (immediate_buffer.empty()) {
|
||||||
immediate_buffer = ImmediateBuffer(largest_copy);
|
immediate_buffer = ImmediateBuffer(largest_copy);
|
||||||
|
|
|
@ -216,14 +216,11 @@ void DrawManager::DrawTexture() {
|
||||||
const bool lower_left{regs.window_origin.mode !=
|
const bool lower_left{regs.window_origin.mode !=
|
||||||
Maxwell3D::Regs::WindowOrigin::Mode::UpperLeft};
|
Maxwell3D::Regs::WindowOrigin::Mode::UpperLeft};
|
||||||
if (lower_left) {
|
if (lower_left) {
|
||||||
draw_texture_state.dst_y0 -= dst_height;
|
draw_texture_state.dst_y0 =
|
||||||
|
static_cast<f32>(regs.surface_clip.height) - draw_texture_state.dst_y0;
|
||||||
}
|
}
|
||||||
draw_texture_state.dst_x1 =
|
draw_texture_state.dst_x1 = draw_texture_state.dst_x0 + dst_width;
|
||||||
draw_texture_state.dst_x0 +
|
draw_texture_state.dst_y1 = draw_texture_state.dst_y0 + dst_height;
|
||||||
static_cast<f32>(Settings::values.resolution_info.ScaleUp(static_cast<u32>(dst_width)));
|
|
||||||
draw_texture_state.dst_y1 =
|
|
||||||
draw_texture_state.dst_y0 +
|
|
||||||
static_cast<f32>(Settings::values.resolution_info.ScaleUp(static_cast<u32>(dst_height)));
|
|
||||||
draw_texture_state.src_x0 = static_cast<float>(regs.draw_texture.src_x0) / 4096.f;
|
draw_texture_state.src_x0 = static_cast<float>(regs.draw_texture.src_x0) / 4096.f;
|
||||||
draw_texture_state.src_y0 = static_cast<float>(regs.draw_texture.src_y0) / 4096.f;
|
draw_texture_state.src_y0 = static_cast<float>(regs.draw_texture.src_y0) / 4096.f;
|
||||||
draw_texture_state.src_x1 =
|
draw_texture_state.src_x1 =
|
||||||
|
|
|
@ -370,27 +370,32 @@ void RasterizerOpenGL::DrawTexture() {
|
||||||
const auto& sampler = texture_cache.GetGraphicsSampler(draw_texture_state.src_sampler);
|
const auto& sampler = texture_cache.GetGraphicsSampler(draw_texture_state.src_sampler);
|
||||||
const auto& texture = texture_cache.GetImageView(draw_texture_state.src_texture);
|
const auto& texture = texture_cache.GetImageView(draw_texture_state.src_texture);
|
||||||
|
|
||||||
|
const auto Scale = [&](auto dim) -> s32 {
|
||||||
|
return Settings::values.resolution_info.ScaleUp(static_cast<s32>(dim));
|
||||||
|
};
|
||||||
|
|
||||||
|
Region2D dst_region = {
|
||||||
|
Offset2D{.x = Scale(draw_texture_state.dst_x0), .y = Scale(draw_texture_state.dst_y0)},
|
||||||
|
Offset2D{.x = Scale(draw_texture_state.dst_x1), .y = Scale(draw_texture_state.dst_y1)}};
|
||||||
|
Region2D src_region = {
|
||||||
|
Offset2D{.x = Scale(draw_texture_state.src_x0), .y = Scale(draw_texture_state.src_y0)},
|
||||||
|
Offset2D{.x = Scale(draw_texture_state.src_x1), .y = Scale(draw_texture_state.src_y1)}};
|
||||||
|
Extent3D src_size = {static_cast<u32>(Scale(texture.size.width)),
|
||||||
|
static_cast<u32>(Scale(texture.size.height)), texture.size.depth};
|
||||||
|
|
||||||
if (device.HasDrawTexture()) {
|
if (device.HasDrawTexture()) {
|
||||||
state_tracker.BindFramebuffer(texture_cache.GetFramebuffer()->Handle());
|
state_tracker.BindFramebuffer(texture_cache.GetFramebuffer()->Handle());
|
||||||
|
|
||||||
glDrawTextureNV(texture.DefaultHandle(), sampler->Handle(), draw_texture_state.dst_x0,
|
glDrawTextureNV(texture.DefaultHandle(), sampler->Handle(),
|
||||||
draw_texture_state.dst_y0, draw_texture_state.dst_x1,
|
static_cast<f32>(dst_region.start.x), static_cast<f32>(dst_region.start.y),
|
||||||
draw_texture_state.dst_y1, 0,
|
static_cast<f32>(dst_region.end.x), static_cast<f32>(dst_region.end.y), 0,
|
||||||
draw_texture_state.src_x0 / static_cast<float>(texture.size.width),
|
draw_texture_state.src_x0 / static_cast<float>(texture.size.width),
|
||||||
draw_texture_state.src_y0 / static_cast<float>(texture.size.height),
|
draw_texture_state.src_y0 / static_cast<float>(texture.size.height),
|
||||||
draw_texture_state.src_x1 / static_cast<float>(texture.size.width),
|
draw_texture_state.src_x1 / static_cast<float>(texture.size.width),
|
||||||
draw_texture_state.src_y1 / static_cast<float>(texture.size.height));
|
draw_texture_state.src_y1 / static_cast<float>(texture.size.height));
|
||||||
} else {
|
} else {
|
||||||
Region2D dst_region = {Offset2D{.x = static_cast<s32>(draw_texture_state.dst_x0),
|
|
||||||
.y = static_cast<s32>(draw_texture_state.dst_y0)},
|
|
||||||
Offset2D{.x = static_cast<s32>(draw_texture_state.dst_x1),
|
|
||||||
.y = static_cast<s32>(draw_texture_state.dst_y1)}};
|
|
||||||
Region2D src_region = {Offset2D{.x = static_cast<s32>(draw_texture_state.src_x0),
|
|
||||||
.y = static_cast<s32>(draw_texture_state.src_y0)},
|
|
||||||
Offset2D{.x = static_cast<s32>(draw_texture_state.src_x1),
|
|
||||||
.y = static_cast<s32>(draw_texture_state.src_y1)}};
|
|
||||||
blit_image.BlitColor(texture_cache.GetFramebuffer()->Handle(), texture.DefaultHandle(),
|
blit_image.BlitColor(texture_cache.GetFramebuffer()->Handle(), texture.DefaultHandle(),
|
||||||
sampler->Handle(), dst_region, src_region, texture.size);
|
sampler->Handle(), dst_region, src_region, src_size);
|
||||||
state_tracker.InvalidateState();
|
state_tracker.InvalidateState();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1064,8 +1064,6 @@ public:
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
auto* ptr = device_memory.GetPointer<u8>(new_query->dependant_address);
|
|
||||||
ASSERT(ptr != nullptr);
|
|
||||||
|
|
||||||
new_query->dependant_manage = must_manage_dependance;
|
new_query->dependant_manage = must_manage_dependance;
|
||||||
pending_flush_queries.push_back(index);
|
pending_flush_queries.push_back(index);
|
||||||
|
@ -1104,9 +1102,11 @@ public:
|
||||||
tfb_streamer.Free(query->dependant_index);
|
tfb_streamer.Free(query->dependant_index);
|
||||||
} else {
|
} else {
|
||||||
u8* pointer = device_memory.GetPointer<u8>(query->dependant_address);
|
u8* pointer = device_memory.GetPointer<u8>(query->dependant_address);
|
||||||
u32 result;
|
if (pointer != nullptr) {
|
||||||
std::memcpy(&result, pointer, sizeof(u32));
|
u32 result;
|
||||||
num_vertices = static_cast<u64>(result) / query->stride;
|
std::memcpy(&result, pointer, sizeof(u32));
|
||||||
|
num_vertices = static_cast<u64>(result) / query->stride;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
query->value = [&]() -> u64 {
|
query->value = [&]() -> u64 {
|
||||||
switch (query->topology) {
|
switch (query->topology) {
|
||||||
|
@ -1360,7 +1360,9 @@ bool QueryCacheRuntime::HostConditionalRenderingCompareValues(VideoCommon::Looku
|
||||||
const auto check_value = [&](DAddr address) {
|
const auto check_value = [&](DAddr address) {
|
||||||
u8* ptr = impl->device_memory.GetPointer<u8>(address);
|
u8* ptr = impl->device_memory.GetPointer<u8>(address);
|
||||||
u64 value{};
|
u64 value{};
|
||||||
std::memcpy(&value, ptr, sizeof(value));
|
if (ptr != nullptr) {
|
||||||
|
std::memcpy(&value, ptr, sizeof(value));
|
||||||
|
}
|
||||||
return value == 0;
|
return value == 0;
|
||||||
};
|
};
|
||||||
std::array<VideoCommon::LookupData*, 2> objects{&object_1, &object_2};
|
std::array<VideoCommon::LookupData*, 2> objects{&object_1, &object_2};
|
||||||
|
|
|
@ -125,11 +125,23 @@ VkRect2D GetScissorState(const Maxwell& regs, size_t index, u32 up_scale = 1, u3
|
||||||
return value < 0 ? std::min<s32>(converted_value - acumm, -1)
|
return value < 0 ? std::min<s32>(converted_value - acumm, -1)
|
||||||
: std::max<s32>(converted_value + acumm, 1);
|
: std::max<s32>(converted_value + acumm, 1);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const bool lower_left = regs.window_origin.mode != Maxwell::WindowOrigin::Mode::UpperLeft;
|
||||||
|
const s32 clip_height = regs.surface_clip.height;
|
||||||
|
|
||||||
|
// Flip coordinates if lower left
|
||||||
|
s32 min_y = lower_left ? (clip_height - src.max_y) : src.min_y.Value();
|
||||||
|
s32 max_y = lower_left ? (clip_height - src.min_y) : src.max_y.Value();
|
||||||
|
|
||||||
|
// Bound to render area
|
||||||
|
min_y = std::max(min_y, 0);
|
||||||
|
max_y = std::max(max_y, 0);
|
||||||
|
|
||||||
if (src.enable) {
|
if (src.enable) {
|
||||||
scissor.offset.x = scale_up(static_cast<s32>(src.min_x));
|
scissor.offset.x = scale_up(src.min_x);
|
||||||
scissor.offset.y = scale_up(static_cast<s32>(src.min_y));
|
scissor.offset.y = scale_up(min_y);
|
||||||
scissor.extent.width = scale_up(src.max_x - src.min_x);
|
scissor.extent.width = scale_up(src.max_x - src.min_x);
|
||||||
scissor.extent.height = scale_up(src.max_y - src.min_y);
|
scissor.extent.height = scale_up(max_y - min_y);
|
||||||
} else {
|
} else {
|
||||||
scissor.offset.x = 0;
|
scissor.offset.x = 0;
|
||||||
scissor.offset.y = 0;
|
scissor.offset.y = 0;
|
||||||
|
@ -308,17 +320,33 @@ void RasterizerVulkan::DrawTexture() {
|
||||||
const auto& draw_texture_state = maxwell3d->draw_manager->GetDrawTextureState();
|
const auto& draw_texture_state = maxwell3d->draw_manager->GetDrawTextureState();
|
||||||
const auto& sampler = texture_cache.GetGraphicsSampler(draw_texture_state.src_sampler);
|
const auto& sampler = texture_cache.GetGraphicsSampler(draw_texture_state.src_sampler);
|
||||||
const auto& texture = texture_cache.GetImageView(draw_texture_state.src_texture);
|
const auto& texture = texture_cache.GetImageView(draw_texture_state.src_texture);
|
||||||
Region2D dst_region = {Offset2D{.x = static_cast<s32>(draw_texture_state.dst_x0),
|
const auto* framebuffer = texture_cache.GetFramebuffer();
|
||||||
.y = static_cast<s32>(draw_texture_state.dst_y0)},
|
|
||||||
Offset2D{.x = static_cast<s32>(draw_texture_state.dst_x1),
|
const bool src_rescaling = texture_cache.IsRescaling() && texture.IsRescaled();
|
||||||
.y = static_cast<s32>(draw_texture_state.dst_y1)}};
|
const bool dst_rescaling = texture_cache.IsRescaling() && framebuffer->IsRescaled();
|
||||||
Region2D src_region = {Offset2D{.x = static_cast<s32>(draw_texture_state.src_x0),
|
|
||||||
.y = static_cast<s32>(draw_texture_state.src_y0)},
|
const auto ScaleSrc = [&](auto dim_f) -> s32 {
|
||||||
Offset2D{.x = static_cast<s32>(draw_texture_state.src_x1),
|
auto dim = static_cast<s32>(dim_f);
|
||||||
.y = static_cast<s32>(draw_texture_state.src_y1)}};
|
return src_rescaling ? Settings::values.resolution_info.ScaleUp(dim) : dim;
|
||||||
blit_image.BlitColor(texture_cache.GetFramebuffer(), texture.RenderTarget(),
|
};
|
||||||
texture.ImageHandle(), sampler->Handle(), dst_region, src_region,
|
|
||||||
texture.size);
|
const auto ScaleDst = [&](auto dim_f) -> s32 {
|
||||||
|
auto dim = static_cast<s32>(dim_f);
|
||||||
|
return dst_rescaling ? Settings::values.resolution_info.ScaleUp(dim) : dim;
|
||||||
|
};
|
||||||
|
|
||||||
|
Region2D dst_region = {Offset2D{.x = ScaleDst(draw_texture_state.dst_x0),
|
||||||
|
.y = ScaleDst(draw_texture_state.dst_y0)},
|
||||||
|
Offset2D{.x = ScaleDst(draw_texture_state.dst_x1),
|
||||||
|
.y = ScaleDst(draw_texture_state.dst_y1)}};
|
||||||
|
Region2D src_region = {Offset2D{.x = ScaleSrc(draw_texture_state.src_x0),
|
||||||
|
.y = ScaleSrc(draw_texture_state.src_y0)},
|
||||||
|
Offset2D{.x = ScaleSrc(draw_texture_state.src_x1),
|
||||||
|
.y = ScaleSrc(draw_texture_state.src_y1)}};
|
||||||
|
Extent3D src_size = {static_cast<u32>(ScaleSrc(texture.size.width)),
|
||||||
|
static_cast<u32>(ScaleSrc(texture.size.height)), texture.size.depth};
|
||||||
|
blit_image.BlitColor(framebuffer, texture.RenderTarget(), texture.ImageHandle(),
|
||||||
|
sampler->Handle(), dst_region, src_region, src_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RasterizerVulkan::Clear(u32 layer_count) {
|
void RasterizerVulkan::Clear(u32 layer_count) {
|
||||||
|
@ -1054,37 +1082,16 @@ void RasterizerVulkan::UpdateDepthBias(Tegra::Engines::Maxwell3D::Regs& regs) {
|
||||||
regs.zeta.format == Tegra::DepthFormat::X8Z24_UNORM ||
|
regs.zeta.format == Tegra::DepthFormat::X8Z24_UNORM ||
|
||||||
regs.zeta.format == Tegra::DepthFormat::S8Z24_UNORM ||
|
regs.zeta.format == Tegra::DepthFormat::S8Z24_UNORM ||
|
||||||
regs.zeta.format == Tegra::DepthFormat::V8Z24_UNORM;
|
regs.zeta.format == Tegra::DepthFormat::V8Z24_UNORM;
|
||||||
bool force_unorm = ([&] {
|
if (is_d24 && !device.SupportsD24DepthBuffer() &&
|
||||||
if (!is_d24 || device.SupportsD24DepthBuffer()) {
|
Settings::values.renderer_amdvlk_depth_bias_workaround) {
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (device.IsExtDepthBiasControlSupported()) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (!Settings::values.renderer_amdvlk_depth_bias_workaround) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
// the base formulas can be obtained from here:
|
// the base formulas can be obtained from here:
|
||||||
// https://docs.microsoft.com/en-us/windows/win32/direct3d11/d3d10-graphics-programming-guide-output-merger-stage-depth-bias
|
// https://docs.microsoft.com/en-us/windows/win32/direct3d11/d3d10-graphics-programming-guide-output-merger-stage-depth-bias
|
||||||
const double rescale_factor =
|
const double rescale_factor =
|
||||||
static_cast<double>(1ULL << (32 - 24)) / (static_cast<double>(0x1.ep+127));
|
static_cast<double>(1ULL << (32 - 24)) / (static_cast<double>(0x1.ep+127));
|
||||||
units = static_cast<float>(static_cast<double>(units) * rescale_factor);
|
units = static_cast<float>(static_cast<double>(units) * rescale_factor);
|
||||||
return false;
|
}
|
||||||
})();
|
|
||||||
scheduler.Record([constant = units, clamp = regs.depth_bias_clamp,
|
scheduler.Record([constant = units, clamp = regs.depth_bias_clamp,
|
||||||
factor = regs.slope_scale_depth_bias, force_unorm,
|
factor = regs.slope_scale_depth_bias](vk::CommandBuffer cmdbuf) {
|
||||||
precise = device.HasExactDepthBiasControl()](vk::CommandBuffer cmdbuf) {
|
|
||||||
if (force_unorm) {
|
|
||||||
VkDepthBiasRepresentationInfoEXT info{
|
|
||||||
.sType = VK_STRUCTURE_TYPE_DEPTH_BIAS_REPRESENTATION_INFO_EXT,
|
|
||||||
.pNext = nullptr,
|
|
||||||
.depthBiasRepresentation =
|
|
||||||
VK_DEPTH_BIAS_REPRESENTATION_LEAST_REPRESENTABLE_VALUE_FORCE_UNORM_EXT,
|
|
||||||
.depthBiasExact = precise ? VK_TRUE : VK_FALSE,
|
|
||||||
};
|
|
||||||
cmdbuf.SetDepthBias(constant, clamp, factor, &info);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
cmdbuf.SetDepthBias(constant, clamp, factor);
|
cmdbuf.SetDepthBias(constant, clamp, factor);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -1962,21 +1962,22 @@ Framebuffer::Framebuffer(TextureCacheRuntime& runtime, std::span<ImageView*, NUM
|
||||||
}
|
}
|
||||||
|
|
||||||
Framebuffer::Framebuffer(TextureCacheRuntime& runtime, ImageView* color_buffer,
|
Framebuffer::Framebuffer(TextureCacheRuntime& runtime, ImageView* color_buffer,
|
||||||
ImageView* depth_buffer, VkExtent2D extent, bool is_rescaled)
|
ImageView* depth_buffer, VkExtent2D extent, bool is_rescaled_)
|
||||||
: render_area{extent} {
|
: render_area{extent} {
|
||||||
std::array<ImageView*, NUM_RT> color_buffers{color_buffer};
|
std::array<ImageView*, NUM_RT> color_buffers{color_buffer};
|
||||||
CreateFramebuffer(runtime, color_buffers, depth_buffer, is_rescaled);
|
CreateFramebuffer(runtime, color_buffers, depth_buffer, is_rescaled_);
|
||||||
}
|
}
|
||||||
|
|
||||||
Framebuffer::~Framebuffer() = default;
|
Framebuffer::~Framebuffer() = default;
|
||||||
|
|
||||||
void Framebuffer::CreateFramebuffer(TextureCacheRuntime& runtime,
|
void Framebuffer::CreateFramebuffer(TextureCacheRuntime& runtime,
|
||||||
std::span<ImageView*, NUM_RT> color_buffers,
|
std::span<ImageView*, NUM_RT> color_buffers,
|
||||||
ImageView* depth_buffer, bool is_rescaled) {
|
ImageView* depth_buffer, bool is_rescaled_) {
|
||||||
boost::container::small_vector<VkImageView, NUM_RT + 1> attachments;
|
boost::container::small_vector<VkImageView, NUM_RT + 1> attachments;
|
||||||
RenderPassKey renderpass_key{};
|
RenderPassKey renderpass_key{};
|
||||||
s32 num_layers = 1;
|
s32 num_layers = 1;
|
||||||
|
|
||||||
|
is_rescaled = is_rescaled_;
|
||||||
const auto& resolution = runtime.resolution;
|
const auto& resolution = runtime.resolution;
|
||||||
|
|
||||||
u32 width = std::numeric_limits<u32>::max();
|
u32 width = std::numeric_limits<u32>::max();
|
||||||
|
|
|
@ -361,6 +361,10 @@ public:
|
||||||
return has_stencil;
|
return has_stencil;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[[nodiscard]] bool IsRescaled() const noexcept {
|
||||||
|
return is_rescaled;
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
vk::Framebuffer framebuffer;
|
vk::Framebuffer framebuffer;
|
||||||
VkRenderPass renderpass{};
|
VkRenderPass renderpass{};
|
||||||
|
@ -373,6 +377,7 @@ private:
|
||||||
std::array<size_t, NUM_RT> rt_map{};
|
std::array<size_t, NUM_RT> rt_map{};
|
||||||
bool has_depth{};
|
bool has_depth{};
|
||||||
bool has_stencil{};
|
bool has_stencil{};
|
||||||
|
bool is_rescaled{};
|
||||||
};
|
};
|
||||||
|
|
||||||
struct TextureCacheParams {
|
struct TextureCacheParams {
|
||||||
|
|
|
@ -72,12 +72,19 @@ TextureCache<P>::TextureCache(Runtime& runtime_, Tegra::MaxwellDeviceMemoryManag
|
||||||
|
|
||||||
template <class P>
|
template <class P>
|
||||||
void TextureCache<P>::RunGarbageCollector() {
|
void TextureCache<P>::RunGarbageCollector() {
|
||||||
bool high_priority_mode = total_used_memory >= expected_memory;
|
bool high_priority_mode = false;
|
||||||
bool aggressive_mode = total_used_memory >= critical_memory;
|
bool aggressive_mode = false;
|
||||||
const u64 ticks_to_destroy = aggressive_mode ? 10ULL : high_priority_mode ? 25ULL : 50ULL;
|
u64 ticks_to_destroy = 0;
|
||||||
size_t num_iterations = aggressive_mode ? 40 : (high_priority_mode ? 20 : 10);
|
size_t num_iterations = 0;
|
||||||
const auto clean_up = [this, &num_iterations, &high_priority_mode,
|
|
||||||
&aggressive_mode](ImageId image_id) {
|
const auto Configure = [&](bool allow_aggressive) {
|
||||||
|
high_priority_mode = total_used_memory >= expected_memory;
|
||||||
|
aggressive_mode = allow_aggressive && total_used_memory >= critical_memory;
|
||||||
|
ticks_to_destroy = aggressive_mode ? 10ULL : high_priority_mode ? 25ULL : 50ULL;
|
||||||
|
num_iterations = aggressive_mode ? 40 : (high_priority_mode ? 20 : 10);
|
||||||
|
};
|
||||||
|
const auto Cleanup = [this, &num_iterations, &high_priority_mode,
|
||||||
|
&aggressive_mode](ImageId image_id) {
|
||||||
if (num_iterations == 0) {
|
if (num_iterations == 0) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -123,7 +130,16 @@ void TextureCache<P>::RunGarbageCollector() {
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
lru_cache.ForEachItemBelow(frame_tick - ticks_to_destroy, clean_up);
|
|
||||||
|
// Try to remove anything old enough and not high priority.
|
||||||
|
Configure(false);
|
||||||
|
lru_cache.ForEachItemBelow(frame_tick - ticks_to_destroy, Cleanup);
|
||||||
|
|
||||||
|
// If pressure is still too high, prune aggressively.
|
||||||
|
if (total_used_memory >= critical_memory) {
|
||||||
|
Configure(true);
|
||||||
|
lru_cache.ForEachItemBelow(frame_tick - ticks_to_destroy, Cleanup);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class P>
|
template <class P>
|
||||||
|
|
|
@ -1137,13 +1137,6 @@ void Device::RemoveUnsuitableExtensions() {
|
||||||
RemoveExtensionFeatureIfUnsuitable(extensions.custom_border_color, features.custom_border_color,
|
RemoveExtensionFeatureIfUnsuitable(extensions.custom_border_color, features.custom_border_color,
|
||||||
VK_EXT_CUSTOM_BORDER_COLOR_EXTENSION_NAME);
|
VK_EXT_CUSTOM_BORDER_COLOR_EXTENSION_NAME);
|
||||||
|
|
||||||
// VK_EXT_depth_bias_control
|
|
||||||
extensions.depth_bias_control =
|
|
||||||
features.depth_bias_control.depthBiasControl &&
|
|
||||||
features.depth_bias_control.leastRepresentableValueForceUnormRepresentation;
|
|
||||||
RemoveExtensionFeatureIfUnsuitable(extensions.depth_bias_control, features.depth_bias_control,
|
|
||||||
VK_EXT_DEPTH_BIAS_CONTROL_EXTENSION_NAME);
|
|
||||||
|
|
||||||
// VK_EXT_depth_clip_control
|
// VK_EXT_depth_clip_control
|
||||||
extensions.depth_clip_control = features.depth_clip_control.depthClipControl;
|
extensions.depth_clip_control = features.depth_clip_control.depthClipControl;
|
||||||
RemoveExtensionFeatureIfUnsuitable(extensions.depth_clip_control, features.depth_clip_control,
|
RemoveExtensionFeatureIfUnsuitable(extensions.depth_clip_control, features.depth_clip_control,
|
||||||
|
|
|
@ -41,7 +41,6 @@ VK_DEFINE_HANDLE(VmaAllocator)
|
||||||
// Define all features which may be used by the implementation and require an extension here.
|
// Define all features which may be used by the implementation and require an extension here.
|
||||||
#define FOR_EACH_VK_FEATURE_EXT(FEATURE) \
|
#define FOR_EACH_VK_FEATURE_EXT(FEATURE) \
|
||||||
FEATURE(EXT, CustomBorderColor, CUSTOM_BORDER_COLOR, custom_border_color) \
|
FEATURE(EXT, CustomBorderColor, CUSTOM_BORDER_COLOR, custom_border_color) \
|
||||||
FEATURE(EXT, DepthBiasControl, DEPTH_BIAS_CONTROL, depth_bias_control) \
|
|
||||||
FEATURE(EXT, DepthClipControl, DEPTH_CLIP_CONTROL, depth_clip_control) \
|
FEATURE(EXT, DepthClipControl, DEPTH_CLIP_CONTROL, depth_clip_control) \
|
||||||
FEATURE(EXT, ExtendedDynamicState, EXTENDED_DYNAMIC_STATE, extended_dynamic_state) \
|
FEATURE(EXT, ExtendedDynamicState, EXTENDED_DYNAMIC_STATE, extended_dynamic_state) \
|
||||||
FEATURE(EXT, ExtendedDynamicState2, EXTENDED_DYNAMIC_STATE_2, extended_dynamic_state2) \
|
FEATURE(EXT, ExtendedDynamicState2, EXTENDED_DYNAMIC_STATE_2, extended_dynamic_state2) \
|
||||||
|
@ -97,7 +96,6 @@ VK_DEFINE_HANDLE(VmaAllocator)
|
||||||
#define FOR_EACH_VK_RECOMMENDED_EXTENSION(EXTENSION_NAME) \
|
#define FOR_EACH_VK_RECOMMENDED_EXTENSION(EXTENSION_NAME) \
|
||||||
EXTENSION_NAME(VK_EXT_CONDITIONAL_RENDERING_EXTENSION_NAME) \
|
EXTENSION_NAME(VK_EXT_CONDITIONAL_RENDERING_EXTENSION_NAME) \
|
||||||
EXTENSION_NAME(VK_EXT_CONSERVATIVE_RASTERIZATION_EXTENSION_NAME) \
|
EXTENSION_NAME(VK_EXT_CONSERVATIVE_RASTERIZATION_EXTENSION_NAME) \
|
||||||
EXTENSION_NAME(VK_EXT_DEPTH_BIAS_CONTROL_EXTENSION_NAME) \
|
|
||||||
EXTENSION_NAME(VK_EXT_DEPTH_RANGE_UNRESTRICTED_EXTENSION_NAME) \
|
EXTENSION_NAME(VK_EXT_DEPTH_RANGE_UNRESTRICTED_EXTENSION_NAME) \
|
||||||
EXTENSION_NAME(VK_EXT_EXTENDED_DYNAMIC_STATE_EXTENSION_NAME) \
|
EXTENSION_NAME(VK_EXT_EXTENDED_DYNAMIC_STATE_EXTENSION_NAME) \
|
||||||
EXTENSION_NAME(VK_EXT_EXTENDED_DYNAMIC_STATE_2_EXTENSION_NAME) \
|
EXTENSION_NAME(VK_EXT_EXTENDED_DYNAMIC_STATE_2_EXTENSION_NAME) \
|
||||||
|
@ -150,9 +148,6 @@ VK_DEFINE_HANDLE(VmaAllocator)
|
||||||
// Define features where the absence of the feature may result in a degraded experience.
|
// Define features where the absence of the feature may result in a degraded experience.
|
||||||
#define FOR_EACH_VK_RECOMMENDED_FEATURE(FEATURE_NAME) \
|
#define FOR_EACH_VK_RECOMMENDED_FEATURE(FEATURE_NAME) \
|
||||||
FEATURE_NAME(custom_border_color, customBorderColors) \
|
FEATURE_NAME(custom_border_color, customBorderColors) \
|
||||||
FEATURE_NAME(depth_bias_control, depthBiasControl) \
|
|
||||||
FEATURE_NAME(depth_bias_control, leastRepresentableValueForceUnormRepresentation) \
|
|
||||||
FEATURE_NAME(depth_bias_control, depthBiasExact) \
|
|
||||||
FEATURE_NAME(extended_dynamic_state, extendedDynamicState) \
|
FEATURE_NAME(extended_dynamic_state, extendedDynamicState) \
|
||||||
FEATURE_NAME(format_a4b4g4r4, formatA4B4G4R4) \
|
FEATURE_NAME(format_a4b4g4r4, formatA4B4G4R4) \
|
||||||
FEATURE_NAME(index_type_uint8, indexTypeUint8) \
|
FEATURE_NAME(index_type_uint8, indexTypeUint8) \
|
||||||
|
@ -479,11 +474,6 @@ public:
|
||||||
return extensions.depth_clip_control;
|
return extensions.depth_clip_control;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns true if the device supports VK_EXT_depth_bias_control.
|
|
||||||
bool IsExtDepthBiasControlSupported() const {
|
|
||||||
return extensions.depth_bias_control;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns true if the device supports VK_EXT_shader_viewport_index_layer.
|
/// Returns true if the device supports VK_EXT_shader_viewport_index_layer.
|
||||||
bool IsExtShaderViewportIndexLayerSupported() const {
|
bool IsExtShaderViewportIndexLayerSupported() const {
|
||||||
return extensions.shader_viewport_index_layer;
|
return extensions.shader_viewport_index_layer;
|
||||||
|
@ -654,10 +644,6 @@ public:
|
||||||
return features.robustness2.nullDescriptor;
|
return features.robustness2.nullDescriptor;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool HasExactDepthBiasControl() const {
|
|
||||||
return features.depth_bias_control.depthBiasExact;
|
|
||||||
}
|
|
||||||
|
|
||||||
u32 GetMaxVertexInputAttributes() const {
|
u32 GetMaxVertexInputAttributes() const {
|
||||||
return properties.properties.limits.maxVertexInputAttributes;
|
return properties.properties.limits.maxVertexInputAttributes;
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,9 +59,7 @@ void ConfigureApplets::Setup(const ConfigurationShared::Builder& builder) {
|
||||||
|
|
||||||
// Untested applets
|
// Untested applets
|
||||||
if (setting->Id() == Settings::values.data_erase_applet_mode.Id() ||
|
if (setting->Id() == Settings::values.data_erase_applet_mode.Id() ||
|
||||||
setting->Id() == Settings::values.error_applet_mode.Id() ||
|
|
||||||
setting->Id() == Settings::values.net_connect_applet_mode.Id() ||
|
setting->Id() == Settings::values.net_connect_applet_mode.Id() ||
|
||||||
setting->Id() == Settings::values.web_applet_mode.Id() ||
|
|
||||||
setting->Id() == Settings::values.shop_applet_mode.Id() ||
|
setting->Id() == Settings::values.shop_applet_mode.Id() ||
|
||||||
setting->Id() == Settings::values.login_share_applet_mode.Id() ||
|
setting->Id() == Settings::values.login_share_applet_mode.Id() ||
|
||||||
setting->Id() == Settings::values.wifi_web_auth_applet_mode.Id() ||
|
setting->Id() == Settings::values.wifi_web_auth_applet_mode.Id() ||
|
||||||
|
|
Loading…
Reference in a new issue