diff options
Diffstat (limited to 'src/common')
| -rw-r--r-- | src/common/arm64/native_clock.cpp | 21 | ||||
| -rw-r--r-- | src/common/page_table.cpp | 30 | ||||
| -rw-r--r-- | src/common/page_table.h | 17 | ||||
| -rw-r--r-- | src/common/settings.cpp | 6 | ||||
| -rw-r--r-- | src/common/settings.h | 46 | ||||
| -rw-r--r-- | src/common/settings_common.h | 1 | ||||
| -rw-r--r-- | src/common/settings_input.cpp | 9 | ||||
| -rw-r--r-- | src/common/settings_input.h | 7 | 
8 files changed, 103 insertions, 34 deletions
| diff --git a/src/common/arm64/native_clock.cpp b/src/common/arm64/native_clock.cpp index 88fdba527..f437d7187 100644 --- a/src/common/arm64/native_clock.cpp +++ b/src/common/arm64/native_clock.cpp @@ -1,6 +1,9 @@  // SPDX-FileCopyrightText: Copyright 2023 yuzu Emulator Project  // SPDX-License-Identifier: GPL-2.0-or-later +#ifdef ANDROID +#include <sys/system_properties.h> +#endif  #include "common/arm64/native_clock.h"  namespace Common::Arm64 { @@ -65,7 +68,23 @@ bool NativeClock::IsNative() const {  u64 NativeClock::GetHostCNTFRQ() {      u64 cntfrq_el0 = 0; -    asm("mrs %[cntfrq_el0], cntfrq_el0" : [cntfrq_el0] "=r"(cntfrq_el0)); +    std::string_view board{""}; +#ifdef ANDROID +    char buffer[PROP_VALUE_MAX]; +    int len{__system_property_get("ro.product.board", buffer)}; +    board = std::string_view(buffer, static_cast<size_t>(len)); +#endif +    if (board == "s5e9925") { // Exynos 2200 +        cntfrq_el0 = 25600000; +    } else if (board == "exynos2100") { // Exynos 2100 +        cntfrq_el0 = 26000000; +    } else if (board == "exynos9810") { // Exynos 9810 +        cntfrq_el0 = 26000000; +    } else if (board == "s5e8825") { // Exynos 1280 +        cntfrq_el0 = 26000000; +    } else { +        asm("mrs %[cntfrq_el0], cntfrq_el0" : [cntfrq_el0] "=r"(cntfrq_el0)); +    }      return cntfrq_el0;  } diff --git a/src/common/page_table.cpp b/src/common/page_table.cpp index 4b1690269..166dc3dce 100644 --- a/src/common/page_table.cpp +++ b/src/common/page_table.cpp @@ -9,12 +9,12 @@ PageTable::PageTable() = default;  PageTable::~PageTable() noexcept = default; -bool PageTable::BeginTraversal(TraversalEntry& out_entry, TraversalContext& out_context, -                               u64 address) const { +bool PageTable::BeginTraversal(TraversalEntry* out_entry, TraversalContext* out_context, +                               Common::ProcessAddress address) const {      // Setup invalid defaults. -    out_entry.phys_addr = 0; -    out_entry.block_size = page_size; -    out_context.next_page = 0; +    out_entry->phys_addr = 0; +    out_entry->block_size = page_size; +    out_context->next_page = 0;      // Validate that we can read the actual entry.      const auto page = address / page_size; @@ -29,20 +29,20 @@ bool PageTable::BeginTraversal(TraversalEntry& out_entry, TraversalContext& out_      }      // Populate the results. -    out_entry.phys_addr = phys_addr + address; -    out_context.next_page = page + 1; -    out_context.next_offset = address + page_size; +    out_entry->phys_addr = phys_addr + GetInteger(address); +    out_context->next_page = page + 1; +    out_context->next_offset = GetInteger(address) + page_size;      return true;  } -bool PageTable::ContinueTraversal(TraversalEntry& out_entry, TraversalContext& context) const { +bool PageTable::ContinueTraversal(TraversalEntry* out_entry, TraversalContext* context) const {      // Setup invalid defaults. -    out_entry.phys_addr = 0; -    out_entry.block_size = page_size; +    out_entry->phys_addr = 0; +    out_entry->block_size = page_size;      // Validate that we can read the actual entry. -    const auto page = context.next_page; +    const auto page = context->next_page;      if (page >= backing_addr.size()) {          return false;      } @@ -54,9 +54,9 @@ bool PageTable::ContinueTraversal(TraversalEntry& out_entry, TraversalContext& c      }      // Populate the results. -    out_entry.phys_addr = phys_addr + context.next_offset; -    context.next_page = page + 1; -    context.next_offset += page_size; +    out_entry->phys_addr = phys_addr + context->next_offset; +    context->next_page = page + 1; +    context->next_offset += page_size;      return true;  } diff --git a/src/common/page_table.h b/src/common/page_table.h index e653d52ad..5340f7d86 100644 --- a/src/common/page_table.h +++ b/src/common/page_table.h @@ -6,6 +6,7 @@  #include <atomic>  #include "common/common_types.h" +#include "common/typed_address.h"  #include "common/virtual_buffer.h"  namespace Common { @@ -100,9 +101,9 @@ struct PageTable {      PageTable(PageTable&&) noexcept = default;      PageTable& operator=(PageTable&&) noexcept = default; -    bool BeginTraversal(TraversalEntry& out_entry, TraversalContext& out_context, -                        u64 address) const; -    bool ContinueTraversal(TraversalEntry& out_entry, TraversalContext& context) const; +    bool BeginTraversal(TraversalEntry* out_entry, TraversalContext* out_context, +                        Common::ProcessAddress address) const; +    bool ContinueTraversal(TraversalEntry* out_entry, TraversalContext* context) const;      /**       * Resizes the page table to be able to accommodate enough pages within @@ -117,6 +118,16 @@ struct PageTable {          return current_address_space_width_in_bits;      } +    bool GetPhysicalAddress(Common::PhysicalAddress* out_phys_addr, +                            Common::ProcessAddress virt_addr) const { +        if (virt_addr > (1ULL << this->GetAddressSpaceBits())) { +            return false; +        } + +        *out_phys_addr = backing_addr[virt_addr / page_size] + GetInteger(virt_addr); +        return true; +    } +      /**       * Vector of memory pointers backing each page. An entry can only be non-null if the       * corresponding attribute element is of type `Memory`. diff --git a/src/common/settings.cpp b/src/common/settings.cpp index 98b43e49c..a10131eb2 100644 --- a/src/common/settings.cpp +++ b/src/common/settings.cpp @@ -203,10 +203,12 @@ const char* TranslateCategory(Category category) {      case Category::Ui:      case Category::UiGeneral:          return "UI"; +    case Category::UiAudio: +        return "UiAudio";      case Category::UiLayout: -        return "UiLayout"; +        return "UILayout";      case Category::UiGameList: -        return "UiGameList"; +        return "UIGameList";      case Category::Screenshots:          return "Screenshots";      case Category::Shortcuts: diff --git a/src/common/settings.h b/src/common/settings.h index 9317075f7..b929fd957 100644 --- a/src/common/settings.h +++ b/src/common/settings.h @@ -153,7 +153,7 @@ struct Values {                                         true,                                         true};      Setting<bool, false> audio_muted{ -        linkage, false, "audio_muted", Category::Audio, Specialization::Default, false, true}; +        linkage, false, "audio_muted", Category::Audio, Specialization::Default, true, true};      Setting<bool, false> dump_audio_commands{          linkage, false, "dump_audio_commands", Category::Audio, Specialization::Default, false}; @@ -232,7 +232,11 @@ struct Values {      SwitchableSetting<bool> use_asynchronous_gpu_emulation{          linkage, true, "use_asynchronous_gpu_emulation", Category::Renderer};      SwitchableSetting<AstcDecodeMode, true> accelerate_astc{linkage, +#ifdef ANDROID +                                                            AstcDecodeMode::Cpu, +#else                                                              AstcDecodeMode::Gpu, +#endif                                                              AstcDecodeMode::Cpu,                                                              AstcDecodeMode::CpuAsynchronous,                                                              "accelerate_astc", @@ -304,7 +308,11 @@ struct Values {          linkage, 0, "bg_blue", Category::Renderer, Specialization::Default, true, true};      SwitchableSetting<GpuAccuracy, true> gpu_accuracy{linkage, +#ifdef ANDROID +                                                      GpuAccuracy::Normal, +#else                                                        GpuAccuracy::High, +#endif                                                        GpuAccuracy::Normal,                                                        GpuAccuracy::Extreme,                                                        "gpu_accuracy", @@ -313,20 +321,38 @@ struct Values {                                                        true,                                                        true};      GpuAccuracy current_gpu_accuracy{GpuAccuracy::High}; -    SwitchableSetting<AnisotropyMode, true> max_anisotropy{ -        linkage,          AnisotropyMode::Automatic, AnisotropyMode::Automatic, AnisotropyMode::X16, -        "max_anisotropy", Category::RendererAdvanced}; +    SwitchableSetting<AnisotropyMode, true> max_anisotropy{linkage, +#ifdef ANDROID +                                                           AnisotropyMode::Default, +#else +                                                           AnisotropyMode::Automatic, +#endif +                                                           AnisotropyMode::Automatic, +                                                           AnisotropyMode::X16, +                                                           "max_anisotropy", +                                                           Category::RendererAdvanced};      SwitchableSetting<AstcRecompression, true> astc_recompression{linkage,                                                                    AstcRecompression::Uncompressed,                                                                    AstcRecompression::Uncompressed,                                                                    AstcRecompression::Bc3,                                                                    "astc_recompression",                                                                    Category::RendererAdvanced}; -    SwitchableSetting<bool> async_presentation{linkage, false, "async_presentation", -                                               Category::RendererAdvanced}; +    SwitchableSetting<bool> async_presentation{linkage, +#ifdef ANDROID +                                               true, +#else +                                               false, +#endif +                                               "async_presentation", Category::RendererAdvanced};      SwitchableSetting<bool> renderer_force_max_clock{linkage, false, "force_max_clock",                                                       Category::RendererAdvanced}; -    SwitchableSetting<bool> use_reactive_flushing{linkage, true, "use_reactive_flushing", +    SwitchableSetting<bool> use_reactive_flushing{linkage, +#ifdef ANDROID +                                                  false, +#else +                                                  true, +#endif +                                                  "use_reactive_flushing",                                                    Category::RendererAdvanced};      SwitchableSetting<bool> use_asynchronous_shaders{linkage, false, "use_asynchronous_shaders",                                                       Category::RendererAdvanced}; @@ -358,6 +384,8 @@ struct Values {                                            Category::RendererDebug};      // TODO: remove this once AMDVLK supports VK_EXT_depth_bias_control      bool renderer_amdvlk_depth_bias_workaround{}; +    Setting<bool> disable_buffer_reorder{linkage, false, "disable_buffer_reorder", +                                         Category::RendererDebug};      // System      SwitchableSetting<Language, true> language_index{linkage, @@ -390,7 +418,11 @@ struct Values {      Setting<s32> current_user{linkage, 0, "current_user", Category::System};      SwitchableSetting<ConsoleMode> use_docked_mode{linkage, +#ifdef ANDROID +                                                   ConsoleMode::Handheld, +#else                                                     ConsoleMode::Docked, +#endif                                                     "use_docked_mode",                                                     Category::System,                                                     Specialization::Radio, diff --git a/src/common/settings_common.h b/src/common/settings_common.h index 1800ab10d..7943223eb 100644 --- a/src/common/settings_common.h +++ b/src/common/settings_common.h @@ -32,6 +32,7 @@ enum class Category : u32 {      AddOns,      Controls,      Ui, +    UiAudio,      UiGeneral,      UiLayout,      UiGameList, diff --git a/src/common/settings_input.cpp b/src/common/settings_input.cpp index 0a6eea3cf..a6007e7b2 100644 --- a/src/common/settings_input.cpp +++ b/src/common/settings_input.cpp @@ -6,10 +6,11 @@  namespace Settings {  namespace NativeButton {  const std::array<const char*, NumButtons> mapping = {{ -    "button_a",      "button_b",     "button_x",     "button_y",    "button_lstick", -    "button_rstick", "button_l",     "button_r",     "button_zl",   "button_zr", -    "button_plus",   "button_minus", "button_dleft", "button_dup",  "button_dright", -    "button_ddown",  "button_sl",    "button_sr",    "button_home", "button_screenshot", +    "button_a",       "button_b",       "button_x",      "button_y",    "button_lstick", +    "button_rstick",  "button_l",       "button_r",      "button_zl",   "button_zr", +    "button_plus",    "button_minus",   "button_dleft",  "button_dup",  "button_dright", +    "button_ddown",   "button_slleft",  "button_srleft", "button_home", "button_screenshot", +    "button_slright", "button_srright",  }};  } diff --git a/src/common/settings_input.h b/src/common/settings_input.h index 46f38c703..53a95ef8f 100644 --- a/src/common/settings_input.h +++ b/src/common/settings_input.h @@ -29,12 +29,15 @@ enum Values : int {      DRight,      DDown, -    SL, -    SR, +    SLLeft, +    SRLeft,      Home,      Screenshot, +    SLRight, +    SRRight, +      NumButtons,  }; | 
