diff options
| -rw-r--r-- | CMakeLists.txt | 10 | ||||
| -rw-r--r-- | src/common/settings.h | 2 | ||||
| -rw-r--r-- | src/input_common/mouse/mouse_poller.cpp | 2 | ||||
| -rw-r--r-- | src/video_core/renderer_vulkan/vk_compute_pass.cpp | 33 | ||||
| -rw-r--r-- | src/video_core/renderer_vulkan/vk_texture_cache.cpp | 6 | ||||
| -rw-r--r-- | src/video_core/texture_cache/texture_cache.h | 6 | ||||
| -rw-r--r-- | src/video_core/texture_cache/util.cpp | 86 | ||||
| -rw-r--r-- | src/yuzu/bootmanager.cpp | 9 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_audio.cpp | 12 | 
9 files changed, 83 insertions, 83 deletions
| diff --git a/CMakeLists.txt b/CMakeLists.txt index 716256cd5..de93ca2c2 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -254,7 +254,9 @@ if(ENABLE_QT)      # Check for system Qt on Linux, fallback to bundled Qt      if (${CMAKE_SYSTEM_NAME} STREQUAL "Linux") -        find_package(Qt5 ${QT_VERSION} COMPONENTS Widgets) +        if (NOT YUZU_USE_BUNDLED_QT) +            find_package(Qt5 ${QT_VERSION} COMPONENTS Widgets) +        endif()          if (NOT Qt5_FOUND OR YUZU_USE_BUNDLED_QT)              # Check for dependencies, then enable bundled Qt download @@ -337,6 +339,8 @@ if(ENABLE_QT)          endif()      endif() +    set(YUZU_QT_NO_CMAKE_SYSTEM_PATH) +      # Workaround for an issue where conan tries to build Qt from scratch instead of download prebuilt binaries      set(QT_PREFIX_HINT) @@ -354,8 +358,10 @@ if(ENABLE_QT)          endif()          set(QT_PREFIX_HINT HINTS "${QT_PREFIX}") + +        set(YUZU_QT_NO_CMAKE_SYSTEM_PATH "NO_CMAKE_SYSTEM_PATH")      endif() -    find_package(Qt5 ${QT_VERSION} REQUIRED COMPONENTS Widgets ${QT_PREFIX_HINT} NO_CMAKE_SYSTEM_PATH) +    find_package(Qt5 ${QT_VERSION} REQUIRED COMPONENTS Widgets ${QT_PREFIX_HINT} ${YUZU_QT_NO_CMAKE_SYSTEM_PATH})      if (YUZU_USE_QT_WEB_ENGINE)          find_package(Qt5 COMPONENTS WebEngineCore WebEngineWidgets)      endif() diff --git a/src/common/settings.h b/src/common/settings.h index 832358036..ce1bc647d 100644 --- a/src/common/settings.h +++ b/src/common/settings.h @@ -368,7 +368,7 @@ struct Values {                                                  "udp_input_servers"};      BasicSetting<bool> mouse_panning{false, "mouse_panning"}; -    BasicSetting<u8> mouse_panning_sensitivity{1, "mouse_panning_sensitivity"}; +    BasicSetting<u8> mouse_panning_sensitivity{10, "mouse_panning_sensitivity"};      BasicSetting<bool> mouse_enabled{false, "mouse_enabled"};      std::string mouse_device;      MouseButtonsRaw mouse_buttons; diff --git a/src/input_common/mouse/mouse_poller.cpp b/src/input_common/mouse/mouse_poller.cpp index 1e84eaddd..efcdd85d2 100644 --- a/src/input_common/mouse/mouse_poller.cpp +++ b/src/input_common/mouse/mouse_poller.cpp @@ -84,7 +84,7 @@ public:          std::lock_guard lock{mutex};          const auto axis_value =              static_cast<float>(mouse_input->GetMouseState(button).axis.at(axis)); -        const float sensitivity = Settings::values.mouse_panning_sensitivity.GetValue() * 0.15f; +        const float sensitivity = Settings::values.mouse_panning_sensitivity.GetValue() * 0.10f;          return axis_value * sensitivity / (100.0f * range);      } diff --git a/src/video_core/renderer_vulkan/vk_compute_pass.cpp b/src/video_core/renderer_vulkan/vk_compute_pass.cpp index 205cd3b05..4181d83ee 100644 --- a/src/video_core/renderer_vulkan/vk_compute_pass.cpp +++ b/src/video_core/renderer_vulkan/vk_compute_pass.cpp @@ -374,20 +374,20 @@ void ASTCDecoderPass::MakeDataBuffer() {      scheduler.Record([src = staging_ref.buffer, offset = staging_ref.offset, dst = *data_buffer,                        TOTAL_BUFFER_SIZE](vk::CommandBuffer cmdbuf) { -        cmdbuf.CopyBuffer(src, dst, -                          VkBufferCopy{ -                              .srcOffset = offset, -                              .dstOffset = 0, -                              .size = TOTAL_BUFFER_SIZE, -                          }); -        cmdbuf.PipelineBarrier( -            VK_PIPELINE_STAGE_ALL_COMMANDS_BIT, VK_PIPELINE_STAGE_ALL_COMMANDS_BIT, 0, -            VkMemoryBarrier{ -                .sType = VK_STRUCTURE_TYPE_MEMORY_BARRIER, -                .pNext = nullptr, -                .srcAccessMask = 0, -                .dstAccessMask = VK_ACCESS_TRANSFER_READ_BIT | VK_ACCESS_TRANSFER_WRITE_BIT, -            }); +        static constexpr VkMemoryBarrier write_barrier{ +            .sType = VK_STRUCTURE_TYPE_MEMORY_BARRIER, +            .pNext = nullptr, +            .srcAccessMask = VK_ACCESS_TRANSFER_WRITE_BIT, +            .dstAccessMask = VK_ACCESS_SHADER_READ_BIT, +        }; +        const VkBufferCopy copy{ +            .srcOffset = offset, +            .dstOffset = 0, +            .size = TOTAL_BUFFER_SIZE, +        }; +        cmdbuf.CopyBuffer(src, dst, copy); +        cmdbuf.PipelineBarrier(VK_PIPELINE_STAGE_TRANSFER_BIT, VK_PIPELINE_STAGE_COMPUTE_SHADER_BIT, +                               0, write_barrier);      });  } @@ -411,7 +411,7 @@ void ASTCDecoderPass::Assemble(Image& image, const StagingBufferRef& map,              const VkImageMemoryBarrier image_barrier{                  .sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER,                  .pNext = nullptr, -                .srcAccessMask = VK_ACCESS_SHADER_WRITE_BIT, +                .srcAccessMask = is_initialized ? VK_ACCESS_SHADER_WRITE_BIT : VkAccessFlags{},                  .dstAccessMask = VK_ACCESS_SHADER_READ_BIT | VK_ACCESS_SHADER_WRITE_BIT,                  .oldLayout = is_initialized ? VK_IMAGE_LAYOUT_GENERAL : VK_IMAGE_LAYOUT_UNDEFINED,                  .newLayout = VK_IMAGE_LAYOUT_GENERAL, @@ -426,7 +426,8 @@ void ASTCDecoderPass::Assemble(Image& image, const StagingBufferRef& map,                      .layerCount = VK_REMAINING_ARRAY_LAYERS,                  },              }; -            cmdbuf.PipelineBarrier(is_initialized ? VK_PIPELINE_STAGE_ALL_COMMANDS_BIT : 0, +            cmdbuf.PipelineBarrier(is_initialized ? VK_PIPELINE_STAGE_ALL_COMMANDS_BIT +                                                  : VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,                                     VK_PIPELINE_STAGE_COMPUTE_SHADER_BIT, 0, image_barrier);              cmdbuf.BindPipeline(VK_PIPELINE_BIND_POINT_COMPUTE, vk_pipeline);          }); diff --git a/src/video_core/renderer_vulkan/vk_texture_cache.cpp b/src/video_core/renderer_vulkan/vk_texture_cache.cpp index a2ab4d1ee..fd01c902c 100644 --- a/src/video_core/renderer_vulkan/vk_texture_cache.cpp +++ b/src/video_core/renderer_vulkan/vk_texture_cache.cpp @@ -608,7 +608,10 @@ void TextureCacheRuntime::BlitImage(Framebuffer* dst_framebuffer, ImageView& dst      const VkImageAspectFlags aspect_mask = ImageAspectMask(src.format);      const bool is_dst_msaa = dst.Samples() != VK_SAMPLE_COUNT_1_BIT;      const bool is_src_msaa = src.Samples() != VK_SAMPLE_COUNT_1_BIT; -    ASSERT(aspect_mask == ImageAspectMask(dst.format)); +    if (aspect_mask != ImageAspectMask(dst.format)) { +        UNIMPLEMENTED_MSG("Incompatible blit from format {} to {}", src.format, dst.format); +        return; +    }      if (aspect_mask == VK_IMAGE_ASPECT_COLOR_BIT && !is_src_msaa && !is_dst_msaa) {          blit_image_helper.BlitColor(dst_framebuffer, src, dst_region, src_region, filter,                                      operation); @@ -911,6 +914,7 @@ void Image::UploadMemory(const StagingBufferRef& map,  void Image::DownloadMemory(const StagingBufferRef& map, std::span<const BufferImageCopy> copies) {      std::vector vk_copies = TransformBufferImageCopies(copies, map.offset, aspect_mask); +    scheduler->RequestOutsideRenderPassOperationContext();      scheduler->Record([buffer = map.buffer, image = *image, aspect_mask = aspect_mask,                         vk_copies](vk::CommandBuffer cmdbuf) {          const VkImageMemoryBarrier read_barrier{ diff --git a/src/video_core/texture_cache/texture_cache.h b/src/video_core/texture_cache/texture_cache.h index 01de2d498..85ce06d56 100644 --- a/src/video_core/texture_cache/texture_cache.h +++ b/src/video_core/texture_cache/texture_cache.h @@ -599,6 +599,12 @@ void TextureCache<P>::UpdateRenderTargets(bool is_clear) {      using namespace VideoCommon::Dirty;      auto& flags = maxwell3d.dirty.flags;      if (!flags[Dirty::RenderTargets]) { +        for (size_t index = 0; index < NUM_RT; ++index) { +            ImageViewId& color_buffer_id = render_targets.color_buffer_ids[index]; +            PrepareImageView(color_buffer_id, true, is_clear && IsFullClear(color_buffer_id)); +        } +        const ImageViewId depth_buffer_id = render_targets.depth_buffer_id; +        PrepareImageView(depth_buffer_id, true, is_clear && IsFullClear(depth_buffer_id));          return;      }      flags[Dirty::RenderTargets] = false; diff --git a/src/video_core/texture_cache/util.cpp b/src/video_core/texture_cache/util.cpp index c872517b8..59cf2f561 100644 --- a/src/video_core/texture_cache/util.cpp +++ b/src/video_core/texture_cache/util.cpp @@ -169,23 +169,6 @@ template <u32 GOB_EXTENT>      return Common::DivCeil(AdjustMipSize(size, level), block_size);  } -[[nodiscard]] constexpr std::pair<int, int> Samples(int num_samples) { -    switch (num_samples) { -    case 1: -        return {1, 1}; -    case 2: -        return {2, 1}; -    case 4: -        return {2, 2}; -    case 8: -        return {4, 2}; -    case 16: -        return {4, 4}; -    } -    UNREACHABLE_MSG("Invalid number of samples={}", num_samples); -    return {1, 1}; -} -  [[nodiscard]] constexpr Extent2D DefaultBlockSize(PixelFormat format) {      return {DefaultBlockWidth(format), DefaultBlockHeight(format)};  } @@ -283,14 +266,13 @@ template <u32 GOB_EXTENT>  }  [[nodiscard]] constexpr LevelInfo MakeLevelInfo(PixelFormat format, Extent3D size, Extent3D block, -                                                u32 num_samples, u32 tile_width_spacing) { -    const auto [samples_x, samples_y] = Samples(num_samples); +                                                u32 tile_width_spacing) {      const u32 bytes_per_block = BytesPerBlock(format);      return {          .size =              { -                .width = size.width * samples_x, -                .height = size.height * samples_y, +                .width = size.width, +                .height = size.height,                  .depth = size.depth,              },          .block = block, @@ -301,14 +283,12 @@ template <u32 GOB_EXTENT>  }  [[nodiscard]] constexpr LevelInfo MakeLevelInfo(const ImageInfo& info) { -    return MakeLevelInfo(info.format, info.size, info.block, info.num_samples, -                         info.tile_width_spacing); +    return MakeLevelInfo(info.format, info.size, info.block, info.tile_width_spacing);  }  [[nodiscard]] constexpr u32 CalculateLevelOffset(PixelFormat format, Extent3D size, Extent3D block, -                                                 u32 num_samples, u32 tile_width_spacing, -                                                 u32 level) { -    const LevelInfo info = MakeLevelInfo(format, size, block, num_samples, tile_width_spacing); +                                                 u32 tile_width_spacing, u32 level) { +    const LevelInfo info = MakeLevelInfo(format, size, block, tile_width_spacing);      u32 offset = 0;      for (u32 current_level = 0; current_level < level; ++current_level) {          offset += CalculateLevelSize(info, current_level); @@ -645,8 +625,8 @@ u32 CalculateLayerStride(const ImageInfo& info) noexcept {  u32 CalculateLayerSize(const ImageInfo& info) noexcept {      ASSERT(info.type != ImageType::Linear); -    return CalculateLevelOffset(info.format, info.size, info.block, info.num_samples, -                                info.tile_width_spacing, info.resources.levels); +    return CalculateLevelOffset(info.format, info.size, info.block, info.tile_width_spacing, +                                info.resources.levels);  }  LevelArray CalculateMipLevelOffsets(const ImageInfo& info) noexcept { @@ -1195,37 +1175,37 @@ static_assert(CalculateLevelSize(LevelInfo{{1920, 1080, 1}, {0, 2, 0}, {1, 1}, 2                0x7f8000);  static_assert(CalculateLevelSize(LevelInfo{{32, 32, 1}, {0, 0, 4}, {1, 1}, 4, 0}, 0) == 0x4000); -static_assert(CalculateLevelOffset(PixelFormat::R8_SINT, {1920, 1080, 1}, {0, 2, 0}, 1, 0, 7) == +static_assert(CalculateLevelOffset(PixelFormat::R8_SINT, {1920, 1080, 1}, {0, 2, 0}, 0, 7) ==                0x2afc00); -static_assert(CalculateLevelOffset(PixelFormat::ASTC_2D_12X12_UNORM, {8192, 4096, 1}, {0, 2, 0}, 1, -                                   0, 12) == 0x50d200); - -static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 1, 0, -                                   0) == 0); -static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 1, 0, -                                   1) == 0x400000); -static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 1, 0, -                                   2) == 0x500000); -static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 1, 0, -                                   3) == 0x540000); -static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 1, 0, -                                   4) == 0x550000); -static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 1, 0, -                                   5) == 0x554000); -static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 1, 0, -                                   6) == 0x555000); -static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 1, 0, -                                   7) == 0x555400); -static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 1, 0, -                                   8) == 0x555600); -static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 1, 0, -                                   9) == 0x555800); +static_assert(CalculateLevelOffset(PixelFormat::ASTC_2D_12X12_UNORM, {8192, 4096, 1}, {0, 2, 0}, 0, +                                   12) == 0x50d200); + +static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 0, 0) == +              0); +static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 0, 1) == +              0x400000); +static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 0, 2) == +              0x500000); +static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 0, 3) == +              0x540000); +static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 0, 4) == +              0x550000); +static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 0, 5) == +              0x554000); +static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 0, 6) == +              0x555000); +static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 0, 7) == +              0x555400); +static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 0, 8) == +              0x555600); +static_assert(CalculateLevelOffset(PixelFormat::A8B8G8R8_UNORM, {1024, 1024, 1}, {0, 4, 0}, 0, 9) == +              0x555800);  constexpr u32 ValidateLayerSize(PixelFormat format, u32 width, u32 height, u32 block_height,                                  u32 tile_width_spacing, u32 level) {      const Extent3D size{width, height, 1};      const Extent3D block{0, block_height, 0}; -    const u32 offset = CalculateLevelOffset(format, size, block, 1, tile_width_spacing, level); +    const u32 offset = CalculateLevelOffset(format, size, block, tile_width_spacing, level);      return AlignLayerSize(offset, size, block, DefaultBlockHeight(format), tile_width_spacing);  } diff --git a/src/yuzu/bootmanager.cpp b/src/yuzu/bootmanager.cpp index 7524e3c40..bfae73b60 100644 --- a/src/yuzu/bootmanager.cpp +++ b/src/yuzu/bootmanager.cpp @@ -411,8 +411,9 @@ void GRenderWindow::mousePressEvent(QMouseEvent* event) {      if (event->source() == Qt::MouseEventSynthesizedBySystem) {          return;      } - -    auto pos = event->pos(); +    // Qt sometimes returns the parent coordinates. To avoid this we read the global mouse +    // coordinates and map them to the current render area +    const auto pos = mapFromGlobal(QCursor::pos());      const auto [x, y] = ScaleTouch(pos);      const auto button = QtButtonToMouseButton(event->button());      input_subsystem->GetMouse()->PressButton(x, y, button); @@ -429,7 +430,9 @@ void GRenderWindow::mouseMoveEvent(QMouseEvent* event) {      if (event->source() == Qt::MouseEventSynthesizedBySystem) {          return;      } -    auto pos = event->pos(); +    // Qt sometimes returns the parent coordinates. To avoid this we read the global mouse +    // coordinates and map them to the current render area +    const auto pos = mapFromGlobal(QCursor::pos());      const auto [x, y] = ScaleTouch(pos);      const int center_x = width() / 2;      const int center_y = height() / 2; diff --git a/src/yuzu/configuration/configure_audio.cpp b/src/yuzu/configuration/configure_audio.cpp index d8ba939d2..1d84bf4ed 100644 --- a/src/yuzu/configuration/configure_audio.cpp +++ b/src/yuzu/configuration/configure_audio.cpp @@ -47,8 +47,8 @@ void ConfigureAudio::SetConfiguration() {      SetAudioDeviceFromDeviceID(); -    const auto volume_value = Settings::values.volume.GetValue() * ui->volume_slider->maximum(); -    ui->volume_slider->setValue(volume_value / 100); +    const auto volume_value = static_cast<int>(Settings::values.volume.GetValue()); +    ui->volume_slider->setValue(volume_value);      ui->toggle_audio_stretching->setChecked(Settings::values.enable_audio_stretching.GetValue()); @@ -113,16 +113,16 @@ void ConfigureAudio::ApplyConfiguration() {          // Guard if during game and set to game-specific value          if (Settings::values.volume.UsingGlobal()) { -            const s32 volume = ui->volume_slider->sliderPosition() / ui->volume_slider->maximum(); -            Settings::values.volume.SetValue(static_cast<u8>(100 * volume)); +            const auto volume = static_cast<u8>(ui->volume_slider->value()); +            Settings::values.volume.SetValue(volume);          }      } else {          if (ui->volume_combo_box->currentIndex() == 0) {              Settings::values.volume.SetGlobal(true);          } else {              Settings::values.volume.SetGlobal(false); -            const s32 volume = ui->volume_slider->sliderPosition() / ui->volume_slider->maximum(); -            Settings::values.volume.SetValue(static_cast<u8>(100 * volume)); +            const auto volume = static_cast<u8>(ui->volume_slider->value()); +            Settings::values.volume.SetValue(volume);          }      }  } | 
