mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-03 11:11:14 +00:00
Remove debug code (again)
This commit is contained in:
parent
1aa4c12e5e
commit
168447d80e
15 changed files with 0 additions and 565 deletions
|
@ -1,145 +0,0 @@
|
||||||
#include <stratosphere/sm.hpp>
|
|
||||||
|
|
||||||
#include "impl/ncm_content_manager.hpp"
|
|
||||||
#include "debug.hpp"
|
|
||||||
#include "ncm_fs.hpp"
|
|
||||||
|
|
||||||
namespace sts::debug {
|
|
||||||
|
|
||||||
#define IRAM_BASE 0x40000000ull
|
|
||||||
#define IRAM_SIZE 0x40000
|
|
||||||
|
|
||||||
#define IRAM_PAYLOAD_MAX_SIZE 0x2F000
|
|
||||||
#define IRAM_PAYLOAD_BASE 0x40010000ull
|
|
||||||
|
|
||||||
#define IRAM_SAFE_START 0x40038000ull
|
|
||||||
#define IRAM_SAFE_END 0x4003D000ull
|
|
||||||
#define IRAM_SAFE_SIZE IRAM_SAFE_END - IRAM_SAFE_START
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
HosMutex g_log_mutex;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t g_curr_log_offset = 0;
|
|
||||||
size_t g_log_skip = 1000;
|
|
||||||
u32 g_page_num = 0;
|
|
||||||
|
|
||||||
char __attribute__ ((aligned (0x1000))) g_work_page[0x1000];
|
|
||||||
|
|
||||||
void clear_iram(void) {
|
|
||||||
/* Fill with null*/
|
|
||||||
memset(g_work_page, 0, sizeof(g_work_page));
|
|
||||||
|
|
||||||
/* Overwrite all of our log's IRAM with 0s. */
|
|
||||||
for (size_t ofs = 0; ofs < IRAM_SAFE_SIZE; ofs += sizeof(g_work_page)) {
|
|
||||||
CopyToIram(IRAM_SAFE_START + ofs, g_work_page, sizeof(g_work_page));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void clear_log(void) {
|
|
||||||
std::scoped_lock lk(g_log_mutex);
|
|
||||||
|
|
||||||
clear_iram();
|
|
||||||
}
|
|
||||||
|
|
||||||
Result Initialize() {
|
|
||||||
clear_log();
|
|
||||||
return ResultSuccess;
|
|
||||||
}
|
|
||||||
|
|
||||||
void DebugLog(const char* format, ...) {
|
|
||||||
std::scoped_lock lk(g_log_mutex);
|
|
||||||
memset(g_work_page, 0, sizeof(g_work_page));
|
|
||||||
|
|
||||||
/* Format a string with our arguments. */
|
|
||||||
va_list args;
|
|
||||||
va_start(args, format);
|
|
||||||
vsnprintf(g_work_page, 0x1000, format, args);
|
|
||||||
va_end(args);
|
|
||||||
|
|
||||||
size_t msg_len = strnlen(g_work_page, 0x1000);
|
|
||||||
|
|
||||||
/* Nothing to log. */
|
|
||||||
if (msg_len == 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Attempt to put some of our new string in the previous 4 bytes. */
|
|
||||||
if (g_curr_log_offset >= 4) {
|
|
||||||
char __attribute__ ((aligned (0x4))) prev_4[4] = {0};
|
|
||||||
CopyFromIram(prev_4, IRAM_SAFE_START+g_curr_log_offset-4, 4);
|
|
||||||
size_t prev_4_size = strnlen(prev_4, 4);
|
|
||||||
|
|
||||||
/* Do we have room to put some of our new string in the old one? */
|
|
||||||
if (prev_4_size < 4) {
|
|
||||||
size_t spare_4_space = 4 - prev_4_size;
|
|
||||||
memcpy(prev_4 + prev_4_size, g_work_page, spare_4_space);
|
|
||||||
|
|
||||||
/* Copy the previous 4 bytes back. */
|
|
||||||
CopyToIram(IRAM_SAFE_START+g_curr_log_offset-4, prev_4, 4);
|
|
||||||
memmove(g_work_page, g_work_page + spare_4_space, 0x1000-spare_4_space);
|
|
||||||
/* Update our size again. */
|
|
||||||
msg_len = strnlen(g_work_page, 0x1000);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t msg_len_aligned = (msg_len + 3) & ~3;
|
|
||||||
|
|
||||||
if (g_curr_log_offset + msg_len_aligned > IRAM_SAFE_SIZE) {
|
|
||||||
if (g_log_skip == 0) {
|
|
||||||
/* Log is full. Reboot to RCM to read it. */
|
|
||||||
RebootToRcm();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
g_log_skip--;
|
|
||||||
g_curr_log_offset = 0;
|
|
||||||
g_page_num++;
|
|
||||||
clear_iram();
|
|
||||||
CopyToIram(IRAM_SAFE_END-sizeof(u32), &g_page_num, sizeof(u32));
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Fill remainder with 0s. */
|
|
||||||
if (msg_len_aligned > msg_len) {
|
|
||||||
memset(g_work_page + msg_len, '\0', msg_len_aligned - msg_len);
|
|
||||||
}
|
|
||||||
|
|
||||||
uintptr_t iram_out_start = IRAM_SAFE_START+g_curr_log_offset;
|
|
||||||
uintptr_t iram_next_page = (iram_out_start + 0x1000-1) & ~(0x1000-1);
|
|
||||||
|
|
||||||
/* We are copying across two pages */
|
|
||||||
if (iram_out_start + msg_len_aligned > iram_next_page) {
|
|
||||||
size_t first_page_size = iram_next_page - iram_out_start;
|
|
||||||
CopyToIram(iram_out_start, g_work_page, first_page_size);
|
|
||||||
CopyToIram(iram_next_page, g_work_page+first_page_size, msg_len_aligned-first_page_size);
|
|
||||||
} else {
|
|
||||||
CopyToIram(iram_out_start, g_work_page, msg_len_aligned);
|
|
||||||
}
|
|
||||||
|
|
||||||
g_curr_log_offset += msg_len_aligned;
|
|
||||||
}
|
|
||||||
|
|
||||||
void LogBytes(const void* buf, size_t len) {
|
|
||||||
if (buf == NULL || len == 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const u8* bytes = static_cast<const u8*>(buf);
|
|
||||||
int count = 0;
|
|
||||||
DebugLog("\n\n00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F\n");
|
|
||||||
DebugLog("-----------------------------------------------\n");
|
|
||||||
|
|
||||||
for (size_t i = 0; i < len; i++) {
|
|
||||||
DebugLog("%02x ", bytes[i]);
|
|
||||||
count++;
|
|
||||||
if ((count % 16) == 0) {
|
|
||||||
DebugLog("\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
DebugLog("\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,39 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2019 Adubbz
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms and conditions of the GNU General Public License,
|
|
||||||
* version 2, as published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
||||||
* more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
#include <switch.h>
|
|
||||||
#include <stratosphere.hpp>
|
|
||||||
#include <inttypes.h>
|
|
||||||
|
|
||||||
namespace sts::debug {
|
|
||||||
#define STR_(X) #X
|
|
||||||
#define STR(X) STR_(X)
|
|
||||||
|
|
||||||
#define D_LOG(format, ...) \
|
|
||||||
debug::DebugLog("%s:" STR(__LINE__) " " format, __FUNCTION__, ##__VA_ARGS__);
|
|
||||||
#define R_DEBUG_START \
|
|
||||||
Result rc = [&]() -> Result {
|
|
||||||
#define R_DEBUG_END \
|
|
||||||
}(); \
|
|
||||||
D_LOG(" -> 0x%08" PRIX32 "\n", rc); \
|
|
||||||
return rc;
|
|
||||||
|
|
||||||
Result Initialize();
|
|
||||||
void DebugLog(const char* format, ...);
|
|
||||||
void LogBytes(const void* buf, size_t len);
|
|
||||||
|
|
||||||
}
|
|
|
@ -19,7 +19,6 @@
|
||||||
#include <stratosphere/kvdb/kvdb_memory_key_value_store.hpp>
|
#include <stratosphere/kvdb/kvdb_memory_key_value_store.hpp>
|
||||||
#include <optional>
|
#include <optional>
|
||||||
|
|
||||||
#include "../debug.hpp"
|
|
||||||
#include "../ncm_contentmetadatabase.hpp"
|
#include "../ncm_contentmetadatabase.hpp"
|
||||||
#include "../ncm_contentstorage.hpp"
|
#include "../ncm_contentstorage.hpp"
|
||||||
#include "../ncm_fs.hpp"
|
#include "../ncm_fs.hpp"
|
||||||
|
@ -151,9 +150,6 @@ namespace sts::ncm::impl {
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
}
|
}
|
||||||
|
|
||||||
R_ASSERT(debug::Initialize());
|
|
||||||
debug::DebugLog("ContentManager::InitializeContentManager\n");
|
|
||||||
|
|
||||||
size_t cur_storage_index = g_num_content_storage_entries;
|
size_t cur_storage_index = g_num_content_storage_entries;
|
||||||
|
|
||||||
for (size_t i = 0; i < MaxContentStorageEntries; i++) {
|
for (size_t i = 0; i < MaxContentStorageEntries; i++) {
|
||||||
|
@ -257,8 +253,6 @@ namespace sts::ncm::impl {
|
||||||
}
|
}
|
||||||
|
|
||||||
void FinalizeContentManager() {
|
void FinalizeContentManager() {
|
||||||
debug::DebugLog("Finalizing content manager...\n");
|
|
||||||
|
|
||||||
{
|
{
|
||||||
std::scoped_lock<HosMutex> lk(g_mutex);
|
std::scoped_lock<HosMutex> lk(g_mutex);
|
||||||
|
|
||||||
|
|
|
@ -20,8 +20,6 @@
|
||||||
#include "../ncm_make_path.hpp"
|
#include "../ncm_make_path.hpp"
|
||||||
#include "../ncm_path_utils.hpp"
|
#include "../ncm_path_utils.hpp"
|
||||||
|
|
||||||
#include "../debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::ncm::impl {
|
namespace sts::ncm::impl {
|
||||||
|
|
||||||
Result PlaceHolderAccessor::Open(FILE** out_handle, PlaceHolderId placeholder_id) {
|
Result PlaceHolderAccessor::Open(FILE** out_handle, PlaceHolderId placeholder_id) {
|
||||||
|
@ -128,7 +126,6 @@ namespace sts::ncm::impl {
|
||||||
this->EnsureRecursively(placeholder_id);
|
this->EnsureRecursively(placeholder_id);
|
||||||
this->GetPath(placeholder_path, placeholder_id);
|
this->GetPath(placeholder_path, placeholder_id);
|
||||||
|
|
||||||
debug::DebugLog("Creating %s\n", placeholder_path);
|
|
||||||
R_TRY_CATCH(fsdevCreateFile(placeholder_path, size, FS_CREATE_BIG_FILE)) {
|
R_TRY_CATCH(fsdevCreateFile(placeholder_path, size, FS_CREATE_BIG_FILE)) {
|
||||||
R_CATCH(ResultFsPathAlreadyExists) {
|
R_CATCH(ResultFsPathAlreadyExists) {
|
||||||
return ResultNcmPlaceHolderAlreadyExists;
|
return ResultNcmPlaceHolderAlreadyExists;
|
||||||
|
@ -143,7 +140,6 @@ namespace sts::ncm::impl {
|
||||||
|
|
||||||
this->GetPath(placeholder_path, placeholder_id);
|
this->GetPath(placeholder_path, placeholder_id);
|
||||||
|
|
||||||
debug::DebugLog("Deleting %s\n", placeholder_path);
|
|
||||||
if (std::remove(placeholder_path) != 0) {
|
if (std::remove(placeholder_path) != 0) {
|
||||||
R_TRY_CATCH(fsdevGetLastResult()) {
|
R_TRY_CATCH(fsdevGetLastResult()) {
|
||||||
R_CATCH(ResultFsPathNotFound) {
|
R_CATCH(ResultFsPathNotFound) {
|
||||||
|
|
|
@ -17,8 +17,6 @@
|
||||||
#include "impl/ncm_content_manager.hpp"
|
#include "impl/ncm_content_manager.hpp"
|
||||||
#include "lr_addoncontentlocationresolver.hpp"
|
#include "lr_addoncontentlocationresolver.hpp"
|
||||||
|
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::lr {
|
namespace sts::lr {
|
||||||
|
|
||||||
AddOnContentLocationResolverInterface::AddOnContentLocationResolverInterface() {
|
AddOnContentLocationResolverInterface::AddOnContentLocationResolverInterface() {
|
||||||
|
@ -26,7 +24,6 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
Result AddOnContentLocationResolverInterface::ResolveAddOnContentPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result AddOnContentLocationResolverInterface::ResolveAddOnContentPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
ncm::StorageId storage_id = ncm::StorageId::None;
|
ncm::StorageId storage_id = ncm::StorageId::None;
|
||||||
|
|
||||||
|
@ -45,21 +42,16 @@ namespace sts::lr {
|
||||||
*out.pointer = path;
|
*out.pointer = path;
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result AddOnContentLocationResolverInterface::RegisterAddOnContentStorage(ncm::StorageId storage_id, ncm::TitleId tid) {
|
Result AddOnContentLocationResolverInterface::RegisterAddOnContentStorage(ncm::StorageId storage_id, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->redirector.SetRedirection(tid, storage_id));
|
R_TRY(this->redirector.SetRedirection(tid, storage_id));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result AddOnContentLocationResolverInterface::UnregisterAllAddOnContentPath() {
|
Result AddOnContentLocationResolverInterface::UnregisterAllAddOnContentPath() {
|
||||||
R_DEBUG_START
|
|
||||||
this->redirector.ClearRedirections();
|
this->redirector.ClearRedirections();
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -17,8 +17,6 @@
|
||||||
#include "impl/ncm_content_manager.hpp"
|
#include "impl/ncm_content_manager.hpp"
|
||||||
#include "lr_contentlocationresolver.hpp"
|
#include "lr_contentlocationresolver.hpp"
|
||||||
|
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::lr {
|
namespace sts::lr {
|
||||||
|
|
||||||
ContentLocationResolverInterface::~ContentLocationResolverInterface() {
|
ContentLocationResolverInterface::~ContentLocationResolverInterface() {
|
||||||
|
@ -30,7 +28,6 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::ResolveProgramPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::ResolveProgramPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (this->program_redirector.FindRedirection(&path, tid)) {
|
if (this->program_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -48,21 +45,15 @@ namespace sts::lr {
|
||||||
|
|
||||||
R_ASSERT(this->content_storage->GetPath(&path, program_content_id));
|
R_ASSERT(this->content_storage->GetPath(&path, program_content_id));
|
||||||
*out.pointer = path;
|
*out.pointer = path;
|
||||||
D_LOG("path: %s\n", path.path);
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::RedirectProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::RedirectProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->program_redirector.SetRedirection(tid, *path.pointer);
|
this->program_redirector.SetRedirection(tid, *path.pointer);
|
||||||
D_LOG("path: %s\n", (*path.pointer).path);
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::ResolveApplicationControlPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::ResolveApplicationControlPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (this->app_control_redirector.FindRedirection(&path, tid)) {
|
if (this->app_control_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -71,11 +62,9 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultLrControlNotFound;
|
return ResultLrControlNotFound;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::ResolveApplicationHtmlDocumentPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::ResolveApplicationHtmlDocumentPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (this->html_docs_redirector.FindRedirection(&path, tid)) {
|
if (this->html_docs_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -84,39 +73,29 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultLrHtmlDocumentNotFound;
|
return ResultLrHtmlDocumentNotFound;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::ResolveDataPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::ResolveDataPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
ncm::ContentId data_content_id;
|
ncm::ContentId data_content_id;
|
||||||
|
|
||||||
R_TRY(this->content_meta_database->GetLatestData(&data_content_id, tid));
|
R_TRY(this->content_meta_database->GetLatestData(&data_content_id, tid));
|
||||||
R_ASSERT(this->content_storage->GetPath(&path, data_content_id));
|
R_ASSERT(this->content_storage->GetPath(&path, data_content_id));
|
||||||
*out.pointer = path;
|
*out.pointer = path;
|
||||||
D_LOG("path: %s\n", path.path);
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::RedirectApplicationControlPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::RedirectApplicationControlPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->app_control_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
this->app_control_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::RedirectApplicationHtmlDocumentPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::RedirectApplicationHtmlDocumentPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->html_docs_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
this->html_docs_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
||||||
D_LOG("path: %s\n", (*path.pointer).path);
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::ResolveApplicationLegalInformationPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::ResolveApplicationLegalInformationPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (this->legal_info_redirector.FindRedirection(&path, tid)) {
|
if (this->legal_info_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -125,18 +104,14 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultLrLegalInformationNotFound;
|
return ResultLrLegalInformationNotFound;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::RedirectApplicationLegalInformationPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::RedirectApplicationLegalInformationPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->legal_info_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
this->legal_info_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::Refresh() {
|
Result ContentLocationResolverInterface::Refresh() {
|
||||||
R_DEBUG_START
|
|
||||||
std::shared_ptr<ncm::IContentMetaDatabase> content_meta_database;
|
std::shared_ptr<ncm::IContentMetaDatabase> content_meta_database;
|
||||||
std::shared_ptr<ncm::IContentStorage> content_storage;
|
std::shared_ptr<ncm::IContentStorage> content_storage;
|
||||||
R_TRY(ncm::impl::OpenContentMetaDatabase(&content_meta_database, this->storage_id));
|
R_TRY(ncm::impl::OpenContentMetaDatabase(&content_meta_database, this->storage_id));
|
||||||
|
@ -151,57 +126,43 @@ namespace sts::lr {
|
||||||
this->legal_info_redirector.ClearRedirections();
|
this->legal_info_redirector.ClearRedirections();
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::RedirectApplicationProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::RedirectApplicationProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->program_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
this->program_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::ClearApplicationRedirection() {
|
Result ContentLocationResolverInterface::ClearApplicationRedirection() {
|
||||||
R_DEBUG_START
|
|
||||||
this->program_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
this->program_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
||||||
this->debug_program_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
this->debug_program_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
||||||
this->app_control_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
this->app_control_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
||||||
this->html_docs_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
this->html_docs_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
||||||
this->legal_info_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
this->legal_info_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::EraseProgramRedirection(ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::EraseProgramRedirection(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->program_redirector.EraseRedirection(tid);
|
this->program_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::EraseApplicationControlRedirection(ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::EraseApplicationControlRedirection(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->app_control_redirector.EraseRedirection(tid);
|
this->app_control_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::EraseApplicationHtmlDocumentRedirection(ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::EraseApplicationHtmlDocumentRedirection(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->html_docs_redirector.EraseRedirection(tid);
|
this->html_docs_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::EraseApplicationLegalInformationRedirection(ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::EraseApplicationLegalInformationRedirection(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->legal_info_redirector.EraseRedirection(tid);
|
this->legal_info_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::ResolveProgramPathForDebug(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::ResolveProgramPathForDebug(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (this->debug_program_redirector.FindRedirection(&path, tid)) {
|
if (this->debug_program_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -217,28 +178,21 @@ namespace sts::lr {
|
||||||
|
|
||||||
*out.pointer = path;
|
*out.pointer = path;
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::RedirectProgramPathForDebug(InPointer<const Path> path, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::RedirectProgramPathForDebug(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->debug_program_redirector.SetRedirection(tid, *path.pointer);
|
this->debug_program_redirector.SetRedirection(tid, *path.pointer);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::RedirectApplicationProgramPathForDebug(InPointer<const Path> path, ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::RedirectApplicationProgramPathForDebug(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->debug_program_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
this->debug_program_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentLocationResolverInterface::EraseProgramRedirectionForDebug(ncm::TitleId tid) {
|
Result ContentLocationResolverInterface::EraseProgramRedirectionForDebug(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->debug_program_redirector.EraseRedirection(tid);
|
this->debug_program_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -17,33 +17,23 @@
|
||||||
|
|
||||||
#include "impl/lr_manager.hpp"
|
#include "impl/lr_manager.hpp"
|
||||||
#include "lr_manager_service.hpp"
|
#include "lr_manager_service.hpp"
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::lr {
|
namespace sts::lr {
|
||||||
|
|
||||||
Result LocationResolverManagerService::OpenLocationResolver(Out<std::shared_ptr<ILocationResolver>> out, ncm::StorageId storage_id) {
|
Result LocationResolverManagerService::OpenLocationResolver(Out<std::shared_ptr<ILocationResolver>> out, ncm::StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::OpenLocationResolver(out, storage_id);
|
return impl::OpenLocationResolver(out, storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result LocationResolverManagerService::OpenRegisteredLocationResolver(Out<std::shared_ptr<RegisteredLocationResolverInterface>> out) {
|
Result LocationResolverManagerService::OpenRegisteredLocationResolver(Out<std::shared_ptr<RegisteredLocationResolverInterface>> out) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::OpenRegisteredLocationResolver(out);
|
return impl::OpenRegisteredLocationResolver(out);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result LocationResolverManagerService::RefreshLocationResolver(ncm::StorageId storage_id) {
|
Result LocationResolverManagerService::RefreshLocationResolver(ncm::StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
D_LOG("storage_id: 0x%x\n", static_cast<u8>(storage_id));
|
|
||||||
return impl::RefreshLocationResolver(storage_id);
|
return impl::RefreshLocationResolver(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result LocationResolverManagerService::OpenAddOnContentLocationResolver(Out<std::shared_ptr<AddOnContentLocationResolverInterface>> out) {
|
Result LocationResolverManagerService::OpenAddOnContentLocationResolver(Out<std::shared_ptr<AddOnContentLocationResolverInterface>> out) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::OpenAddOnContentLocationResolver(out);
|
return impl::OpenAddOnContentLocationResolver(out);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -17,8 +17,6 @@
|
||||||
#include "impl/ncm_content_manager.hpp"
|
#include "impl/ncm_content_manager.hpp"
|
||||||
#include "lr_redirectonlylocationresolver.hpp"
|
#include "lr_redirectonlylocationresolver.hpp"
|
||||||
|
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::lr {
|
namespace sts::lr {
|
||||||
|
|
||||||
RedirectOnlyLocationResolverInterface::~RedirectOnlyLocationResolverInterface() {
|
RedirectOnlyLocationResolverInterface::~RedirectOnlyLocationResolverInterface() {
|
||||||
|
@ -30,7 +28,6 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::ResolveProgramPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::ResolveProgramPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (this->program_redirector.FindRedirection(&path, tid)) {
|
if (this->program_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -39,18 +36,14 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultLrProgramNotFound;
|
return ResultLrProgramNotFound;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::RedirectProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::RedirectProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->program_redirector.SetRedirection(tid, *path.pointer);
|
this->program_redirector.SetRedirection(tid, *path.pointer);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::ResolveApplicationControlPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::ResolveApplicationControlPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (this->app_control_redirector.FindRedirection(&path, tid)) {
|
if (this->app_control_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -59,11 +52,9 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultLrControlNotFound;
|
return ResultLrControlNotFound;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::ResolveApplicationHtmlDocumentPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::ResolveApplicationHtmlDocumentPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (this->html_docs_redirector.FindRedirection(&path, tid)) {
|
if (this->html_docs_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -72,31 +63,23 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultLrHtmlDocumentNotFound;
|
return ResultLrHtmlDocumentNotFound;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::ResolveDataPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::ResolveDataPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultLrDataNotFound;
|
return ResultLrDataNotFound;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::RedirectApplicationControlPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::RedirectApplicationControlPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->app_control_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
this->app_control_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::RedirectApplicationHtmlDocumentPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::RedirectApplicationHtmlDocumentPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->html_docs_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
this->html_docs_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::ResolveApplicationLegalInformationPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::ResolveApplicationLegalInformationPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (this->legal_info_redirector.FindRedirection(&path, tid)) {
|
if (this->legal_info_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -105,75 +88,57 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultLrLegalInformationNotFound;
|
return ResultLrLegalInformationNotFound;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::RedirectApplicationLegalInformationPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::RedirectApplicationLegalInformationPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->legal_info_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
this->legal_info_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::Refresh() {
|
Result RedirectOnlyLocationResolverInterface::Refresh() {
|
||||||
R_DEBUG_START
|
|
||||||
this->program_redirector.ClearRedirections();
|
this->program_redirector.ClearRedirections();
|
||||||
this->debug_program_redirector.ClearRedirections();
|
this->debug_program_redirector.ClearRedirections();
|
||||||
this->app_control_redirector.ClearRedirections();
|
this->app_control_redirector.ClearRedirections();
|
||||||
this->html_docs_redirector.ClearRedirections();
|
this->html_docs_redirector.ClearRedirections();
|
||||||
this->legal_info_redirector.ClearRedirections();
|
this->legal_info_redirector.ClearRedirections();
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::RedirectApplicationProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::RedirectApplicationProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->program_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
this->program_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::ClearApplicationRedirection() {
|
Result RedirectOnlyLocationResolverInterface::ClearApplicationRedirection() {
|
||||||
R_DEBUG_START
|
|
||||||
this->program_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
this->program_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
||||||
this->debug_program_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
this->debug_program_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
||||||
this->app_control_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
this->app_control_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
||||||
this->html_docs_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
this->html_docs_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
||||||
this->legal_info_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
this->legal_info_redirector.ClearRedirections(impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::EraseProgramRedirection(ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::EraseProgramRedirection(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->program_redirector.EraseRedirection(tid);
|
this->program_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::EraseApplicationControlRedirection(ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::EraseApplicationControlRedirection(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->app_control_redirector.EraseRedirection(tid);
|
this->app_control_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::EraseApplicationHtmlDocumentRedirection(ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::EraseApplicationHtmlDocumentRedirection(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->html_docs_redirector.EraseRedirection(tid);
|
this->html_docs_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::EraseApplicationLegalInformationRedirection(ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::EraseApplicationLegalInformationRedirection(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->legal_info_redirector.EraseRedirection(tid);
|
this->legal_info_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::ResolveProgramPathForDebug(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::ResolveProgramPathForDebug(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (this->debug_program_redirector.FindRedirection(&path, tid)) {
|
if (this->debug_program_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -189,28 +154,21 @@ namespace sts::lr {
|
||||||
|
|
||||||
*out.pointer = path;
|
*out.pointer = path;
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::RedirectProgramPathForDebug(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::RedirectProgramPathForDebug(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->debug_program_redirector.SetRedirection(tid, *path.pointer);
|
this->debug_program_redirector.SetRedirection(tid, *path.pointer);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::RedirectApplicationProgramPathForDebug(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::RedirectApplicationProgramPathForDebug(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->debug_program_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
this->debug_program_redirector.SetRedirection(tid, *path.pointer, impl::RedirectionFlags_Application);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RedirectOnlyLocationResolverInterface::EraseProgramRedirectionForDebug(ncm::TitleId tid) {
|
Result RedirectOnlyLocationResolverInterface::EraseProgramRedirectionForDebug(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->debug_program_redirector.EraseRedirection(tid);
|
this->debug_program_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -16,8 +16,6 @@
|
||||||
|
|
||||||
#include "lr_registeredlocationresolver.hpp"
|
#include "lr_registeredlocationresolver.hpp"
|
||||||
|
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::lr {
|
namespace sts::lr {
|
||||||
|
|
||||||
RegisteredLocationResolverInterface::RegisteredLocationResolverInterface() {
|
RegisteredLocationResolverInterface::RegisteredLocationResolverInterface() {
|
||||||
|
@ -32,7 +30,6 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RegisteredLocationResolverInterface::ResolveProgramPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result RegisteredLocationResolverInterface::ResolveProgramPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (!this->program_redirector.FindRedirection(&path, tid)) {
|
if (!this->program_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -43,11 +40,9 @@ namespace sts::lr {
|
||||||
|
|
||||||
*out.pointer = path;
|
*out.pointer = path;
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RegisteredLocationResolverInterface::RegisterProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RegisteredLocationResolverInterface::RegisterProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path tmp_path = *path.pointer;
|
Path tmp_path = *path.pointer;
|
||||||
|
|
||||||
if (!this->registered_program_redirector.SetRedirection(tid, tmp_path)) {
|
if (!this->registered_program_redirector.SetRedirection(tid, tmp_path)) {
|
||||||
|
@ -56,26 +51,20 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RegisteredLocationResolverInterface::UnregisterProgramPath(ncm::TitleId tid) {
|
Result RegisteredLocationResolverInterface::UnregisterProgramPath(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->registered_program_redirector.EraseRedirection(tid);
|
this->registered_program_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RegisteredLocationResolverInterface::RedirectProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RegisteredLocationResolverInterface::RedirectProgramPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path tmp_path = *path.pointer;
|
Path tmp_path = *path.pointer;
|
||||||
this->program_redirector.SetRedirection(tid, tmp_path);
|
this->program_redirector.SetRedirection(tid, tmp_path);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RegisteredLocationResolverInterface::ResolveHtmlDocumentPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
Result RegisteredLocationResolverInterface::ResolveHtmlDocumentPath(OutPointerWithServerSize<Path, 0x1> out, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path path;
|
Path path;
|
||||||
|
|
||||||
if (!this->html_docs_redirector.FindRedirection(&path, tid)) {
|
if (!this->html_docs_redirector.FindRedirection(&path, tid)) {
|
||||||
|
@ -86,11 +75,9 @@ namespace sts::lr {
|
||||||
|
|
||||||
*out.pointer = path;
|
*out.pointer = path;
|
||||||
return ResultLrHtmlDocumentNotFound;
|
return ResultLrHtmlDocumentNotFound;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RegisteredLocationResolverInterface::RegisterHtmlDocumentPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RegisteredLocationResolverInterface::RegisterHtmlDocumentPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path tmp_path = *path.pointer;
|
Path tmp_path = *path.pointer;
|
||||||
|
|
||||||
if (!this->registered_html_docs_redirector.SetRedirection(tid, tmp_path)) {
|
if (!this->registered_html_docs_redirector.SetRedirection(tid, tmp_path)) {
|
||||||
|
@ -99,30 +86,23 @@ namespace sts::lr {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RegisteredLocationResolverInterface::UnregisterHtmlDocumentPath(ncm::TitleId tid) {
|
Result RegisteredLocationResolverInterface::UnregisterHtmlDocumentPath(ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
this->registered_html_docs_redirector.EraseRedirection(tid);
|
this->registered_html_docs_redirector.EraseRedirection(tid);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RegisteredLocationResolverInterface::RedirectHtmlDocumentPath(InPointer<const Path> path, ncm::TitleId tid) {
|
Result RegisteredLocationResolverInterface::RedirectHtmlDocumentPath(InPointer<const Path> path, ncm::TitleId tid) {
|
||||||
R_DEBUG_START
|
|
||||||
Path tmp_path = *path.pointer;
|
Path tmp_path = *path.pointer;
|
||||||
this->html_docs_redirector.SetRedirection(tid, tmp_path);
|
this->html_docs_redirector.SetRedirection(tid, tmp_path);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result RegisteredLocationResolverInterface::Refresh() {
|
Result RegisteredLocationResolverInterface::Refresh() {
|
||||||
R_DEBUG_START
|
|
||||||
this->registered_program_redirector.ClearRedirections();
|
this->registered_program_redirector.ClearRedirections();
|
||||||
this->registered_html_docs_redirector.ClearRedirections();
|
this->registered_html_docs_redirector.ClearRedirections();
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -17,94 +17,64 @@
|
||||||
#include "impl/ncm_content_manager.hpp"
|
#include "impl/ncm_content_manager.hpp"
|
||||||
#include "ncm_content_manager_service.hpp"
|
#include "ncm_content_manager_service.hpp"
|
||||||
|
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::ncm {
|
namespace sts::ncm {
|
||||||
|
|
||||||
Result ContentManagerService::CreateContentStorage(StorageId storage_id) {
|
Result ContentManagerService::CreateContentStorage(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::CreateContentStorage(storage_id);
|
return impl::CreateContentStorage(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::CreateContentMetaDatabase(StorageId storage_id) {
|
Result ContentManagerService::CreateContentMetaDatabase(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::CreateContentMetaDatabase(storage_id);
|
return impl::CreateContentMetaDatabase(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::VerifyContentStorage(StorageId storage_id) {
|
Result ContentManagerService::VerifyContentStorage(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::VerifyContentStorage(storage_id);
|
return impl::VerifyContentStorage(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::VerifyContentMetaDatabase(StorageId storage_id) {
|
Result ContentManagerService::VerifyContentMetaDatabase(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::VerifyContentMetaDatabase(storage_id);
|
return impl::VerifyContentMetaDatabase(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::OpenContentStorage(Out<std::shared_ptr<IContentStorage>> out, StorageId storage_id) {
|
Result ContentManagerService::OpenContentStorage(Out<std::shared_ptr<IContentStorage>> out, StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
D_LOG("storage id: 0x%x\n", storage_id);
|
|
||||||
std::shared_ptr<IContentStorage> content_storage;
|
std::shared_ptr<IContentStorage> content_storage;
|
||||||
R_TRY(impl::OpenContentStorage(&content_storage, storage_id));
|
R_TRY(impl::OpenContentStorage(&content_storage, storage_id));
|
||||||
out.SetValue(std::move(content_storage));
|
out.SetValue(std::move(content_storage));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::OpenContentMetaDatabase(Out<std::shared_ptr<IContentMetaDatabase>> out, StorageId storage_id) {
|
Result ContentManagerService::OpenContentMetaDatabase(Out<std::shared_ptr<IContentMetaDatabase>> out, StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
D_LOG("storage id: 0x%x\n", storage_id);
|
|
||||||
std::shared_ptr<IContentMetaDatabase> content_meta_database;
|
std::shared_ptr<IContentMetaDatabase> content_meta_database;
|
||||||
R_TRY(impl::OpenContentMetaDatabase(&content_meta_database, storage_id));
|
R_TRY(impl::OpenContentMetaDatabase(&content_meta_database, storage_id));
|
||||||
out.SetValue(std::move(content_meta_database));
|
out.SetValue(std::move(content_meta_database));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::CloseContentStorageForcibly(StorageId storage_id) {
|
Result ContentManagerService::CloseContentStorageForcibly(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::CloseContentStorageForcibly(storage_id);
|
return impl::CloseContentStorageForcibly(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::CloseContentMetaDatabaseForcibly(StorageId storage_id) {
|
Result ContentManagerService::CloseContentMetaDatabaseForcibly(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::CloseContentMetaDatabaseForcibly(storage_id);
|
return impl::CloseContentMetaDatabaseForcibly(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::CleanupContentMetaDatabase(StorageId storage_id) {
|
Result ContentManagerService::CleanupContentMetaDatabase(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::CleanupContentMetaDatabase(storage_id);
|
return impl::CleanupContentMetaDatabase(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::ActivateContentStorage(StorageId storage_id) {
|
Result ContentManagerService::ActivateContentStorage(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::ActivateContentStorage(storage_id);
|
return impl::ActivateContentStorage(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::InactivateContentStorage(StorageId storage_id) {
|
Result ContentManagerService::InactivateContentStorage(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::InactivateContentStorage(storage_id);
|
return impl::InactivateContentStorage(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::ActivateContentMetaDatabase(StorageId storage_id) {
|
Result ContentManagerService::ActivateContentMetaDatabase(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::ActivateContentMetaDatabase(storage_id);
|
return impl::ActivateContentMetaDatabase(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentManagerService::InactivateContentMetaDatabase(StorageId storage_id) {
|
Result ContentManagerService::InactivateContentMetaDatabase(StorageId storage_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return impl::InactivateContentMetaDatabase(storage_id);
|
return impl::InactivateContentMetaDatabase(storage_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -17,8 +17,6 @@
|
||||||
#include "ncm_contentmetadatabase.hpp"
|
#include "ncm_contentmetadatabase.hpp"
|
||||||
#include "ncm_utils.hpp"
|
#include "ncm_utils.hpp"
|
||||||
|
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::ncm {
|
namespace sts::ncm {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
@ -95,11 +93,6 @@ namespace sts::ncm {
|
||||||
Result ContentMetaDatabaseInterface::GetContentIdByTypeImpl(ContentId* out, const ContentMetaKey& key, ContentType type, std::optional<u8> id_offset) {
|
Result ContentMetaDatabaseInterface::GetContentIdByTypeImpl(ContentId* out, const ContentMetaKey& key, ContentType type, std::optional<u8> id_offset) {
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
D_LOG("key id: 0x%lx\n", key.id);
|
|
||||||
D_LOG("key version: 0x%x\n", key.version)
|
|
||||||
D_LOG("type: 0x%x\n", type);
|
|
||||||
D_LOG("id_offset: 0x%x\n", id_offset);
|
|
||||||
|
|
||||||
const auto it = this->kvs->lower_bound(key);
|
const auto it = this->kvs->lower_bound(key);
|
||||||
if (it == this->kvs->end() || it->GetKey().id != key.id) {
|
if (it == this->kvs->end() || it->GetKey().id != key.id) {
|
||||||
return ResultNcmContentMetaNotFound;
|
return ResultNcmContentMetaNotFound;
|
||||||
|
@ -146,9 +139,6 @@ namespace sts::ncm {
|
||||||
return ResultNcmContentNotFound;
|
return ResultNcmContentNotFound;
|
||||||
}
|
}
|
||||||
|
|
||||||
char content_name[sizeof(ContentId)*2+1] = {0};
|
|
||||||
GetStringFromContentId(content_name, found_content_info->content_id);
|
|
||||||
D_LOG("content id: %s.nca\n", content_name);
|
|
||||||
*out = found_content_info->content_id;
|
*out = found_content_info->content_id;
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
}
|
}
|
||||||
|
@ -180,50 +170,36 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::Set(ContentMetaKey key, InBuffer<u8> value) {
|
Result ContentMetaDatabaseInterface::Set(ContentMetaKey key, InBuffer<u8> value) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
D_LOG(" set title_id: 0x%lx\n", key.id);
|
|
||||||
D_LOG(" set version: 0x%x\n", key.version);
|
|
||||||
|
|
||||||
R_TRY(this->kvs->Set(key, value.buffer, value.num_elements));
|
R_TRY(this->kvs->Set(key, value.buffer, value.num_elements));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::Get(Out<u64> out_size, ContentMetaKey key, OutBuffer<u8> out_value) {
|
Result ContentMetaDatabaseInterface::Get(Out<u64> out_size, ContentMetaKey key, OutBuffer<u8> out_value) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
R_TRY(this->kvs->Get(out_size.GetPointer(), out_value.buffer, out_value.num_elements, key));
|
R_TRY(this->kvs->Get(out_size.GetPointer(), out_value.buffer, out_value.num_elements, key));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::Remove(ContentMetaKey key) {
|
Result ContentMetaDatabaseInterface::Remove(ContentMetaKey key) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
R_TRY(this->kvs->Remove(key));
|
R_TRY(this->kvs->Remove(key));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::GetContentIdByType(Out<ContentId> out_content_id, ContentMetaKey key, ContentType type) {
|
Result ContentMetaDatabaseInterface::GetContentIdByType(Out<ContentId> out_content_id, ContentMetaKey key, ContentType type) {
|
||||||
R_DEBUG_START
|
|
||||||
ContentId content_id;
|
ContentId content_id;
|
||||||
R_TRY(this->GetContentIdByTypeImpl(&content_id, key, type, std::nullopt));
|
R_TRY(this->GetContentIdByTypeImpl(&content_id, key, type, std::nullopt));
|
||||||
out_content_id.SetValue(content_id);
|
out_content_id.SetValue(content_id);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::ListContentInfo(Out<u32> out_count, OutBuffer<ContentInfo> out_info, ContentMetaKey key, u32 offset) {
|
Result ContentMetaDatabaseInterface::ListContentInfo(Out<u32> out_count, OutBuffer<ContentInfo> out_info, ContentMetaKey key, u32 offset) {
|
||||||
R_DEBUG_START
|
|
||||||
if (offset >> 0x1f != 0) {
|
if (offset >> 0x1f != 0) {
|
||||||
return ResultNcmInvalidOffset;
|
return ResultNcmInvalidOffset;
|
||||||
}
|
}
|
||||||
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
const void *value = nullptr;
|
const void *value = nullptr;
|
||||||
size_t value_size = 0;
|
size_t value_size = 0;
|
||||||
R_TRY(GetContentMetaValuePointer(&value, &value_size, key, this->kvs));
|
R_TRY(GetContentMetaValuePointer(&value, &value_size, key, this->kvs));
|
||||||
|
@ -237,22 +213,14 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out_count.SetValue(count);
|
out_count.SetValue(count);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::List(Out<u32> out_entries_total, Out<u32> out_entries_written, OutBuffer<ContentMetaKey> out_info, ContentMetaType type, TitleId application_title_id, TitleId title_id_min, TitleId title_id_max, ContentInstallType install_type) {
|
Result ContentMetaDatabaseInterface::List(Out<u32> out_entries_total, Out<u32> out_entries_written, OutBuffer<ContentMetaKey> out_info, ContentMetaType type, TitleId application_title_id, TitleId title_id_min, TitleId title_id_max, ContentInstallType install_type) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
size_t entries_total = 0;
|
size_t entries_total = 0;
|
||||||
size_t entries_written = 0;
|
size_t entries_written = 0;
|
||||||
|
|
||||||
D_LOG("app tid: 0x%x\n", application_title_id);
|
|
||||||
D_LOG("meta type: 0x%x\n", type);
|
|
||||||
D_LOG("install type: 0x%x\n", install_type);
|
|
||||||
D_LOG("tid min: 0x%lx\n", title_id_min);
|
|
||||||
D_LOG("tid max: 0x%lx\n", title_id_max);
|
|
||||||
|
|
||||||
/* If there are no entries then we've already successfully listed them all. */
|
/* If there are no entries then we've already successfully listed them all. */
|
||||||
if (this->kvs->GetCount() == 0) {
|
if (this->kvs->GetCount() == 0) {
|
||||||
out_entries_total.SetValue(entries_total);
|
out_entries_total.SetValue(entries_total);
|
||||||
|
@ -304,21 +272,17 @@ namespace sts::ncm {
|
||||||
out_entries_total.SetValue(entries_total);
|
out_entries_total.SetValue(entries_total);
|
||||||
out_entries_written.SetValue(entries_written);
|
out_entries_written.SetValue(entries_written);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::GetLatestContentMetaKey(Out<ContentMetaKey> out_key, TitleId title_id) {
|
Result ContentMetaDatabaseInterface::GetLatestContentMetaKey(Out<ContentMetaKey> out_key, TitleId title_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
ContentMetaKey key;
|
ContentMetaKey key;
|
||||||
R_TRY(this->GetLatestContentMetaKeyImpl(&key, title_id));
|
R_TRY(this->GetLatestContentMetaKeyImpl(&key, title_id));
|
||||||
out_key.SetValue(key);
|
out_key.SetValue(key);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::ListApplication(Out<u32> out_entries_total, Out<u32> out_entries_written, OutBuffer<ApplicationContentMetaKey> out_keys, ContentMetaType type) {
|
Result ContentMetaDatabaseInterface::ListApplication(Out<u32> out_entries_total, Out<u32> out_entries_written, OutBuffer<ApplicationContentMetaKey> out_keys, ContentMetaType type) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
size_t entries_total = 0;
|
size_t entries_total = 0;
|
||||||
|
@ -369,11 +333,9 @@ namespace sts::ncm {
|
||||||
out_entries_total.SetValue(entries_total);
|
out_entries_total.SetValue(entries_total);
|
||||||
out_entries_written.SetValue(entries_written);
|
out_entries_written.SetValue(entries_written);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::Has(Out<bool> out, ContentMetaKey key) {
|
Result ContentMetaDatabaseInterface::Has(Out<bool> out, ContentMetaKey key) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
if (this->kvs->GetCount() == 0) {
|
if (this->kvs->GetCount() == 0) {
|
||||||
|
@ -387,16 +349,11 @@ namespace sts::ncm {
|
||||||
has = it->GetKey() == key;
|
has = it->GetKey() == key;
|
||||||
}
|
}
|
||||||
|
|
||||||
D_LOG("key id: 0x%lx\n", key.id);
|
|
||||||
D_LOG("key version: 0x%x\n", key.version);
|
|
||||||
D_LOG("has: %d\n", has);
|
|
||||||
out.SetValue(has);
|
out.SetValue(has);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::HasAll(Out<bool> out, InBuffer<ContentMetaKey> keys) {
|
Result ContentMetaDatabaseInterface::HasAll(Out<bool> out, InBuffer<ContentMetaKey> keys) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
bool has = true;
|
bool has = true;
|
||||||
|
@ -406,11 +363,9 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out.SetValue(has);
|
out.SetValue(has);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::GetSize(Out<u64> out_size, ContentMetaKey key) {
|
Result ContentMetaDatabaseInterface::GetSize(Out<u64> out_size, ContentMetaKey key) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
if (this->kvs->GetCount() == 0) {
|
if (this->kvs->GetCount() == 0) {
|
||||||
|
@ -424,11 +379,9 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out_size.SetValue(it->GetValueSize());
|
out_size.SetValue(it->GetValueSize());
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::GetRequiredSystemVersion(Out<u32> out_version, ContentMetaKey key) {
|
Result ContentMetaDatabaseInterface::GetRequiredSystemVersion(Out<u32> out_version, ContentMetaKey key) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
if (key.type != ContentMetaType::Application && key.type != ContentMetaType::Patch) {
|
if (key.type != ContentMetaType::Application && key.type != ContentMetaType::Patch) {
|
||||||
|
@ -444,40 +397,30 @@ namespace sts::ncm {
|
||||||
const auto ext_header = GetValueExtendedHeader<ApplicationMetaExtendedHeader>(value);
|
const auto ext_header = GetValueExtendedHeader<ApplicationMetaExtendedHeader>(value);
|
||||||
out_version.SetValue(ext_header->required_system_version);
|
out_version.SetValue(ext_header->required_system_version);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::GetPatchId(Out<TitleId> out_patch_id, ContentMetaKey key) {
|
Result ContentMetaDatabaseInterface::GetPatchId(Out<TitleId> out_patch_id, ContentMetaKey key) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
if (key.type != ContentMetaType::Application) {
|
if (key.type != ContentMetaType::Application) {
|
||||||
return ResultNcmInvalidContentMetaKey;
|
return ResultNcmInvalidContentMetaKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
D_LOG(" key title_id: 0x%lx\n", key.id);
|
|
||||||
D_LOG(" key version: 0x%x\n", key.version);
|
|
||||||
|
|
||||||
const void* value = nullptr;
|
const void* value = nullptr;
|
||||||
size_t value_size = 0;
|
size_t value_size = 0;
|
||||||
R_TRY(GetContentMetaValuePointer(&value, &value_size, key, this->kvs));
|
R_TRY(GetContentMetaValuePointer(&value, &value_size, key, this->kvs));
|
||||||
const auto ext_header = GetValueExtendedHeader<ApplicationMetaExtendedHeader>(value);
|
const auto ext_header = GetValueExtendedHeader<ApplicationMetaExtendedHeader>(value);
|
||||||
|
|
||||||
out_patch_id.SetValue(ext_header->patch_id);
|
out_patch_id.SetValue(ext_header->patch_id);
|
||||||
D_LOG(" patch title_id: 0x%lx\n", *out_patch_id);
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::DisableForcibly() {
|
Result ContentMetaDatabaseInterface::DisableForcibly() {
|
||||||
R_DEBUG_START
|
|
||||||
this->disabled = true;
|
this->disabled = true;
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::LookupOrphanContent(OutBuffer<bool> out_orphaned, InBuffer<ContentId> content_ids) {
|
Result ContentMetaDatabaseInterface::LookupOrphanContent(OutBuffer<bool> out_orphaned, InBuffer<ContentId> content_ids) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
if (out_orphaned.num_elements < content_ids.num_elements) {
|
if (out_orphaned.num_elements < content_ids.num_elements) {
|
||||||
|
@ -522,28 +465,17 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (size_t i = 0; i < content_ids.num_elements; i++) {
|
|
||||||
char content_name[sizeof(ContentId)*2+1] = {0};
|
|
||||||
GetStringFromContentId(content_name, content_ids[i]);
|
|
||||||
D_LOG("content id: %s.nca\n", content_name);
|
|
||||||
D_LOG("orphaned: %d\n", out_orphaned[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::Commit() {
|
Result ContentMetaDatabaseInterface::Commit() {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
R_TRY(this->kvs->Save());
|
R_TRY(this->kvs->Save());
|
||||||
R_TRY(fsdevCommitDevice(this->mount_name));
|
R_TRY(fsdevCommitDevice(this->mount_name));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::HasContent(Out<bool> out, ContentMetaKey key, ContentId content_id) {
|
Result ContentMetaDatabaseInterface::HasContent(Out<bool> out, ContentMetaKey key, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
const void* value = nullptr;
|
const void* value = nullptr;
|
||||||
size_t value_size = 0;
|
size_t value_size = 0;
|
||||||
R_TRY(GetContentMetaValuePointer(&value, &value_size, key, this->kvs));
|
R_TRY(GetContentMetaValuePointer(&value, &value_size, key, this->kvs));
|
||||||
|
@ -563,11 +495,9 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out.SetValue(false);
|
out.SetValue(false);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::ListContentMetaInfo(Out<u32> out_entries_written, OutBuffer<ContentMetaInfo> out_meta_info, ContentMetaKey key, u32 start_index) {
|
Result ContentMetaDatabaseInterface::ListContentMetaInfo(Out<u32> out_entries_written, OutBuffer<ContentMetaInfo> out_meta_info, ContentMetaKey key, u32 start_index) {
|
||||||
R_DEBUG_START
|
|
||||||
if (start_index >> 0x1f != 0) {
|
if (start_index >> 0x1f != 0) {
|
||||||
return ResultNcmInvalidOffset;
|
return ResultNcmInvalidOffset;
|
||||||
}
|
}
|
||||||
|
@ -598,11 +528,9 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out_entries_written.SetValue(entries_written);
|
out_entries_written.SetValue(entries_written);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::GetAttributes(Out<ContentMetaAttribute> out_attributes, ContentMetaKey key) {
|
Result ContentMetaDatabaseInterface::GetAttributes(Out<ContentMetaAttribute> out_attributes, ContentMetaKey key) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
const void* value = nullptr;
|
const void* value = nullptr;
|
||||||
|
@ -611,11 +539,9 @@ namespace sts::ncm {
|
||||||
const auto header = GetValueHeader(value);
|
const auto header = GetValueHeader(value);
|
||||||
out_attributes.SetValue(header->attributes);
|
out_attributes.SetValue(header->attributes);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::GetRequiredApplicationVersion(Out<u32> out_version, ContentMetaKey key) {
|
Result ContentMetaDatabaseInterface::GetRequiredApplicationVersion(Out<u32> out_version, ContentMetaKey key) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
if (key.type != ContentMetaType::AddOnContent) {
|
if (key.type != ContentMetaType::AddOnContent) {
|
||||||
|
@ -628,16 +554,13 @@ namespace sts::ncm {
|
||||||
const auto ext_header = GetValueExtendedHeader<AddOnContentMetaExtendedHeader>(value);
|
const auto ext_header = GetValueExtendedHeader<AddOnContentMetaExtendedHeader>(value);
|
||||||
out_version.SetValue(ext_header->required_application_version);
|
out_version.SetValue(ext_header->required_application_version);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::GetContentIdByTypeAndIdOffset(Out<ContentId> out_content_id, ContentMetaKey key, ContentType type, u8 id_offset) {
|
Result ContentMetaDatabaseInterface::GetContentIdByTypeAndIdOffset(Out<ContentId> out_content_id, ContentMetaKey key, ContentType type, u8 id_offset) {
|
||||||
R_DEBUG_START
|
|
||||||
ContentId content_id;
|
ContentId content_id;
|
||||||
R_TRY(this->GetContentIdByTypeImpl(&content_id, key, type, std::optional(id_offset)));
|
R_TRY(this->GetContentIdByTypeImpl(&content_id, key, type, std::optional(id_offset)));
|
||||||
out_content_id.SetValue(content_id);
|
out_content_id.SetValue(content_id);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentMetaDatabaseInterface::GetLatestProgram(ContentId* out_content_id, TitleId title_id) {
|
Result ContentMetaDatabaseInterface::GetLatestProgram(ContentId* out_content_id, TitleId title_id) {
|
||||||
|
@ -657,7 +580,6 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
Result OnMemoryContentMetaDatabaseInterface::GetLatestContentMetaKey(Out<ContentMetaKey> out_key, TitleId title_id) {
|
Result OnMemoryContentMetaDatabaseInterface::GetLatestContentMetaKey(Out<ContentMetaKey> out_key, TitleId title_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
const ContentMetaKey key = ContentMetaKey::Make(title_id, 0, ContentMetaType::Unknown);
|
const ContentMetaKey key = ContentMetaKey::Make(title_id, 0, ContentMetaType::Unknown);
|
||||||
|
@ -677,20 +599,15 @@ namespace sts::ncm {
|
||||||
|
|
||||||
*out_key = *found_key;
|
*out_key = *found_key;
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result OnMemoryContentMetaDatabaseInterface::LookupOrphanContent(OutBuffer<bool> out_orphaned, InBuffer<ContentId> content_ids) {
|
Result OnMemoryContentMetaDatabaseInterface::LookupOrphanContent(OutBuffer<bool> out_orphaned, InBuffer<ContentId> content_ids) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentMetaDatabase;
|
return ResultNcmInvalidContentMetaDatabase;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result OnMemoryContentMetaDatabaseInterface::Commit() {
|
Result OnMemoryContentMetaDatabaseInterface::Commit() {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -20,8 +20,6 @@
|
||||||
#include "ncm_make_path.hpp"
|
#include "ncm_make_path.hpp"
|
||||||
#include "ncm_utils.hpp"
|
#include "ncm_utils.hpp"
|
||||||
|
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::ncm {
|
namespace sts::ncm {
|
||||||
|
|
||||||
ContentStorageInterface::~ContentStorageInterface() {
|
ContentStorageInterface::~ContentStorageInterface() {
|
||||||
|
@ -89,16 +87,13 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GeneratePlaceHolderId(Out<PlaceHolderId> out) {
|
Result ContentStorageInterface::GeneratePlaceHolderId(Out<PlaceHolderId> out) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
sts::rnd::GenerateRandomBytes(out.GetPointer(), sizeof(NcmNcaId));
|
sts::rnd::GenerateRandomBytes(out.GetPointer(), sizeof(NcmNcaId));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::CreatePlaceHolder(PlaceHolderId placeholder_id, ContentId content_id, u64 size) {
|
Result ContentStorageInterface::CreatePlaceHolder(PlaceHolderId placeholder_id, ContentId content_id, u64 size) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char content_path[FS_MAX_PATH] = {0};
|
char content_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -108,19 +103,14 @@ namespace sts::ncm {
|
||||||
R_TRY(this->placeholder_accessor.Create(placeholder_id, size));
|
R_TRY(this->placeholder_accessor.Create(placeholder_id, size));
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::DeletePlaceHolder(PlaceHolderId placeholder_id) {
|
Result ContentStorageInterface::DeletePlaceHolder(PlaceHolderId placeholder_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
return this->placeholder_accessor.Delete(placeholder_id);
|
return this->placeholder_accessor.Delete(placeholder_id);
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::HasPlaceHolder(Out<bool> out, PlaceHolderId placeholder_id) {
|
Result ContentStorageInterface::HasPlaceHolder(Out<bool> out, PlaceHolderId placeholder_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char placeholder_path[FS_MAX_PATH] = {0};
|
char placeholder_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -131,11 +121,9 @@ namespace sts::ncm {
|
||||||
out.SetValue(has);
|
out.SetValue(has);
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::WritePlaceHolder(PlaceHolderId placeholder_id, u64 offset, InBuffer<u8> data) {
|
Result ContentStorageInterface::WritePlaceHolder(PlaceHolderId placeholder_id, u64 offset, InBuffer<u8> data) {
|
||||||
R_DEBUG_START
|
|
||||||
/* Offset is too large */
|
/* Offset is too large */
|
||||||
if (offset >> 0x3f != 0) {
|
if (offset >> 0x3f != 0) {
|
||||||
return ResultNcmInvalidOffset;
|
return ResultNcmInvalidOffset;
|
||||||
|
@ -144,11 +132,9 @@ namespace sts::ncm {
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
R_TRY(this->placeholder_accessor.Write(placeholder_id, offset, data.buffer, data.num_elements));
|
R_TRY(this->placeholder_accessor.Write(placeholder_id, offset, data.buffer, data.num_elements));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::Register(PlaceHolderId placeholder_id, ContentId content_id) {
|
Result ContentStorageInterface::Register(PlaceHolderId placeholder_id, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
this->ClearContentCache();
|
this->ClearContentCache();
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
|
@ -170,11 +156,9 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::Delete(ContentId content_id) {
|
Result ContentStorageInterface::Delete(ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
this->ClearContentCache();
|
this->ClearContentCache();
|
||||||
|
@ -190,11 +174,9 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::Has(Out<bool> out, ContentId content_id) {
|
Result ContentStorageInterface::Has(Out<bool> out, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char content_path[FS_MAX_PATH] = {0};
|
char content_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -205,11 +187,9 @@ namespace sts::ncm {
|
||||||
out.SetValue(has);
|
out.SetValue(has);
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GetPath(OutPointerWithServerSize<lr::Path, 0x1> out, ContentId content_id) {
|
Result ContentStorageInterface::GetPath(OutPointerWithServerSize<lr::Path, 0x1> out, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char content_path[FS_MAX_PATH] = {0};
|
char content_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -217,13 +197,10 @@ namespace sts::ncm {
|
||||||
this->GetContentPath(content_path, content_id);
|
this->GetContentPath(content_path, content_id);
|
||||||
R_TRY(ConvertToFsCommonPath(common_path, FS_MAX_PATH-1, content_path));
|
R_TRY(ConvertToFsCommonPath(common_path, FS_MAX_PATH-1, content_path));
|
||||||
*out.pointer = common_path;
|
*out.pointer = common_path;
|
||||||
D_LOG("path: %s\n", common_path);
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GetPlaceHolderPath(OutPointerWithServerSize<lr::Path, 0x1> out, PlaceHolderId placeholder_id) {
|
Result ContentStorageInterface::GetPlaceHolderPath(OutPointerWithServerSize<lr::Path, 0x1> out, PlaceHolderId placeholder_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char placeholder_path[FS_MAX_PATH] = {0};
|
char placeholder_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -232,11 +209,9 @@ namespace sts::ncm {
|
||||||
R_TRY(ConvertToFsCommonPath(common_path, FS_MAX_PATH-1, placeholder_path));
|
R_TRY(ConvertToFsCommonPath(common_path, FS_MAX_PATH-1, placeholder_path));
|
||||||
*out.pointer = common_path;
|
*out.pointer = common_path;
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::CleanupAllPlaceHolder() {
|
Result ContentStorageInterface::CleanupAllPlaceHolder() {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char placeholder_root_path[FS_MAX_PATH] = {0};
|
char placeholder_root_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -252,11 +227,9 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::ListPlaceHolder(Out<u32> out_count, OutBuffer<PlaceHolderId> out_buf) {
|
Result ContentStorageInterface::ListPlaceHolder(Out<u32> out_count, OutBuffer<PlaceHolderId> out_buf) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char placeholder_root_path[FS_MAX_PATH] = {0};
|
char placeholder_root_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -283,11 +256,9 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out_count.SetValue(static_cast<u32>(entry_count));
|
out_count.SetValue(static_cast<u32>(entry_count));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GetContentCount(Out<u32> out_count) {
|
Result ContentStorageInterface::GetContentCount(Out<u32> out_count) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char content_root_path[FS_MAX_PATH] = {0};
|
char content_root_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -308,11 +279,9 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out_count.SetValue(content_count);
|
out_count.SetValue(content_count);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::ListContentId(Out<u32> out_count, OutBuffer<ContentId> out_buf, u32 start_offset) {
|
Result ContentStorageInterface::ListContentId(Out<u32> out_count, OutBuffer<ContentId> out_buf, u32 start_offset) {
|
||||||
R_DEBUG_START
|
|
||||||
if (start_offset >> 0x1f != 0) {
|
if (start_offset >> 0x1f != 0) {
|
||||||
return ResultNcmInvalidOffset;
|
return ResultNcmInvalidOffset;
|
||||||
}
|
}
|
||||||
|
@ -358,16 +327,13 @@ namespace sts::ncm {
|
||||||
for (size_t i = 0; i < entry_count; i++) {
|
for (size_t i = 0; i < entry_count; i++) {
|
||||||
char content_name[sizeof(ContentId)*2+1] = {0};
|
char content_name[sizeof(ContentId)*2+1] = {0};
|
||||||
GetStringFromContentId(content_name, out_buf[i]);
|
GetStringFromContentId(content_name, out_buf[i]);
|
||||||
D_LOG("content id: %s.nca\n", content_name);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
out_count.SetValue(static_cast<u32>(entry_count));
|
out_count.SetValue(static_cast<u32>(entry_count));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GetSizeFromContentId(Out<u64> out_size, ContentId content_id) {
|
Result ContentStorageInterface::GetSizeFromContentId(Out<u64> out_size, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char content_path[FS_MAX_PATH] = {0};
|
char content_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -380,20 +346,16 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out_size.SetValue(st.st_size);
|
out_size.SetValue(st.st_size);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::DisableForcibly() {
|
Result ContentStorageInterface::DisableForcibly() {
|
||||||
R_DEBUG_START
|
|
||||||
this->disabled = true;
|
this->disabled = true;
|
||||||
this->ClearContentCache();
|
this->ClearContentCache();
|
||||||
this->placeholder_accessor.InvalidateAll();
|
this->placeholder_accessor.InvalidateAll();
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::RevertToPlaceHolder(PlaceHolderId placeholder_id, ContentId old_content_id, ContentId new_content_id) {
|
Result ContentStorageInterface::RevertToPlaceHolder(PlaceHolderId placeholder_id, ContentId old_content_id, ContentId new_content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char old_content_path[FS_MAX_PATH] = {0};
|
char old_content_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -420,20 +382,15 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::SetPlaceHolderSize(PlaceHolderId placeholder_id, u64 size) {
|
Result ContentStorageInterface::SetPlaceHolderSize(PlaceHolderId placeholder_id, u64 size) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
R_TRY(this->placeholder_accessor.SetSize(placeholder_id, size));
|
R_TRY(this->placeholder_accessor.SetSize(placeholder_id, size));
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::ReadContentIdFile(OutBuffer<u8> buf, ContentId content_id, u64 offset) {
|
Result ContentStorageInterface::ReadContentIdFile(OutBuffer<u8> buf, ContentId content_id, u64 offset) {
|
||||||
R_DEBUG_START
|
|
||||||
/* Offset is too large */
|
/* Offset is too large */
|
||||||
if (offset >> 0x3f != 0) {
|
if (offset >> 0x3f != 0) {
|
||||||
return ResultNcmInvalidOffset;
|
return ResultNcmInvalidOffset;
|
||||||
|
@ -446,11 +403,9 @@ namespace sts::ncm {
|
||||||
R_TRY(ReadFile(this->content_cache_file_handle, offset, buf.buffer, buf.num_elements));
|
R_TRY(ReadFile(this->content_cache_file_handle, offset, buf.buffer, buf.num_elements));
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GetRightsIdFromPlaceHolderId(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, PlaceHolderId placeholder_id) {
|
Result ContentStorageInterface::GetRightsIdFromPlaceHolderId(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, PlaceHolderId placeholder_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
FsRightsId rights_id = {0};
|
FsRightsId rights_id = {0};
|
||||||
|
@ -466,11 +421,9 @@ namespace sts::ncm {
|
||||||
out_key_generation.SetValue(static_cast<u64>(key_generation));
|
out_key_generation.SetValue(static_cast<u64>(key_generation));
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GetRightsIdFromContentId(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, ContentId content_id) {
|
Result ContentStorageInterface::GetRightsIdFromContentId(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
impl::RightsIdCache* rights_id_cache = impl::GetRightsIdCache();
|
impl::RightsIdCache* rights_id_cache = impl::GetRightsIdCache();
|
||||||
|
@ -527,11 +480,9 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::WriteContentForDebug(ContentId content_id, u64 offset, InBuffer<u8> data) {
|
Result ContentStorageInterface::WriteContentForDebug(ContentId content_id, u64 offset, InBuffer<u8> data) {
|
||||||
R_DEBUG_START
|
|
||||||
/* Offset is too large */
|
/* Offset is too large */
|
||||||
if (offset >> 0x3f != 0) {
|
if (offset >> 0x3f != 0) {
|
||||||
return ResultNcmInvalidOffset;
|
return ResultNcmInvalidOffset;
|
||||||
|
@ -560,44 +511,34 @@ namespace sts::ncm {
|
||||||
R_TRY(WriteFile(f, offset, data.buffer, data.num_elements, FS_WRITEOPTION_FLUSH));
|
R_TRY(WriteFile(f, offset, data.buffer, data.num_elements, FS_WRITEOPTION_FLUSH));
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GetFreeSpaceSize(Out<u64> out_size) {
|
Result ContentStorageInterface::GetFreeSpaceSize(Out<u64> out_size) {
|
||||||
R_DEBUG_START
|
|
||||||
struct statvfs st = {0};
|
struct statvfs st = {0};
|
||||||
if (statvfs(this->root_path, &st) == -1) {
|
if (statvfs(this->root_path, &st) == -1) {
|
||||||
return fsdevGetLastResult();
|
return fsdevGetLastResult();
|
||||||
}
|
}
|
||||||
|
|
||||||
D_LOG("free space: 0x%x\n", st.f_bfree);
|
|
||||||
out_size.SetValue(st.f_bfree);
|
out_size.SetValue(st.f_bfree);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GetTotalSpaceSize(Out<u64> out_size) {
|
Result ContentStorageInterface::GetTotalSpaceSize(Out<u64> out_size) {
|
||||||
R_DEBUG_START
|
|
||||||
struct statvfs st = {0};
|
struct statvfs st = {0};
|
||||||
if (statvfs(this->root_path, &st) == -1) {
|
if (statvfs(this->root_path, &st) == -1) {
|
||||||
return fsdevGetLastResult();
|
return fsdevGetLastResult();
|
||||||
}
|
}
|
||||||
|
|
||||||
D_LOG("total space: 0x%x\n", st.f_blocks);
|
|
||||||
out_size.SetValue(st.f_blocks);
|
out_size.SetValue(st.f_blocks);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::FlushPlaceHolder() {
|
Result ContentStorageInterface::FlushPlaceHolder() {
|
||||||
R_DEBUG_START
|
|
||||||
this->placeholder_accessor.InvalidateAll();
|
this->placeholder_accessor.InvalidateAll();
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GetSizeFromPlaceHolderId(Out<u64> out_size, PlaceHolderId placeholder_id) {
|
Result ContentStorageInterface::GetSizeFromPlaceHolderId(Out<u64> out_size, PlaceHolderId placeholder_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
bool found_in_cache = false;
|
bool found_in_cache = false;
|
||||||
|
@ -620,11 +561,9 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out_size.SetValue(st.st_size);
|
out_size.SetValue(st.st_size);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::RepairInvalidFileAttribute() {
|
Result ContentStorageInterface::RepairInvalidFileAttribute() {
|
||||||
R_DEBUG_START
|
|
||||||
char content_root_path[FS_MAX_PATH] = {0};
|
char content_root_path[FS_MAX_PATH] = {0};
|
||||||
this->GetContentRootPath(content_root_path);
|
this->GetContentRootPath(content_root_path);
|
||||||
unsigned int dir_depth = this->GetContentDirectoryDepth();
|
unsigned int dir_depth = this->GetContentDirectoryDepth();
|
||||||
|
@ -653,11 +592,9 @@ namespace sts::ncm {
|
||||||
R_TRY(TraverseDirectory(placeholder_root_path, dir_depth, fix_file_attributes));
|
R_TRY(TraverseDirectory(placeholder_root_path, dir_depth, fix_file_attributes));
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ContentStorageInterface::GetRightsIdFromPlaceHolderIdWithCache(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, PlaceHolderId placeholder_id, ContentId cache_content_id) {
|
Result ContentStorageInterface::GetRightsIdFromPlaceHolderIdWithCache(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, PlaceHolderId placeholder_id, ContentId cache_content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
impl::RightsIdCache* rights_id_cache = impl::GetRightsIdCache();
|
impl::RightsIdCache* rights_id_cache = impl::GetRightsIdCache();
|
||||||
|
@ -714,7 +651,6 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -21,8 +21,6 @@
|
||||||
#include "ncm_fs.hpp"
|
#include "ncm_fs.hpp"
|
||||||
#include "ncm_path_utils.hpp"
|
#include "ncm_path_utils.hpp"
|
||||||
|
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::ncm {
|
namespace sts::ncm {
|
||||||
|
|
||||||
Result OpenFile(FILE** out, const char* path, u32 mode) {
|
Result OpenFile(FILE** out, const char* path, u32 mode) {
|
||||||
|
@ -61,9 +59,6 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
Result WriteFile(FILE* f, size_t offset, const void* buffer, size_t size, u32 option) {
|
Result WriteFile(FILE* f, size_t offset, const void* buffer, size_t size, u32 option) {
|
||||||
R_DEBUG_START
|
|
||||||
D_LOG("Writing 0x%llx to offset 0x%llx\n", size, offset);
|
|
||||||
|
|
||||||
if (fseek(f, offset, SEEK_SET) != 0) {
|
if (fseek(f, offset, SEEK_SET) != 0) {
|
||||||
return fsdevGetLastResult();
|
return fsdevGetLastResult();
|
||||||
}
|
}
|
||||||
|
@ -77,7 +72,6 @@ namespace sts::ncm {
|
||||||
}
|
}
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadFile(FILE* f, size_t offset, void* buffer, size_t size) {
|
Result ReadFile(FILE* f, size_t offset, void* buffer, size_t size) {
|
||||||
|
|
|
@ -22,8 +22,6 @@
|
||||||
#include "lr_manager_service.hpp"
|
#include "lr_manager_service.hpp"
|
||||||
#include "ncm_content_manager_service.hpp"
|
#include "ncm_content_manager_service.hpp"
|
||||||
|
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
extern u32 __start__;
|
extern u32 __start__;
|
||||||
|
|
||||||
|
|
|
@ -18,12 +18,9 @@
|
||||||
#include "ncm_path_utils.hpp"
|
#include "ncm_path_utils.hpp"
|
||||||
#include "ncm_readonlycontentstorage.hpp"
|
#include "ncm_readonlycontentstorage.hpp"
|
||||||
|
|
||||||
#include "debug.hpp"
|
|
||||||
|
|
||||||
namespace sts::ncm {
|
namespace sts::ncm {
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::Initialize(const char* root_path, MakeContentPathFunc content_path_func) {
|
Result ReadOnlyContentStorageInterface::Initialize(const char* root_path, MakeContentPathFunc content_path_func) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
const size_t root_path_len = strnlen(root_path, FS_MAX_PATH-1);
|
const size_t root_path_len = strnlen(root_path, FS_MAX_PATH-1);
|
||||||
|
@ -35,53 +32,37 @@ namespace sts::ncm {
|
||||||
strncpy(this->root_path, root_path, FS_MAX_PATH-2);
|
strncpy(this->root_path, root_path, FS_MAX_PATH-2);
|
||||||
this->make_content_path_func = *content_path_func;
|
this->make_content_path_func = *content_path_func;
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GeneratePlaceHolderId(Out<PlaceHolderId> out) {
|
Result ReadOnlyContentStorageInterface::GeneratePlaceHolderId(Out<PlaceHolderId> out) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::CreatePlaceHolder(PlaceHolderId placeholder_id, ContentId content_id, u64 size) {
|
Result ReadOnlyContentStorageInterface::CreatePlaceHolder(PlaceHolderId placeholder_id, ContentId content_id, u64 size) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::DeletePlaceHolder(PlaceHolderId placeholder_id) {
|
Result ReadOnlyContentStorageInterface::DeletePlaceHolder(PlaceHolderId placeholder_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::HasPlaceHolder(Out<bool> out, PlaceHolderId placeholder_id) {
|
Result ReadOnlyContentStorageInterface::HasPlaceHolder(Out<bool> out, PlaceHolderId placeholder_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::WritePlaceHolder(PlaceHolderId placeholder_id, u64 offset, InBuffer<u8> data) {
|
Result ReadOnlyContentStorageInterface::WritePlaceHolder(PlaceHolderId placeholder_id, u64 offset, InBuffer<u8> data) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::Register(PlaceHolderId placeholder_id, ContentId content_id) {
|
Result ReadOnlyContentStorageInterface::Register(PlaceHolderId placeholder_id, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::Delete(ContentId content_id) {
|
Result ReadOnlyContentStorageInterface::Delete(ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::Has(Out<bool> out, ContentId content_id) {
|
Result ReadOnlyContentStorageInterface::Has(Out<bool> out, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char content_path[FS_MAX_PATH] = {0};
|
char content_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -97,11 +78,9 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out.SetValue(has);
|
out.SetValue(has);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GetPath(OutPointerWithServerSize<lr::Path, 0x1> out, ContentId content_id) {
|
Result ReadOnlyContentStorageInterface::GetPath(OutPointerWithServerSize<lr::Path, 0x1> out, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char content_path[FS_MAX_PATH] = {0};
|
char content_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -119,41 +98,29 @@ namespace sts::ncm {
|
||||||
*out.pointer = common_path;
|
*out.pointer = common_path;
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GetPlaceHolderPath(OutPointerWithServerSize<lr::Path, 0x1> out, PlaceHolderId placeholder_id) {
|
Result ReadOnlyContentStorageInterface::GetPlaceHolderPath(OutPointerWithServerSize<lr::Path, 0x1> out, PlaceHolderId placeholder_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::CleanupAllPlaceHolder() {
|
Result ReadOnlyContentStorageInterface::CleanupAllPlaceHolder() {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::ListPlaceHolder(Out<u32> out_count, OutBuffer<PlaceHolderId> out_buf) {
|
Result ReadOnlyContentStorageInterface::ListPlaceHolder(Out<u32> out_count, OutBuffer<PlaceHolderId> out_buf) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GetContentCount(Out<u32> out_count) {
|
Result ReadOnlyContentStorageInterface::GetContentCount(Out<u32> out_count) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::ListContentId(Out<u32> out_count, OutBuffer<ContentId> out_buf, u32 start_offset) {
|
Result ReadOnlyContentStorageInterface::ListContentId(Out<u32> out_count, OutBuffer<ContentId> out_buf, u32 start_offset) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GetSizeFromContentId(Out<u64> out_size, ContentId content_id) {
|
Result ReadOnlyContentStorageInterface::GetSizeFromContentId(Out<u64> out_size, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
char content_path[FS_MAX_PATH] = {0};
|
char content_path[FS_MAX_PATH] = {0};
|
||||||
|
@ -173,30 +140,22 @@ namespace sts::ncm {
|
||||||
|
|
||||||
out_size.SetValue(st.st_size);
|
out_size.SetValue(st.st_size);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::DisableForcibly() {
|
Result ReadOnlyContentStorageInterface::DisableForcibly() {
|
||||||
R_DEBUG_START
|
|
||||||
this->disabled = true;
|
this->disabled = true;
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::RevertToPlaceHolder(PlaceHolderId placeholder_id, ContentId old_content_id, ContentId new_content_id) {
|
Result ReadOnlyContentStorageInterface::RevertToPlaceHolder(PlaceHolderId placeholder_id, ContentId old_content_id, ContentId new_content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::SetPlaceHolderSize(PlaceHolderId placeholder_id, u64 size) {
|
Result ReadOnlyContentStorageInterface::SetPlaceHolderSize(PlaceHolderId placeholder_id, u64 size) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::ReadContentIdFile(OutBuffer<u8> buf, ContentId content_id, u64 offset) {
|
Result ReadOnlyContentStorageInterface::ReadContentIdFile(OutBuffer<u8> buf, ContentId content_id, u64 offset) {
|
||||||
R_DEBUG_START
|
|
||||||
/* Offset is too large */
|
/* Offset is too large */
|
||||||
if (offset >> 0x3f != 0) {
|
if (offset >> 0x3f != 0) {
|
||||||
return ResultNcmInvalidOffset;
|
return ResultNcmInvalidOffset;
|
||||||
|
@ -224,17 +183,13 @@ namespace sts::ncm {
|
||||||
R_TRY(ReadFile(f, offset, buf.buffer, buf.num_elements));
|
R_TRY(ReadFile(f, offset, buf.buffer, buf.num_elements));
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GetRightsIdFromPlaceHolderId(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, PlaceHolderId placeholder_id) {
|
Result ReadOnlyContentStorageInterface::GetRightsIdFromPlaceHolderId(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, PlaceHolderId placeholder_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GetRightsIdFromContentId(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, ContentId content_id) {
|
Result ReadOnlyContentStorageInterface::GetRightsIdFromContentId(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, ContentId content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
R_TRY(this->EnsureEnabled());
|
R_TRY(this->EnsureEnabled());
|
||||||
|
|
||||||
FsRightsId rights_id = {0};
|
FsRightsId rights_id = {0};
|
||||||
|
@ -258,51 +213,36 @@ namespace sts::ncm {
|
||||||
out_key_generation.SetValue(static_cast<u64>(key_generation));
|
out_key_generation.SetValue(static_cast<u64>(key_generation));
|
||||||
|
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::WriteContentForDebug(ContentId content_id, u64 offset, InBuffer<u8> data) {
|
Result ReadOnlyContentStorageInterface::WriteContentForDebug(ContentId content_id, u64 offset, InBuffer<u8> data) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GetFreeSpaceSize(Out<u64> out_size) {
|
Result ReadOnlyContentStorageInterface::GetFreeSpaceSize(Out<u64> out_size) {
|
||||||
R_DEBUG_START
|
|
||||||
out_size.SetValue(0);
|
out_size.SetValue(0);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GetTotalSpaceSize(Out<u64> out_size) {
|
Result ReadOnlyContentStorageInterface::GetTotalSpaceSize(Out<u64> out_size) {
|
||||||
R_DEBUG_START
|
|
||||||
out_size.SetValue(0);
|
out_size.SetValue(0);
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::FlushPlaceHolder() {
|
Result ReadOnlyContentStorageInterface::FlushPlaceHolder() {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GetSizeFromPlaceHolderId(Out<u64> out, PlaceHolderId placeholder_id) {
|
Result ReadOnlyContentStorageInterface::GetSizeFromPlaceHolderId(Out<u64> out, PlaceHolderId placeholder_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::RepairInvalidFileAttribute() {
|
Result ReadOnlyContentStorageInterface::RepairInvalidFileAttribute() {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Result ReadOnlyContentStorageInterface::GetRightsIdFromPlaceHolderIdWithCache(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, PlaceHolderId placeholder_id, ContentId cache_content_id) {
|
Result ReadOnlyContentStorageInterface::GetRightsIdFromPlaceHolderIdWithCache(Out<FsRightsId> out_rights_id, Out<u64> out_key_generation, PlaceHolderId placeholder_id, ContentId cache_content_id) {
|
||||||
R_DEBUG_START
|
|
||||||
return ResultNcmInvalidContentStorageOperation;
|
return ResultNcmInvalidContentStorageOperation;
|
||||||
R_DEBUG_END
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
Loading…
Reference in a new issue