diff options
| -rw-r--r-- | CMakeLists.txt | 20 | ||||
| -rw-r--r-- | CMakeModules/DownloadExternals.cmake | 22 | ||||
| -rw-r--r-- | src/core/frontend/emu_window.cpp | 23 | ||||
| -rw-r--r-- | src/core/frontend/emu_window.h | 28 | ||||
| -rw-r--r-- | src/core/hle/service/hid/hid.cpp | 39 | ||||
| -rw-r--r-- | src/yuzu_cmd/CMakeLists.txt | 1 | ||||
| -rw-r--r-- | src/yuzu_cmd/emu_window/emu_window_sdl2.cpp | 2 | ||||
| -rw-r--r-- | src/yuzu_cmd/emu_window/emu_window_sdl2.h | 2 | ||||
| -rw-r--r-- | src/yuzu_cmd/resource.h | 16 | 
9 files changed, 104 insertions, 49 deletions
| diff --git a/CMakeLists.txt b/CMakeLists.txt index 7afa972f5..15ecb8a9c 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -19,6 +19,8 @@ CMAKE_DEPENDENT_OPTION(YUZU_USE_BUNDLED_QT "Download bundled Qt binaries" ON "EN  option(ENABLE_WEB_SERVICE "Enable web services (telemetry, etc.)" ON) +option(YUZU_USE_BUNDLED_BOOST "Download bundled Boost" OFF) +  CMAKE_DEPENDENT_OPTION(YUZU_USE_BUNDLED_FFMPEG "Download/Build bundled FFmpeg" ON "WIN32" OFF)  option(YUZU_USE_QT_WEB_ENGINE "Use QtWebEngine for web applet implementation" OFF) @@ -199,7 +201,9 @@ macro(yuzu_find_packages)      unset(FN_FORCE_REQUIRED)  endmacro() -find_package(Boost 1.73.0 COMPONENTS context headers QUIET) +if (NOT YUZU_USE_BUNDLED_BOOST) +    find_package(Boost 1.73.0 COMPONENTS context headers QUIET) +endif()  if (Boost_FOUND)      set(Boost_LIBRARIES Boost::boost)      # Conditionally add Boost::context only if the active version of the Conan or system Boost package provides it @@ -210,6 +214,20 @@ if (Boost_FOUND)      if (TARGET Boost::context)          list(APPEND Boost_LIBRARIES Boost::context)      endif() +elseif (${CMAKE_SYSTEM_NAME} STREQUAL "Linux" OR YUZU_USE_BUNDLED_BOOST) +    message(STATUS "Boost 1.73.0 or newer not found, falling back to externals") +    set(YUZU_USE_BUNDLED_BOOST ON CACHE BOOL "Download bundled Boost" FORCE) + +    # Use yuzu Boost binaries +    set(Boost_EXT_NAME "boost_1_75_0") +    set(Boost_PATH "${CMAKE_BINARY_DIR}/externals/${Boost_EXT_NAME}") +    download_bundled_external("boost/" ${Boost_EXT_NAME} "") +    set(Boost_USE_DEBUG_RUNTIME FALSE) +    set(Boost_USE_STATIC_LIBS ON) +    find_package(Boost 1.75.0 REQUIRED COMPONENTS context headers PATHS ${Boost_PATH} NO_DEFAULT_PATH) +    # Manually set the include dirs since the find_package sets it incorrectly +    set(Boost_INCLUDE_DIRS ${Boost_PATH}/include CACHE PATH "Path to Boost headers" FORCE) +    include_directories(SYSTEM "${Boost_INCLUDE_DIRS}")  else()      message(STATUS "Boost 1.73.0 or newer not found, falling back to Conan")      list(APPEND CONAN_REQUIRED_LIBS "boost/1.73.0") diff --git a/CMakeModules/DownloadExternals.cmake b/CMakeModules/DownloadExternals.cmake index d3f91764d..4c4dec5ff 100644 --- a/CMakeModules/DownloadExternals.cmake +++ b/CMakeModules/DownloadExternals.cmake @@ -4,15 +4,29 @@  #   remote_path: path to the file to download, relative to the remote repository root  #   prefix_var: name of a variable which will be set with the path to the extracted contents  function(download_bundled_external remote_path lib_name prefix_var) + +set(package_repo "no_platform") +set(package_extension "no_platform") +if (WIN32) +    set(package_repo "ext-windows-bin/raw/master/") +    set(package_extension ".7z") +elseif (${CMAKE_SYSTEM_NAME} STREQUAL "Linux") +    set(package_repo "ext-linux-bin/raw/main/") +    set(package_extension ".tar.xz") +else() +    message(FATAL_ERROR "No package available for this platform") +endif() +set(package_url "https://github.com/yuzu-emu/${package_repo}") +  set(prefix "${CMAKE_BINARY_DIR}/externals/${lib_name}")  if (NOT EXISTS "${prefix}")      message(STATUS "Downloading binaries for ${lib_name}...")      file(DOWNLOAD -        https://github.com/yuzu-emu/ext-windows-bin/raw/master/${remote_path}${lib_name}.7z -        "${CMAKE_BINARY_DIR}/externals/${lib_name}.7z" SHOW_PROGRESS) -    execute_process(COMMAND ${CMAKE_COMMAND} -E tar xf "${CMAKE_BINARY_DIR}/externals/${lib_name}.7z" +        ${package_url}${remote_path}${lib_name}${package_extension} +        "${CMAKE_BINARY_DIR}/externals/${lib_name}${package_extension}" SHOW_PROGRESS) +    execute_process(COMMAND ${CMAKE_COMMAND} -E tar xf "${CMAKE_BINARY_DIR}/externals/${lib_name}${package_extension}"          WORKING_DIRECTORY "${CMAKE_BINARY_DIR}/externals")  endif()  message(STATUS "Using bundled binaries at ${prefix}")  set(${prefix_var} "${prefix}" PARENT_SCOPE) -endfunction()
\ No newline at end of file +endfunction() diff --git a/src/core/frontend/emu_window.cpp b/src/core/frontend/emu_window.cpp index 474de9206..cff49899a 100644 --- a/src/core/frontend/emu_window.cpp +++ b/src/core/frontend/emu_window.cpp @@ -60,23 +60,23 @@ EmuWindow::~EmuWindow() {   * @param framebuffer_y Framebuffer y-coordinate to check   * @return True if the coordinates are within the touchpad, otherwise false   */ -static bool IsWithinTouchscreen(const Layout::FramebufferLayout& layout, unsigned framebuffer_x, -                                unsigned framebuffer_y) { +static bool IsWithinTouchscreen(const Layout::FramebufferLayout& layout, u32 framebuffer_x, +                                u32 framebuffer_y) {      return (framebuffer_y >= layout.screen.top && framebuffer_y < layout.screen.bottom &&              framebuffer_x >= layout.screen.left && framebuffer_x < layout.screen.right);  } -std::tuple<unsigned, unsigned> EmuWindow::ClipToTouchScreen(unsigned new_x, unsigned new_y) const { +std::pair<u32, u32> EmuWindow::ClipToTouchScreen(u32 new_x, u32 new_y) const {      new_x = std::max(new_x, framebuffer_layout.screen.left);      new_x = std::min(new_x, framebuffer_layout.screen.right - 1);      new_y = std::max(new_y, framebuffer_layout.screen.top);      new_y = std::min(new_y, framebuffer_layout.screen.bottom - 1); -    return std::make_tuple(new_x, new_y); +    return std::make_pair(new_x, new_y);  } -void EmuWindow::TouchPressed(unsigned framebuffer_x, unsigned framebuffer_y, std::size_t id) { +void EmuWindow::TouchPressed(u32 framebuffer_x, u32 framebuffer_y, size_t id) {      if (!IsWithinTouchscreen(framebuffer_layout, framebuffer_x, framebuffer_y)) {          return;      } @@ -95,7 +95,7 @@ void EmuWindow::TouchPressed(unsigned framebuffer_x, unsigned framebuffer_y, std      touch_state->status[id] = std::make_tuple(x, y, true);  } -void EmuWindow::TouchReleased(std::size_t id) { +void EmuWindow::TouchReleased(size_t id) {      if (id >= touch_state->status.size()) {          return;      } @@ -103,20 +103,23 @@ void EmuWindow::TouchReleased(std::size_t id) {      touch_state->status[id] = std::make_tuple(0.0f, 0.0f, false);  } -void EmuWindow::TouchMoved(unsigned framebuffer_x, unsigned framebuffer_y, std::size_t id) { +void EmuWindow::TouchMoved(u32 framebuffer_x, u32 framebuffer_y, size_t id) {      if (id >= touch_state->status.size()) {          return;      } -    if (!std::get<2>(touch_state->status[id])) + +    if (!std::get<2>(touch_state->status[id])) {          return; +    } -    if (!IsWithinTouchscreen(framebuffer_layout, framebuffer_x, framebuffer_y)) +    if (!IsWithinTouchscreen(framebuffer_layout, framebuffer_x, framebuffer_y)) {          std::tie(framebuffer_x, framebuffer_y) = ClipToTouchScreen(framebuffer_x, framebuffer_y); +    }      TouchPressed(framebuffer_x, framebuffer_y, id);  } -void EmuWindow::UpdateCurrentFramebufferLayout(unsigned width, unsigned height) { +void EmuWindow::UpdateCurrentFramebufferLayout(u32 width, u32 height) {      NotifyFramebufferLayoutChanged(Layout::DefaultFrameLayout(width, height));  } diff --git a/src/core/frontend/emu_window.h b/src/core/frontend/emu_window.h index 2436c6580..076148698 100644 --- a/src/core/frontend/emu_window.h +++ b/src/core/frontend/emu_window.h @@ -82,7 +82,7 @@ public:          bool fullscreen = false;          int res_width = 0;          int res_height = 0; -        std::pair<unsigned, unsigned> min_client_area_size; +        std::pair<u32, u32> min_client_area_size;      };      /// Data describing host window system information @@ -119,13 +119,13 @@ public:       * @param framebuffer_y Framebuffer y-coordinate that was pressed       * @param id Touch event ID       */ -    void TouchPressed(unsigned framebuffer_x, unsigned framebuffer_y, std::size_t id); +    void TouchPressed(u32 framebuffer_x, u32 framebuffer_y, size_t id);      /**       * Signal that a touch released event has occurred (e.g. mouse click released)       * @param id Touch event ID       */ -    void TouchReleased(std::size_t id); +    void TouchReleased(size_t id);      /**       * Signal that a touch movement event has occurred (e.g. mouse was moved over the emu window) @@ -133,7 +133,7 @@ public:       * @param framebuffer_y Framebuffer y-coordinate       * @param id Touch event ID       */ -    void TouchMoved(unsigned framebuffer_x, unsigned framebuffer_y, std::size_t id); +    void TouchMoved(u32 framebuffer_x, u32 framebuffer_y, size_t id);      /**       * Returns currently active configuration. @@ -173,7 +173,7 @@ public:       * Convenience method to update the current frame layout       * Read from the current settings to determine which layout to use.       */ -    void UpdateCurrentFramebufferLayout(unsigned width, unsigned height); +    void UpdateCurrentFramebufferLayout(u32 width, u32 height);  protected:      explicit EmuWindow(); @@ -208,7 +208,7 @@ protected:       * Update internal client area size with the given parameter.       * @note EmuWindow implementations will usually use this in window resize event handlers.       */ -    void NotifyClientAreaSizeChanged(const std::pair<unsigned, unsigned>& size) { +    void NotifyClientAreaSizeChanged(std::pair<u32, u32> size) {          client_area_width = size.first;          client_area_height = size.second;      } @@ -221,14 +221,19 @@ private:       * For the request to be honored, EmuWindow implementations will usually reimplement this       * function.       */ -    virtual void OnMinimalClientAreaChangeRequest(std::pair<unsigned, unsigned>) { +    virtual void OnMinimalClientAreaChangeRequest(std::pair<u32, u32>) {          // By default, ignore this request and do nothing.      } +    /** +     * Clip the provided coordinates to be inside the touchscreen area. +     */ +    std::pair<u32, u32> ClipToTouchScreen(u32 new_x, u32 new_y) const; +      Layout::FramebufferLayout framebuffer_layout; ///< Current framebuffer layout -    unsigned client_area_width;  ///< Current client width, should be set by window impl. -    unsigned client_area_height; ///< Current client height, should be set by window impl. +    u32 client_area_width;  ///< Current client width, should be set by window impl. +    u32 client_area_height; ///< Current client height, should be set by window impl.      WindowConfig config;        ///< Internal configuration (changes pending for being applied in                                  /// ProcessConfigurationChanges) @@ -236,11 +241,6 @@ private:      class TouchState;      std::shared_ptr<TouchState> touch_state; - -    /** -     * Clip the provided coordinates to be inside the touchscreen area. -     */ -    std::tuple<unsigned, unsigned> ClipToTouchScreen(unsigned new_x, unsigned new_y) const;  };  } // namespace Core::Frontend diff --git a/src/core/hle/service/hid/hid.cpp b/src/core/hle/service/hid/hid.cpp index 4c1c0ac68..2aa1942cb 100644 --- a/src/core/hle/service/hid/hid.cpp +++ b/src/core/hle/service/hid/hid.cpp @@ -19,6 +19,7 @@  #include "core/hle/kernel/k_shared_memory.h"  #include "core/hle/kernel/k_writable_event.h"  #include "core/hle/kernel/kernel.h" +#include "core/hle/kernel/transfer_memory.h"  #include "core/hle/service/hid/errors.h"  #include "core/hle/service/hid/hid.h"  #include "core/hle/service/hid/irs.h" @@ -1484,7 +1485,43 @@ void Hid::StopSevenSixAxisSensor(Kernel::HLERequestContext& ctx) {  }  void Hid::InitializeSevenSixAxisSensor(Kernel::HLERequestContext& ctx) { -    LOG_WARNING(Service_HID, "(STUBBED) called"); +    IPC::RequestParser rp{ctx}; +    const auto applet_resource_user_id{rp.Pop<u64>()}; +    const auto t_mem_1_size{rp.Pop<u64>()}; +    const auto t_mem_2_size{rp.Pop<u64>()}; +    const auto t_mem_1_handle{ctx.GetCopyHandle(0)}; +    const auto t_mem_2_handle{ctx.GetCopyHandle(1)}; + +    ASSERT_MSG(t_mem_1_size == 0x1000, "t_mem_1_size is not 0x1000 bytes"); +    ASSERT_MSG(t_mem_2_size == 0x7F000, "t_mem_2_size is not 0x7F000 bytes"); + +    auto t_mem_1 = +        system.CurrentProcess()->GetHandleTable().Get<Kernel::TransferMemory>(t_mem_1_handle); + +    if (t_mem_1 == nullptr) { +        LOG_ERROR(Service_HID, "t_mem_1 is a nullptr for handle=0x{:08X}", t_mem_1_handle); +        IPC::ResponseBuilder rb{ctx, 2}; +        rb.Push(RESULT_UNKNOWN); +        return; +    } + +    auto t_mem_2 = +        system.CurrentProcess()->GetHandleTable().Get<Kernel::TransferMemory>(t_mem_2_handle); + +    if (t_mem_2 == nullptr) { +        LOG_ERROR(Service_HID, "t_mem_2 is a nullptr for handle=0x{:08X}", t_mem_2_handle); +        IPC::ResponseBuilder rb{ctx, 2}; +        rb.Push(RESULT_UNKNOWN); +        return; +    } + +    ASSERT_MSG(t_mem_1->GetSize() == 0x1000, "t_mem_1 has incorrect size"); +    ASSERT_MSG(t_mem_2->GetSize() == 0x7F000, "t_mem_2 has incorrect size"); + +    LOG_WARNING(Service_HID, +                "(STUBBED) called, t_mem_1_handle=0x{:08X}, t_mem_2_handle=0x{:08X}, " +                "applet_resource_user_id={}", +                t_mem_1_handle, t_mem_2_handle, applet_resource_user_id);      IPC::ResponseBuilder rb{ctx, 2};      rb.Push(RESULT_SUCCESS); diff --git a/src/yuzu_cmd/CMakeLists.txt b/src/yuzu_cmd/CMakeLists.txt index 8461f8896..4bf25727b 100644 --- a/src/yuzu_cmd/CMakeLists.txt +++ b/src/yuzu_cmd/CMakeLists.txt @@ -20,7 +20,6 @@ add_executable(yuzu-cmd      emu_window/emu_window_sdl2_gl.h      emu_window/emu_window_sdl2_vk.cpp      emu_window/emu_window_sdl2_vk.h -    resource.h      yuzu.cpp      yuzu.rc  ) diff --git a/src/yuzu_cmd/emu_window/emu_window_sdl2.cpp b/src/yuzu_cmd/emu_window/emu_window_sdl2.cpp index 3bb555a6b..d64f81106 100644 --- a/src/yuzu_cmd/emu_window/emu_window_sdl2.cpp +++ b/src/yuzu_cmd/emu_window/emu_window_sdl2.cpp @@ -238,6 +238,6 @@ void EmuWindow_SDL2::SetWindowIcon() {      SDL_FreeSurface(window_icon);  } -void EmuWindow_SDL2::OnMinimalClientAreaChangeRequest(std::pair<unsigned, unsigned> minimal_size) { +void EmuWindow_SDL2::OnMinimalClientAreaChangeRequest(std::pair<u32, u32> minimal_size) {      SDL_SetWindowMinimumSize(render_window, minimal_size.first, minimal_size.second);  } diff --git a/src/yuzu_cmd/emu_window/emu_window_sdl2.h b/src/yuzu_cmd/emu_window/emu_window_sdl2.h index 0e17bbca7..1b9ab5b93 100644 --- a/src/yuzu_cmd/emu_window/emu_window_sdl2.h +++ b/src/yuzu_cmd/emu_window/emu_window_sdl2.h @@ -71,7 +71,7 @@ protected:      void Fullscreen();      /// Called when a configuration change affects the minimal size of the window -    void OnMinimalClientAreaChangeRequest(std::pair<unsigned, unsigned> minimal_size) override; +    void OnMinimalClientAreaChangeRequest(std::pair<u32, u32> minimal_size) override;      /// Is the window still open?      bool is_open = true; diff --git a/src/yuzu_cmd/resource.h b/src/yuzu_cmd/resource.h deleted file mode 100644 index df8e459e4..000000000 --- a/src/yuzu_cmd/resource.h +++ /dev/null @@ -1,16 +0,0 @@ -//{{NO_DEPENDENCIES}} -// Microsoft Visual C++ generated include file. -// Used by pcafe.rc -// -#define IDI_ICON3 103 - -// Next default values for new objects -// -#ifdef APSTUDIO_INVOKED -#ifndef APSTUDIO_READONLY_SYMBOLS -#define _APS_NEXT_RESOURCE_VALUE 105 -#define _APS_NEXT_COMMAND_VALUE 40001 -#define _APS_NEXT_CONTROL_VALUE 1001 -#define _APS_NEXT_SYMED_VALUE 101 -#endif -#endif | 
