diff options
| -rw-r--r-- | CMakeLists.txt | 20 | ||||
| -rw-r--r-- | CMakeModules/DownloadExternals.cmake | 22 | ||||
| -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/resource.h | 16 |
5 files changed, 75 insertions, 23 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 | |||
| 19 | 19 | ||
| 20 | option(ENABLE_WEB_SERVICE "Enable web services (telemetry, etc.)" ON) | 20 | option(ENABLE_WEB_SERVICE "Enable web services (telemetry, etc.)" ON) |
| 21 | 21 | ||
| 22 | option(YUZU_USE_BUNDLED_BOOST "Download bundled Boost" OFF) | ||
| 23 | |||
| 22 | CMAKE_DEPENDENT_OPTION(YUZU_USE_BUNDLED_FFMPEG "Download/Build bundled FFmpeg" ON "WIN32" OFF) | 24 | CMAKE_DEPENDENT_OPTION(YUZU_USE_BUNDLED_FFMPEG "Download/Build bundled FFmpeg" ON "WIN32" OFF) |
| 23 | 25 | ||
| 24 | option(YUZU_USE_QT_WEB_ENGINE "Use QtWebEngine for web applet implementation" OFF) | 26 | option(YUZU_USE_QT_WEB_ENGINE "Use QtWebEngine for web applet implementation" OFF) |
| @@ -199,7 +201,9 @@ macro(yuzu_find_packages) | |||
| 199 | unset(FN_FORCE_REQUIRED) | 201 | unset(FN_FORCE_REQUIRED) |
| 200 | endmacro() | 202 | endmacro() |
| 201 | 203 | ||
| 202 | find_package(Boost 1.73.0 COMPONENTS context headers QUIET) | 204 | if (NOT YUZU_USE_BUNDLED_BOOST) |
| 205 | find_package(Boost 1.73.0 COMPONENTS context headers QUIET) | ||
| 206 | endif() | ||
| 203 | if (Boost_FOUND) | 207 | if (Boost_FOUND) |
| 204 | set(Boost_LIBRARIES Boost::boost) | 208 | set(Boost_LIBRARIES Boost::boost) |
| 205 | # Conditionally add Boost::context only if the active version of the Conan or system Boost package provides it | 209 | # 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) | |||
| 210 | if (TARGET Boost::context) | 214 | if (TARGET Boost::context) |
| 211 | list(APPEND Boost_LIBRARIES Boost::context) | 215 | list(APPEND Boost_LIBRARIES Boost::context) |
| 212 | endif() | 216 | endif() |
| 217 | elseif (${CMAKE_SYSTEM_NAME} STREQUAL "Linux" OR YUZU_USE_BUNDLED_BOOST) | ||
| 218 | message(STATUS "Boost 1.73.0 or newer not found, falling back to externals") | ||
| 219 | set(YUZU_USE_BUNDLED_BOOST ON CACHE BOOL "Download bundled Boost" FORCE) | ||
| 220 | |||
| 221 | # Use yuzu Boost binaries | ||
| 222 | set(Boost_EXT_NAME "boost_1_75_0") | ||
| 223 | set(Boost_PATH "${CMAKE_BINARY_DIR}/externals/${Boost_EXT_NAME}") | ||
| 224 | download_bundled_external("boost/" ${Boost_EXT_NAME} "") | ||
| 225 | set(Boost_USE_DEBUG_RUNTIME FALSE) | ||
| 226 | set(Boost_USE_STATIC_LIBS ON) | ||
| 227 | find_package(Boost 1.75.0 REQUIRED COMPONENTS context headers PATHS ${Boost_PATH} NO_DEFAULT_PATH) | ||
| 228 | # Manually set the include dirs since the find_package sets it incorrectly | ||
| 229 | set(Boost_INCLUDE_DIRS ${Boost_PATH}/include CACHE PATH "Path to Boost headers" FORCE) | ||
| 230 | include_directories(SYSTEM "${Boost_INCLUDE_DIRS}") | ||
| 213 | else() | 231 | else() |
| 214 | message(STATUS "Boost 1.73.0 or newer not found, falling back to Conan") | 232 | message(STATUS "Boost 1.73.0 or newer not found, falling back to Conan") |
| 215 | list(APPEND CONAN_REQUIRED_LIBS "boost/1.73.0") | 233 | 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 @@ | |||
| 4 | # remote_path: path to the file to download, relative to the remote repository root | 4 | # remote_path: path to the file to download, relative to the remote repository root |
| 5 | # prefix_var: name of a variable which will be set with the path to the extracted contents | 5 | # prefix_var: name of a variable which will be set with the path to the extracted contents |
| 6 | function(download_bundled_external remote_path lib_name prefix_var) | 6 | function(download_bundled_external remote_path lib_name prefix_var) |
| 7 | |||
| 8 | set(package_repo "no_platform") | ||
| 9 | set(package_extension "no_platform") | ||
| 10 | if (WIN32) | ||
| 11 | set(package_repo "ext-windows-bin/raw/master/") | ||
| 12 | set(package_extension ".7z") | ||
| 13 | elseif (${CMAKE_SYSTEM_NAME} STREQUAL "Linux") | ||
| 14 | set(package_repo "ext-linux-bin/raw/main/") | ||
| 15 | set(package_extension ".tar.xz") | ||
| 16 | else() | ||
| 17 | message(FATAL_ERROR "No package available for this platform") | ||
| 18 | endif() | ||
| 19 | set(package_url "https://github.com/yuzu-emu/${package_repo}") | ||
| 20 | |||
| 7 | set(prefix "${CMAKE_BINARY_DIR}/externals/${lib_name}") | 21 | set(prefix "${CMAKE_BINARY_DIR}/externals/${lib_name}") |
| 8 | if (NOT EXISTS "${prefix}") | 22 | if (NOT EXISTS "${prefix}") |
| 9 | message(STATUS "Downloading binaries for ${lib_name}...") | 23 | message(STATUS "Downloading binaries for ${lib_name}...") |
| 10 | file(DOWNLOAD | 24 | file(DOWNLOAD |
| 11 | https://github.com/yuzu-emu/ext-windows-bin/raw/master/${remote_path}${lib_name}.7z | 25 | ${package_url}${remote_path}${lib_name}${package_extension} |
| 12 | "${CMAKE_BINARY_DIR}/externals/${lib_name}.7z" SHOW_PROGRESS) | 26 | "${CMAKE_BINARY_DIR}/externals/${lib_name}${package_extension}" SHOW_PROGRESS) |
| 13 | execute_process(COMMAND ${CMAKE_COMMAND} -E tar xf "${CMAKE_BINARY_DIR}/externals/${lib_name}.7z" | 27 | execute_process(COMMAND ${CMAKE_COMMAND} -E tar xf "${CMAKE_BINARY_DIR}/externals/${lib_name}${package_extension}" |
| 14 | WORKING_DIRECTORY "${CMAKE_BINARY_DIR}/externals") | 28 | WORKING_DIRECTORY "${CMAKE_BINARY_DIR}/externals") |
| 15 | endif() | 29 | endif() |
| 16 | message(STATUS "Using bundled binaries at ${prefix}") | 30 | message(STATUS "Using bundled binaries at ${prefix}") |
| 17 | set(${prefix_var} "${prefix}" PARENT_SCOPE) | 31 | set(${prefix_var} "${prefix}" PARENT_SCOPE) |
| 18 | endfunction() \ No newline at end of file | 32 | endfunction() |
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 @@ | |||
| 19 | #include "core/hle/kernel/k_shared_memory.h" | 19 | #include "core/hle/kernel/k_shared_memory.h" |
| 20 | #include "core/hle/kernel/k_writable_event.h" | 20 | #include "core/hle/kernel/k_writable_event.h" |
| 21 | #include "core/hle/kernel/kernel.h" | 21 | #include "core/hle/kernel/kernel.h" |
| 22 | #include "core/hle/kernel/transfer_memory.h" | ||
| 22 | #include "core/hle/service/hid/errors.h" | 23 | #include "core/hle/service/hid/errors.h" |
| 23 | #include "core/hle/service/hid/hid.h" | 24 | #include "core/hle/service/hid/hid.h" |
| 24 | #include "core/hle/service/hid/irs.h" | 25 | #include "core/hle/service/hid/irs.h" |
| @@ -1484,7 +1485,43 @@ void Hid::StopSevenSixAxisSensor(Kernel::HLERequestContext& ctx) { | |||
| 1484 | } | 1485 | } |
| 1485 | 1486 | ||
| 1486 | void Hid::InitializeSevenSixAxisSensor(Kernel::HLERequestContext& ctx) { | 1487 | void Hid::InitializeSevenSixAxisSensor(Kernel::HLERequestContext& ctx) { |
| 1487 | LOG_WARNING(Service_HID, "(STUBBED) called"); | 1488 | IPC::RequestParser rp{ctx}; |
| 1489 | const auto applet_resource_user_id{rp.Pop<u64>()}; | ||
| 1490 | const auto t_mem_1_size{rp.Pop<u64>()}; | ||
| 1491 | const auto t_mem_2_size{rp.Pop<u64>()}; | ||
| 1492 | const auto t_mem_1_handle{ctx.GetCopyHandle(0)}; | ||
| 1493 | const auto t_mem_2_handle{ctx.GetCopyHandle(1)}; | ||
| 1494 | |||
| 1495 | ASSERT_MSG(t_mem_1_size == 0x1000, "t_mem_1_size is not 0x1000 bytes"); | ||
| 1496 | ASSERT_MSG(t_mem_2_size == 0x7F000, "t_mem_2_size is not 0x7F000 bytes"); | ||
| 1497 | |||
| 1498 | auto t_mem_1 = | ||
| 1499 | system.CurrentProcess()->GetHandleTable().Get<Kernel::TransferMemory>(t_mem_1_handle); | ||
| 1500 | |||
| 1501 | if (t_mem_1 == nullptr) { | ||
| 1502 | LOG_ERROR(Service_HID, "t_mem_1 is a nullptr for handle=0x{:08X}", t_mem_1_handle); | ||
| 1503 | IPC::ResponseBuilder rb{ctx, 2}; | ||
| 1504 | rb.Push(RESULT_UNKNOWN); | ||
| 1505 | return; | ||
| 1506 | } | ||
| 1507 | |||
| 1508 | auto t_mem_2 = | ||
| 1509 | system.CurrentProcess()->GetHandleTable().Get<Kernel::TransferMemory>(t_mem_2_handle); | ||
| 1510 | |||
| 1511 | if (t_mem_2 == nullptr) { | ||
| 1512 | LOG_ERROR(Service_HID, "t_mem_2 is a nullptr for handle=0x{:08X}", t_mem_2_handle); | ||
| 1513 | IPC::ResponseBuilder rb{ctx, 2}; | ||
| 1514 | rb.Push(RESULT_UNKNOWN); | ||
| 1515 | return; | ||
| 1516 | } | ||
| 1517 | |||
| 1518 | ASSERT_MSG(t_mem_1->GetSize() == 0x1000, "t_mem_1 has incorrect size"); | ||
| 1519 | ASSERT_MSG(t_mem_2->GetSize() == 0x7F000, "t_mem_2 has incorrect size"); | ||
| 1520 | |||
| 1521 | LOG_WARNING(Service_HID, | ||
| 1522 | "(STUBBED) called, t_mem_1_handle=0x{:08X}, t_mem_2_handle=0x{:08X}, " | ||
| 1523 | "applet_resource_user_id={}", | ||
| 1524 | t_mem_1_handle, t_mem_2_handle, applet_resource_user_id); | ||
| 1488 | 1525 | ||
| 1489 | IPC::ResponseBuilder rb{ctx, 2}; | 1526 | IPC::ResponseBuilder rb{ctx, 2}; |
| 1490 | rb.Push(RESULT_SUCCESS); | 1527 | 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 | |||
| 20 | emu_window/emu_window_sdl2_gl.h | 20 | emu_window/emu_window_sdl2_gl.h |
| 21 | emu_window/emu_window_sdl2_vk.cpp | 21 | emu_window/emu_window_sdl2_vk.cpp |
| 22 | emu_window/emu_window_sdl2_vk.h | 22 | emu_window/emu_window_sdl2_vk.h |
| 23 | resource.h | ||
| 24 | yuzu.cpp | 23 | yuzu.cpp |
| 25 | yuzu.rc | 24 | yuzu.rc |
| 26 | ) | 25 | ) |
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 @@ | |||
| 1 | //{{NO_DEPENDENCIES}} | ||
| 2 | // Microsoft Visual C++ generated include file. | ||
| 3 | // Used by pcafe.rc | ||
| 4 | // | ||
| 5 | #define IDI_ICON3 103 | ||
| 6 | |||
| 7 | // Next default values for new objects | ||
| 8 | // | ||
| 9 | #ifdef APSTUDIO_INVOKED | ||
| 10 | #ifndef APSTUDIO_READONLY_SYMBOLS | ||
| 11 | #define _APS_NEXT_RESOURCE_VALUE 105 | ||
| 12 | #define _APS_NEXT_COMMAND_VALUE 40001 | ||
| 13 | #define _APS_NEXT_CONTROL_VALUE 1001 | ||
| 14 | #define _APS_NEXT_SYMED_VALUE 101 | ||
| 15 | #endif | ||
| 16 | #endif | ||