diff options
| m--------- | externals/catch | 0 | ||||
| -rw-r--r-- | src/common/file_util.h | 12 | ||||
| -rw-r--r-- | src/core/CMakeLists.txt | 2 | ||||
| -rw-r--r-- | src/core/hle/romfs.cpp | 102 | ||||
| -rw-r--r-- | src/core/hle/romfs.h | 22 | ||||
| -rw-r--r-- | src/core/hle/service/acc/acc.cpp | 7 | ||||
| -rw-r--r-- | src/core/hle/service/acc/acc.h | 1 | ||||
| -rw-r--r-- | src/core/hle/service/acc/acc_su.cpp | 2 | ||||
| -rw-r--r-- | src/core/hle/service/acc/acc_u0.cpp | 2 | ||||
| -rw-r--r-- | src/core/hle/service/acc/acc_u1.cpp | 2 | ||||
| -rw-r--r-- | src/core/hle/service/hid/hid.cpp | 2 | ||||
| -rw-r--r-- | src/tests/common/param_package.cpp | 2 | ||||
| -rw-r--r-- | src/tests/core/core_timing.cpp | 2 | ||||
| -rw-r--r-- | src/tests/glad.cpp | 2 | ||||
| -rw-r--r-- | src/tests/tests.cpp | 2 | 
15 files changed, 24 insertions, 138 deletions
diff --git a/externals/catch b/externals/catch -Subproject d2a130f2433aeaca070e3e4d6298a80049d21cf +Subproject 15cf3caaceb21172ea42a24e595a2eb58c3ec96 diff --git a/src/common/file_util.h b/src/common/file_util.h index 28697d527..430dac41c 100644 --- a/src/common/file_util.h +++ b/src/common/file_util.h @@ -8,6 +8,7 @@  #include <cstdio>  #include <fstream>  #include <functional> +#include <limits>  #include <string>  #include <string_view>  #include <type_traits> @@ -210,8 +211,9 @@ public:          static_assert(std::is_trivially_copyable<T>(),                        "Given array does not consist of trivially copyable objects"); -        if (!IsOpen()) -            return -1; +        if (!IsOpen()) { +            return std::numeric_limits<size_t>::max(); +        }          return std::fread(data, sizeof(T), length, m_file);      } @@ -220,8 +222,10 @@ public:      size_t WriteArray(const T* data, size_t length) {          static_assert(std::is_trivially_copyable<T>(),                        "Given array does not consist of trivially copyable objects"); -        if (!IsOpen()) -            return -1; +        if (!IsOpen()) { +            return std::numeric_limits<size_t>::max(); +        } +          return std::fwrite(data, sizeof(T), length, m_file);      } diff --git a/src/core/CMakeLists.txt b/src/core/CMakeLists.txt index 0abf7edc1..cceb1564b 100644 --- a/src/core/CMakeLists.txt +++ b/src/core/CMakeLists.txt @@ -104,8 +104,6 @@ add_library(core STATIC      hle/lock.cpp      hle/lock.h      hle/result.h -    hle/romfs.cpp -    hle/romfs.h      hle/service/acc/acc.cpp      hle/service/acc/acc.h      hle/service/acc/acc_aa.cpp diff --git a/src/core/hle/romfs.cpp b/src/core/hle/romfs.cpp deleted file mode 100644 index 3157df71d..000000000 --- a/src/core/hle/romfs.cpp +++ /dev/null @@ -1,102 +0,0 @@ -// Copyright 2017 Citra Emulator Project -// Licensed under GPLv2 or any later version -// Refer to the license.txt file included. - -#include <cstring> -#include "common/swap.h" -#include "core/hle/romfs.h" - -namespace RomFS { - -struct Header { -    u32_le header_length; -    u32_le dir_hash_table_offset; -    u32_le dir_hash_table_length; -    u32_le dir_table_offset; -    u32_le dir_table_length; -    u32_le file_hash_table_offset; -    u32_le file_hash_table_length; -    u32_le file_table_offset; -    u32_le file_table_length; -    u32_le data_offset; -}; - -static_assert(sizeof(Header) == 0x28, "Header has incorrect size"); - -struct DirectoryMetadata { -    u32_le parent_dir_offset; -    u32_le next_dir_offset; -    u32_le first_child_dir_offset; -    u32_le first_file_offset; -    u32_le same_hash_next_dir_offset; -    u32_le name_length; // in bytes -    // followed by directory name -}; - -static_assert(sizeof(DirectoryMetadata) == 0x18, "DirectoryMetadata has incorrect size"); - -struct FileMetadata { -    u32_le parent_dir_offset; -    u32_le next_file_offset; -    u64_le data_offset; -    u64_le data_length; -    u32_le same_hash_next_file_offset; -    u32_le name_length; // in bytes -    // followed by file name -}; - -static_assert(sizeof(FileMetadata) == 0x20, "FileMetadata has incorrect size"); - -static bool MatchName(const u8* buffer, u32 name_length, const std::u16string& name) { -    std::vector<char16_t> name_buffer(name_length / sizeof(char16_t)); -    std::memcpy(name_buffer.data(), buffer, name_length); -    return name == std::u16string(name_buffer.begin(), name_buffer.end()); -} - -const u8* GetFilePointer(const u8* romfs, const std::vector<std::u16string>& path) { -    constexpr u32 INVALID_FIELD = 0xFFFFFFFF; - -    // Split path into directory names and file name -    std::vector<std::u16string> dir_names = path; -    dir_names.pop_back(); -    const std::u16string& file_name = path.back(); - -    Header header; -    std::memcpy(&header, romfs, sizeof(header)); - -    // Find directories of each level -    DirectoryMetadata dir; -    const u8* current_dir = romfs + header.dir_table_offset; -    std::memcpy(&dir, current_dir, sizeof(dir)); -    for (const std::u16string& dir_name : dir_names) { -        u32 child_dir_offset; -        child_dir_offset = dir.first_child_dir_offset; -        while (true) { -            if (child_dir_offset == INVALID_FIELD) { -                return nullptr; -            } -            const u8* current_child_dir = romfs + header.dir_table_offset + child_dir_offset; -            std::memcpy(&dir, current_child_dir, sizeof(dir)); -            if (MatchName(current_child_dir + sizeof(dir), dir.name_length, dir_name)) { -                current_dir = current_child_dir; -                break; -            } -            child_dir_offset = dir.next_dir_offset; -        } -    } - -    // Find the file -    FileMetadata file; -    u32 file_offset = dir.first_file_offset; -    while (file_offset != INVALID_FIELD) { -        const u8* current_file = romfs + header.file_table_offset + file_offset; -        std::memcpy(&file, current_file, sizeof(file)); -        if (MatchName(current_file + sizeof(file), file.name_length, file_name)) { -            return romfs + header.data_offset + file.data_offset; -        } -        file_offset = file.next_file_offset; -    } -    return nullptr; -} - -} // namespace RomFS diff --git a/src/core/hle/romfs.h b/src/core/hle/romfs.h deleted file mode 100644 index ee9f29760..000000000 --- a/src/core/hle/romfs.h +++ /dev/null @@ -1,22 +0,0 @@ -// Copyright 2017 Citra Emulator Project -// Licensed under GPLv2 or any later version -// Refer to the license.txt file included. - -#pragma once - -#include <string> -#include <vector> -#include "common/common_types.h" - -namespace RomFS { - -/** - * Gets the pointer to a file in a RomFS image. - * @param romfs The pointer to the RomFS image - * @param path A vector containing the directory names and file name of the path to the file - * @return the pointer to the file - * @todo reimplement this with a full RomFS manager - */ -const u8* GetFilePointer(const u8* romfs, const std::vector<std::u16string>& path); - -} // namespace RomFS diff --git a/src/core/hle/service/acc/acc.cpp b/src/core/hle/service/acc/acc.cpp index 6d15b46ed..e952b0518 100644 --- a/src/core/hle/service/acc/acc.cpp +++ b/src/core/hle/service/acc/acc.cpp @@ -119,6 +119,13 @@ private:      }  }; +void Module::Interface::GetUserCount(Kernel::HLERequestContext& ctx) { +    LOG_WARNING(Service_ACC, "(STUBBED) called"); +    IPC::ResponseBuilder rb{ctx, 3}; +    rb.Push(RESULT_SUCCESS); +    rb.Push<u32>(1); +} +  void Module::Interface::GetUserExistence(Kernel::HLERequestContext& ctx) {      LOG_WARNING(Service_ACC, "(STUBBED) called");      IPC::ResponseBuilder rb{ctx, 3}; diff --git a/src/core/hle/service/acc/acc.h b/src/core/hle/service/acc/acc.h index 0a01d954c..88cabaa01 100644 --- a/src/core/hle/service/acc/acc.h +++ b/src/core/hle/service/acc/acc.h @@ -14,6 +14,7 @@ public:      public:          explicit Interface(std::shared_ptr<Module> module, const char* name); +        void GetUserCount(Kernel::HLERequestContext& ctx);          void GetUserExistence(Kernel::HLERequestContext& ctx);          void ListAllUsers(Kernel::HLERequestContext& ctx);          void ListOpenUsers(Kernel::HLERequestContext& ctx); diff --git a/src/core/hle/service/acc/acc_su.cpp b/src/core/hle/service/acc/acc_su.cpp index 9ffb40b22..8b2a71f37 100644 --- a/src/core/hle/service/acc/acc_su.cpp +++ b/src/core/hle/service/acc/acc_su.cpp @@ -8,7 +8,7 @@ namespace Service::Account {  ACC_SU::ACC_SU(std::shared_ptr<Module> module) : Module::Interface(std::move(module), "acc:su") {      static const FunctionInfo functions[] = { -        {0, nullptr, "GetUserCount"}, +        {0, &ACC_SU::GetUserCount, "GetUserCount"},          {1, &ACC_SU::GetUserExistence, "GetUserExistence"},          {2, &ACC_SU::ListAllUsers, "ListAllUsers"},          {3, &ACC_SU::ListOpenUsers, "ListOpenUsers"}, diff --git a/src/core/hle/service/acc/acc_u0.cpp b/src/core/hle/service/acc/acc_u0.cpp index 44e21ac09..d84c8b2e1 100644 --- a/src/core/hle/service/acc/acc_u0.cpp +++ b/src/core/hle/service/acc/acc_u0.cpp @@ -8,7 +8,7 @@ namespace Service::Account {  ACC_U0::ACC_U0(std::shared_ptr<Module> module) : Module::Interface(std::move(module), "acc:u0") {      static const FunctionInfo functions[] = { -        {0, nullptr, "GetUserCount"}, +        {0, &ACC_U0::GetUserCount, "GetUserCount"},          {1, &ACC_U0::GetUserExistence, "GetUserExistence"},          {2, &ACC_U0::ListAllUsers, "ListAllUsers"},          {3, &ACC_U0::ListOpenUsers, "ListOpenUsers"}, diff --git a/src/core/hle/service/acc/acc_u1.cpp b/src/core/hle/service/acc/acc_u1.cpp index d101d4e0d..0ceaf06b5 100644 --- a/src/core/hle/service/acc/acc_u1.cpp +++ b/src/core/hle/service/acc/acc_u1.cpp @@ -8,7 +8,7 @@ namespace Service::Account {  ACC_U1::ACC_U1(std::shared_ptr<Module> module) : Module::Interface(std::move(module), "acc:u1") {      static const FunctionInfo functions[] = { -        {0, nullptr, "GetUserCount"}, +        {0, &ACC_U1::GetUserCount, "GetUserCount"},          {1, &ACC_U1::GetUserExistence, "GetUserExistence"},          {2, &ACC_U1::ListAllUsers, "ListAllUsers"},          {3, &ACC_U1::ListOpenUsers, "ListOpenUsers"}, diff --git a/src/core/hle/service/hid/hid.cpp b/src/core/hle/service/hid/hid.cpp index 8f0262e34..dcdfa0e19 100644 --- a/src/core/hle/service/hid/hid.cpp +++ b/src/core/hle/service/hid/hid.cpp @@ -457,7 +457,7 @@ private:      }      void IsSixAxisSensorAtRest(Kernel::HLERequestContext& ctx) { -        IPC::ResponseBuilder rb{ctx, 2}; +        IPC::ResponseBuilder rb{ctx, 3};          rb.Push(RESULT_SUCCESS);          // TODO (Hexagon12): Properly implement reading gyroscope values from controllers.          rb.Push(true); diff --git a/src/tests/common/param_package.cpp b/src/tests/common/param_package.cpp index 19d372236..4c0f9654f 100644 --- a/src/tests/common/param_package.cpp +++ b/src/tests/common/param_package.cpp @@ -2,7 +2,7 @@  // Licensed under GPLv2 or any later version  // Refer to the license.txt file included. -#include <catch.hpp> +#include <catch2/catch.hpp>  #include <math.h>  #include "common/param_package.h" diff --git a/src/tests/core/core_timing.cpp b/src/tests/core/core_timing.cpp index fcaa30990..2242c14cf 100644 --- a/src/tests/core/core_timing.cpp +++ b/src/tests/core/core_timing.cpp @@ -2,7 +2,7 @@  // Licensed under GPLv2+  // Refer to the license.txt file included. -#include <catch.hpp> +#include <catch2/catch.hpp>  #include <array>  #include <bitset> diff --git a/src/tests/glad.cpp b/src/tests/glad.cpp index b0b016440..1797c0e3d 100644 --- a/src/tests/glad.cpp +++ b/src/tests/glad.cpp @@ -2,7 +2,7 @@  // Licensed under GPLv2 or any later version  // Refer to the license.txt file included. -#include <catch.hpp> +#include <catch2/catch.hpp>  #include <glad/glad.h>  // This is not an actual test, but a work-around for issue #2183. diff --git a/src/tests/tests.cpp b/src/tests/tests.cpp index 73978676f..275b430d9 100644 --- a/src/tests/tests.cpp +++ b/src/tests/tests.cpp @@ -3,7 +3,7 @@  // Refer to the license.txt file included.  #define CATCH_CONFIG_MAIN -#include <catch.hpp> +#include <catch2/catch.hpp>  // Catch provides the main function since we've given it the  // CATCH_CONFIG_MAIN preprocessor directive.  | 
