Merge branch 'master' of github.com:melonDS-emu/melonDS
This commit is contained in:
commit
fd1e4379b9
|
@ -1,4 +1,4 @@
|
||||||
cmake_minimum_required(VERSION 3.15)
|
cmake_minimum_required(VERSION 3.16)
|
||||||
|
|
||||||
cmake_policy(VERSION 3.15)
|
cmake_policy(VERSION 3.15)
|
||||||
if (POLICY CMP0076)
|
if (POLICY CMP0076)
|
||||||
|
@ -9,6 +9,11 @@ set(CMAKE_POLICY_DEFAULT_CMP0069 NEW)
|
||||||
|
|
||||||
set(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake" ${CMAKE_MODULE_PATH})
|
set(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake" ${CMAKE_MODULE_PATH})
|
||||||
|
|
||||||
|
option(USE_VCPKG "Use vcpkg for dependency packages" OFF)
|
||||||
|
if (USE_VCPKG)
|
||||||
|
include(ConfigureVcpkg)
|
||||||
|
endif()
|
||||||
|
|
||||||
project(melonDS
|
project(melonDS
|
||||||
VERSION 0.9.5
|
VERSION 0.9.5
|
||||||
DESCRIPTION "DS emulator, sorta"
|
DESCRIPTION "DS emulator, sorta"
|
||||||
|
|
|
@ -0,0 +1,90 @@
|
||||||
|
include(FetchContent)
|
||||||
|
|
||||||
|
set(_DEFAULT_VCPKG_ROOT "${CMAKE_SOURCE_DIR}/vcpkg")
|
||||||
|
set(VCPKG_ROOT "${_DEFAULT_VCPKG_ROOT}" CACHE STRING "The path to the vcpkg repository")
|
||||||
|
|
||||||
|
if (VCPKG_ROOT STREQUAL "${_DEFAULT_VCPKG_ROOT}")
|
||||||
|
FetchContent_Declare(vcpkg
|
||||||
|
GIT_REPOSITORY "https://github.com/Microsoft/vcpkg.git"
|
||||||
|
GIT_TAG 2023.12.12
|
||||||
|
SOURCE_DIR "${CMAKE_SOURCE_DIR}/vcpkg")
|
||||||
|
FetchContent_MakeAvailable(vcpkg)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(VCPKG_OVERLAY_TRIPLETS "${CMAKE_SOURCE_DIR}/cmake/overlay-triplets")
|
||||||
|
|
||||||
|
option(USE_RECOMMENDED_TRIPLETS "Use the recommended triplets that are used for official builds" ON)
|
||||||
|
|
||||||
|
if (CMAKE_OSX_ARCHITECTURES MATCHES ";")
|
||||||
|
message(FATAL_ERROR "macOS universal builds are not supported. Build them individually and combine afterwards instead.")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (USE_RECOMMENDED_TRIPLETS)
|
||||||
|
execute_process(
|
||||||
|
COMMAND uname -m
|
||||||
|
OUTPUT_VARIABLE _HOST_PROCESSOR
|
||||||
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
||||||
|
|
||||||
|
set(_CAN_TARGET_AS_HOST OFF)
|
||||||
|
|
||||||
|
if (APPLE)
|
||||||
|
if (NOT CMAKE_OSX_ARCHITECTURES)
|
||||||
|
if (_HOST_PROCESSOR STREQUAL arm64)
|
||||||
|
set(CMAKE_OSX_ARCHITECTURES arm64)
|
||||||
|
else()
|
||||||
|
set(CMAKE_OSX_ARCHITECTURES x86_64)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (CMAKE_OSX_ARCHITECTURES STREQUAL arm64)
|
||||||
|
set(_WANTED_TRIPLET arm64-osx-11-release)
|
||||||
|
set(CMAKE_OSX_DEPLOYMENT_TARGET 11.0)
|
||||||
|
else()
|
||||||
|
set(_WANTED_TRIPLET x64-osx-1015-release)
|
||||||
|
set(CMAKE_OSX_DEPLOYMENT_TARGET 10.15)
|
||||||
|
endif()
|
||||||
|
elseif(WIN32)
|
||||||
|
# TODO Windows arm64 if possible
|
||||||
|
set(_CAN_TARGET_AS_HOST ON)
|
||||||
|
set(_WANTED_TRIPLET x64-mingw-static)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Don't override it if the user set something else
|
||||||
|
if (NOT VCPKG_TARGET_TRIPLET)
|
||||||
|
set(VCPKG_TARGET_TRIPLET "${_WANTED_TRIPLET}")
|
||||||
|
else()
|
||||||
|
set(_WANTED_TRIPLET "${VCPKG_TARGET_TRIPLET}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (APPLE)
|
||||||
|
if (_HOST_PROCESSOR MATCHES arm64)
|
||||||
|
if (_WANTED_TRIPLET MATCHES "^arm64-osx-")
|
||||||
|
set(_CAN_TARGET_AS_HOST ON)
|
||||||
|
elseif (_WANTED_TRIPLET STREQUAL "x64-osx-1015-release")
|
||||||
|
# Use the default triplet for when building for arm64
|
||||||
|
# because we're probably making a universal build
|
||||||
|
set(VCPKG_HOST_TRIPLET arm64-osx-11-release)
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
if (_WANTED_TRIPLET MATCHES "^x64-osx-")
|
||||||
|
set(_CAN_TARGET_AS_HOST ON)
|
||||||
|
elseif (_WANTED_TRIPLET STREQUAL "arm64-osx-11-release")
|
||||||
|
set(VCPKG_HOST_TRIPLET x64-osx-1015-release)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# If host and target triplet differ, vcpkg seems to always assume that the host can't run the target's binaries.
|
||||||
|
# In cases like cross compiling from ARM -> Intel macOS, or target being an older version of the host OS, we *can* do that so the packages built targeting the host are redundant.
|
||||||
|
if (_CAN_TARGET_AS_HOST AND NOT VCPKG_HOST_TRIPLET)
|
||||||
|
option(VCPKG_TARGET_AS_HOST "Use the target as host triplet to speed up builds" ON)
|
||||||
|
else()
|
||||||
|
option(VCPKG_TARGET_AS_HOST "Use the target as host triplet to speed up builds" OFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (VCPKG_TARGET_AS_HOST)
|
||||||
|
set(VCPKG_HOST_TRIPLET "${VCPKG_TARGET_TRIPLET}" CACHE STRING "Host triplet to use for vcpkg")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(CMAKE_TOOLCHAIN_FILE "${VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake")
|
|
@ -0,0 +1,12 @@
|
||||||
|
set(VCPKG_TARGET_ARCHITECTURE arm64)
|
||||||
|
set(VCPKG_CRT_LINKAGE dynamic)
|
||||||
|
set(VCPKG_LIBRARY_LINKAGE static)
|
||||||
|
|
||||||
|
set(VCPKG_CMAKE_SYSTEM_NAME Darwin)
|
||||||
|
set(VCPKG_CMAKE_SYSTEM_VERSION 11.0)
|
||||||
|
set(VCPKG_OSX_ARCHITECTURES arm64)
|
||||||
|
set(VCPKG_BUILD_TYPE release)
|
||||||
|
set(VCPKG_OSX_DEPLOYMENT_TARGET 11.0)
|
||||||
|
|
||||||
|
set(VCPKG_C_FLAGS -mmacosx-version-min=11.0)
|
||||||
|
set(VCPKG_CXX_FLAGS -mmacosx-version-min=11.0)
|
|
@ -0,0 +1,12 @@
|
||||||
|
set(VCPKG_TARGET_ARCHITECTURE x64)
|
||||||
|
set(VCPKG_CRT_LINKAGE dynamic)
|
||||||
|
set(VCPKG_LIBRARY_LINKAGE static)
|
||||||
|
|
||||||
|
set(VCPKG_CMAKE_SYSTEM_NAME Darwin)
|
||||||
|
set(VCPKG_CMAKE_SYSTEM_VERSION 10.15)
|
||||||
|
set(VCPKG_OSX_ARCHITECTURES x86_64)
|
||||||
|
set(VCPKG_BUILD_TYPE release)
|
||||||
|
set(VCPKG_OSX_DEPLOYMENT_TARGET 10.15)
|
||||||
|
|
||||||
|
set(VCPKG_C_FLAGS -mmacosx-version-min=10.15)
|
||||||
|
set(VCPKG_CXX_FLAGS -mmacosx-version-min=10.15)
|
|
@ -122,7 +122,8 @@ NANDImage::NANDImage(NANDImage&& other) noexcept :
|
||||||
ConsoleID(other.ConsoleID),
|
ConsoleID(other.ConsoleID),
|
||||||
FATIV(other.FATIV),
|
FATIV(other.FATIV),
|
||||||
FATKey(other.FATKey),
|
FATKey(other.FATKey),
|
||||||
ESKey(other.ESKey)
|
ESKey(other.ESKey),
|
||||||
|
Length(other.Length)
|
||||||
{
|
{
|
||||||
other.CurFile = nullptr;
|
other.CurFile = nullptr;
|
||||||
}
|
}
|
||||||
|
@ -140,6 +141,7 @@ NANDImage& NANDImage::operator=(NANDImage&& other) noexcept
|
||||||
FATIV = other.FATIV;
|
FATIV = other.FATIV;
|
||||||
FATKey = other.FATKey;
|
FATKey = other.FATKey;
|
||||||
ESKey = other.ESKey;
|
ESKey = other.ESKey;
|
||||||
|
Length = other.Length;
|
||||||
|
|
||||||
other.CurFile = nullptr;
|
other.CurFile = nullptr;
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,14 +32,8 @@ using namespace Platform;
|
||||||
using std::string;
|
using std::string;
|
||||||
|
|
||||||
FATStorage::FATStorage(const std::string& filename, u64 size, bool readonly, const std::optional<string>& sourcedir) :
|
FATStorage::FATStorage(const std::string& filename, u64 size, bool readonly, const std::optional<string>& sourcedir) :
|
||||||
FilePath(filename),
|
FATStorage(FATStorageArgs { filename, size, readonly, sourcedir })
|
||||||
FileSize(size),
|
|
||||||
ReadOnly(readonly),
|
|
||||||
SourceDir(sourcedir)
|
|
||||||
{
|
{
|
||||||
Load(filename, size, sourcedir);
|
|
||||||
|
|
||||||
File = Platform::OpenLocalFile(FilePath, FileMode::ReadWriteExisting);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
FATStorage::FATStorage(const FATStorageArgs& args) noexcept :
|
FATStorage::FATStorage(const FATStorageArgs& args) noexcept :
|
||||||
|
@ -55,7 +49,7 @@ FATStorage::FATStorage(FATStorageArgs&& args) noexcept :
|
||||||
{
|
{
|
||||||
Load(FilePath, FileSize, SourceDir);
|
Load(FilePath, FileSize, SourceDir);
|
||||||
|
|
||||||
File = nullptr;
|
File = Platform::OpenLocalFile(FilePath, FileMode::ReadWriteExisting);
|
||||||
}
|
}
|
||||||
|
|
||||||
FATStorage::FATStorage(FATStorage&& other) noexcept
|
FATStorage::FATStorage(FATStorage&& other) noexcept
|
||||||
|
|
|
@ -48,8 +48,8 @@ class FATStorage
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
FATStorage(const std::string& filename, u64 size, bool readonly, const std::optional<std::string>& sourcedir = std::nullopt);
|
FATStorage(const std::string& filename, u64 size, bool readonly, const std::optional<std::string>& sourcedir = std::nullopt);
|
||||||
FATStorage(const FATStorageArgs& args) noexcept;
|
explicit FATStorage(const FATStorageArgs& args) noexcept;
|
||||||
FATStorage(FATStorageArgs&& args) noexcept;
|
explicit FATStorage(FATStorageArgs&& args) noexcept;
|
||||||
FATStorage(FATStorage&& other) noexcept;
|
FATStorage(FATStorage&& other) noexcept;
|
||||||
FATStorage(const FATStorage& other) = delete;
|
FATStorage(const FATStorage& other) = delete;
|
||||||
FATStorage& operator=(const FATStorage& other) = delete;
|
FATStorage& operator=(const FATStorage& other) = delete;
|
||||||
|
|
|
@ -1657,9 +1657,15 @@ std::unique_ptr<CartCommon> ParseROM(std::unique_ptr<u8[]>&& romdata, u32 romlen
|
||||||
std::unique_ptr<u8[]> sram = args ? std::move(args->SRAM) : nullptr;
|
std::unique_ptr<u8[]> sram = args ? std::move(args->SRAM) : nullptr;
|
||||||
u32 sramlen = args ? args->SRAMLength : 0;
|
u32 sramlen = args ? args->SRAMLength : 0;
|
||||||
if (homebrew)
|
if (homebrew)
|
||||||
cart = std::make_unique<CartHomebrew>(std::move(cartrom), cartromsize, cartid, romparams, args ? std::move(args->SDCard) : std::nullopt);
|
{
|
||||||
|
std::optional<FATStorage> sdcard = args && args->SDCard ? std::make_optional<FATStorage>(std::move(*args->SDCard)) : std::nullopt;
|
||||||
|
cart = std::make_unique<CartHomebrew>(std::move(cartrom), cartromsize, cartid, romparams, std::move(sdcard));
|
||||||
|
}
|
||||||
else if (gametitle[0] == 0 && !strncmp("SD/TF-NDS", gametitle + 1, 9) && gamecode == 0x414D5341)
|
else if (gametitle[0] == 0 && !strncmp("SD/TF-NDS", gametitle + 1, 9) && gamecode == 0x414D5341)
|
||||||
cart = std::make_unique<CartR4>(std::move(cartrom), cartromsize, cartid, romparams, CartR4TypeR4, CartR4LanguageEnglish, args ? std::move(args->SDCard) : std::nullopt);
|
{
|
||||||
|
std::optional<FATStorage> sdcard = args && args->SDCard ? std::make_optional<FATStorage>(std::move(*args->SDCard)) : std::nullopt;
|
||||||
|
cart = std::make_unique<CartR4>(std::move(cartrom), cartromsize, cartid, romparams, CartR4TypeR4, CartR4LanguageEnglish, std::move(sdcard));
|
||||||
|
}
|
||||||
else if (cartid & 0x08000000)
|
else if (cartid & 0x08000000)
|
||||||
cart = std::make_unique<CartRetailNAND>(std::move(cartrom), cartromsize, cartid, romparams, std::move(sram), sramlen);
|
cart = std::make_unique<CartRetailNAND>(std::move(cartrom), cartromsize, cartid, romparams, std::move(sram), sramlen);
|
||||||
else if (irversion != 0)
|
else if (irversion != 0)
|
||||||
|
|
|
@ -84,11 +84,11 @@ if (BUILD_STATIC)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
pkg_check_modules(SDL2 REQUIRED IMPORTED_TARGET sdl2)
|
pkg_check_modules(SDL2 REQUIRED IMPORTED_TARGET sdl2)
|
||||||
pkg_check_modules(Slirp REQUIRED IMPORTED_TARGET slirp)
|
pkg_check_modules(Slirp REQUIRED slirp)
|
||||||
pkg_check_modules(LibArchive REQUIRED IMPORTED_TARGET libarchive)
|
pkg_check_modules(LibArchive REQUIRED IMPORTED_TARGET libarchive)
|
||||||
pkg_check_modules(Zstd REQUIRED IMPORTED_TARGET libzstd)
|
pkg_check_modules(Zstd REQUIRED IMPORTED_TARGET libzstd)
|
||||||
|
|
||||||
fix_interface_includes(PkgConfig::SDL2 PkgConfig::Slirp PkgConfig::LibArchive)
|
fix_interface_includes(PkgConfig::SDL2 PkgConfig::LibArchive)
|
||||||
|
|
||||||
add_compile_definitions(ARCHIVE_SUPPORT_ENABLED)
|
add_compile_definitions(ARCHIVE_SUPPORT_ENABLED)
|
||||||
|
|
||||||
|
@ -160,9 +160,12 @@ else()
|
||||||
target_include_directories(melonDS PUBLIC ${Qt5Gui_PRIVATE_INCLUDE_DIRS})
|
target_include_directories(melonDS PUBLIC ${Qt5Gui_PRIVATE_INCLUDE_DIRS})
|
||||||
endif()
|
endif()
|
||||||
target_link_libraries(melonDS PRIVATE core)
|
target_link_libraries(melonDS PRIVATE core)
|
||||||
target_link_libraries(melonDS PRIVATE PkgConfig::SDL2 PkgConfig::Slirp PkgConfig::LibArchive PkgConfig::Zstd)
|
target_link_libraries(melonDS PRIVATE PkgConfig::SDL2 PkgConfig::LibArchive PkgConfig::Zstd)
|
||||||
target_link_libraries(melonDS PRIVATE ${QT_LINK_LIBS} ${CMAKE_DL_LIBS})
|
target_link_libraries(melonDS PRIVATE ${QT_LINK_LIBS} ${CMAKE_DL_LIBS})
|
||||||
|
|
||||||
|
target_include_directories(melonDS PRIVATE "${Slirp_INCLUDE_DIRS}")
|
||||||
|
target_link_libraries(melonDS PRIVATE "${Slirp_LINK_LIBRARIES}")
|
||||||
|
|
||||||
if (UNIX)
|
if (UNIX)
|
||||||
option(PORTABLE "Make a portable build that looks for its configuration in the current directory" OFF)
|
option(PORTABLE "Make a portable build that looks for its configuration in the current directory" OFF)
|
||||||
elseif (WIN32)
|
elseif (WIN32)
|
||||||
|
|
|
@ -25,9 +25,11 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
#include <cmath>
|
||||||
|
|
||||||
#include <QPaintEvent>
|
#include <QPaintEvent>
|
||||||
#include <QPainter>
|
#include <QPainter>
|
||||||
|
#include <QDebug>
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
#ifndef APPLE
|
#ifndef APPLE
|
||||||
#include <qpa/qplatformnativeinterface.h>
|
#include <qpa/qplatformnativeinterface.h>
|
||||||
|
|
|
@ -326,10 +326,14 @@ bool EmuThread::UpdateConsole(UpdateConsoleNDSArgs&& ndsargs, UpdateConsoleGBAAr
|
||||||
NDS::Current = nullptr;
|
NDS::Current = nullptr;
|
||||||
|
|
||||||
NDS = CreateConsole(std::move(nextndscart), std::move(nextgbacart));
|
NDS = CreateConsole(std::move(nextndscart), std::move(nextgbacart));
|
||||||
|
|
||||||
|
if (NDS == nullptr)
|
||||||
|
return false;
|
||||||
|
|
||||||
NDS->Reset();
|
NDS->Reset();
|
||||||
NDS::Current = NDS.get();
|
NDS::Current = NDS.get();
|
||||||
|
|
||||||
return NDS != nullptr;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto arm9bios = ROMManager::LoadARM9BIOS();
|
auto arm9bios = ROMManager::LoadARM9BIOS();
|
||||||
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
{
|
||||||
|
"dependencies": [
|
||||||
|
"sdl2",
|
||||||
|
"libarchive",
|
||||||
|
"libslirp",
|
||||||
|
"zstd",
|
||||||
|
{
|
||||||
|
"name": "qtbase",
|
||||||
|
"default-features": false,
|
||||||
|
"features": ["gui", "png", "thread", "widgets", "opengl", "zstd"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "qtmultimedia",
|
||||||
|
"default-features": false
|
||||||
|
},
|
||||||
|
"qtsvg"
|
||||||
|
]
|
||||||
|
}
|
Loading…
Reference in New Issue